summaryrefslogtreecommitdiffstats
path: root/dom/media/test/test_source_media.html
blob: 0889ef050be143976ae2916901ce5ccb55b28a89 (plain)
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
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>Media test: media attribute for the source element.</title>
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
<script type="text/javascript" src="manifest.js"></script>
<script type="text/javascript" src="../../../dom/html/test/reflect.js"></script>
</head>
<body>
<pre id="test">
<script type="text/javascript">
  var testCount = 0;
  function notifyFinished() {
    testCount++;
    if (testCount == 2) {
      SimpleTest.finish();
    }
  }

  function clearNode(n) {
    n.remove();
    n.src = "";
    while (n.firstChild) {
      n.removeChild(n.firstChild);
    }
  }

  SimpleTest.waitForExplicitFinish();

  reflectString({
    element: document.createElement("source"),
    attribute: "media",
  });

  var media = getPlayableVideo(gSmallTests);

  if (media == null) {
    todo(false, "No media supported.");
    SimpleTest.finish();
  } else {
    var v = document.createElement('video');
    v.preload = "metadata";
    v.innerHTML = "<source src=\"" + media.name + "?fail\" media=\"not all\">" +
                  "<source src=\""+ media.name + "?pass\" media=\"all\">";
    var v2 = document.createElement("video");
    v2.preload = "metadata";
    v2.innerHTML = "<source src=\""+ media.name +"?pass\">" +
                   "<source src=\""+ media.name + "?fail\" media=\"all\">";
    document.body.appendChild(v);
    document.body.appendChild(v2);

    v.addEventListener("loadedmetadata", function(e) {
        ok(/pass/.test(e.target.currentSrc),
          "The source has been chosen according to the media attribute.");
        clearNode(e.target);
        notifyFinished();
        });
    v2.addEventListener("loadedmetadata", function(e) {
        ok(/pass/.test(e.target.currentSrc),
          "If no media attribute is specified, it defaults to \'all\'.")
        clearNode(e.target);
        notifyFinished();
    });
  }

</script>
</pre>
</body>
</html>