1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
  
     | 
    
      <!doctype html>
<html>
  <head>
    <title>Video controls test - Error</title>
    <script src="/tests/SimpleTest/SimpleTest.js"></script>
    <script src="/tests/SimpleTest/EventUtils.js"></script>
    <script type="text/javascript" src="head.js"></script>
    <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
  </head>
  <body>
    <p id="display"></p>
    <div id="content">
      <video id="video" controls preload="auto"></video>
    </div>
    <script clas="testbody" type="application/javascript">
      const video = document.getElementById("video");
      const statusOverlay = getElementWithinVideo(video, "statusOverlay");
      const statusIcon = getElementWithinVideo(video, "statusIcon");
      const statusLabelErrorNoSource = getElementWithinVideo(
        video,
        "errorNoSource"
      );
      add_task(async function setup() {
        await SpecialPowers.pushPrefEnv({ set: [["media.cache_size", 40000]] });
      });
      add_task(async function check_normal_status() {
        await new Promise(resolve => {
          video.src = "seek_with_sound.webm";
          video.addEventListener("loadedmetadata", () =>
            SimpleTest.executeSoon(resolve)
          );
        });
        // Wait for the fade out transition to complete in case the throbber
        // shows up on slower platforms.
        await SimpleTest.promiseWaitForCondition(
          () => statusOverlay.hidden,
          "statusOverlay should not present without error"
        );
        ok(
          !statusOverlay.hasAttribute("status"),
          "statusOverlay should not be showing a state message."
        );
        isnot(
          statusIcon.getAttribute("type"),
          "error",
          "should not show error icon"
        );
      });
      add_task(async function invalid_source() {
        const errorType = "errorNoSource";
        await new Promise(resolve => {
          video.src = "invalid_source.webm";
          video.addEventListener("error", () =>
            SimpleTest.executeSoon(resolve)
          );
        });
        ok(
          !statusOverlay.hidden,
          `statusOverlay should show when ${errorType}`
        );
        is(
          statusOverlay.getAttribute("status"),
          errorType,
          `statusOverlay should have correct error state: ${errorType}`
        );
        is(
          statusIcon.getAttribute("type"),
          "error",
          `should show error icon when ${errorType}`
        );
        isnot(
          statusLabelErrorNoSource.getBoundingClientRect().height,
          0,
          "errorNoSource status label should be visible."
        );
      });
    </script>
  </body>
</html>
 
     |