summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/browsers/windows/nested-browsing-contexts/frameElement.sub.html
blob: f1d5581f68958390c81c008189cb34ed18ca6a25 (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
72
73
74
<!DOCTYPE html>
<meta charset="utf-8"/>
<title>HTML Test: window.frameElement</title>
<link rel="author" title="Intel" href="http://www.intel.com/" />
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script>

var t1 = async_test("The window's frameElement attribute must return its container element if it is a nested browsing context");
var t2 = async_test("The SecurityError must be thrown if the window accesses to frameElement attribute of a Window which does not have the same effective script origin");
var t3 = async_test("The window's frameElement attribute must return null if the container's document does not have the same effective script origin");

function on_load() {
  t1.step(function () {
    assert_equals(frames[0].frameElement, document.getElementById("fr1"),
                  "The frameElement attribute should be the first iframe element.");
    assert_equals(window["win2"].frameElement, document.getElementById("obj"),
                  "The frameElement attribute should be the object element.");
    assert_equals(window["win3"].frameElement, document.getElementById("emb"),
                  "The frameElement attribute should be the embed element.");
    assert_equals(document.getElementById("fr4").contentWindow[0].frameElement,
                  document.getElementById("fr4").contentDocument.getElementById("f1"),
                  "The frameElement attribute should be the frame element in 'test.html'.");
  });
  t1.done();

  t2.step(function () {
    assert_throws("SecurityError", function () { frames[1].frameElement; },
                  "The SecurityError exception should be thrown.");
  });
  t2.done();

  t3.step(function () {
    document.getElementById("fr5").contentWindow.postMessage(null, "*");
  });
  window.addEventListener("message", function (event) {
    var data = JSON.parse(event.data);
    if (data.name == "testcase3") {
      t3.step(function () {
        assert_equals(data.result, "window.frameElement = null",
                      "The frameElement attribute should be null.");
      });
      t3.done();
    }
  }, false);
}

</script>
<body onload="on_load()">
  <div id="log"></div>
  <iframe id="fr1"></iframe>
  <iframe id="fr2" src="test.html"></iframe> <!-- cross origin -->
  <iframe id="fr3" src="" style="display:none"></iframe>
  <object id="obj" name="win2" type="text/html" data="about:blank"></object>
  <embed id="emb" name="win3" type="image/svg+xml" src="/images/green.svg" />
  <iframe id="fr4" src="test.html"></iframe> <!-- same origin -->
  <iframe id="fr5" src="testcase3.html"></iframe> <!-- cross origin -->
  <script>

  setup(function () {
    var src_base = get_host_info().HTTP_REMOTE_ORIGIN;
    src_base += document.location.pathname.substring(0, document.location.pathname.lastIndexOf("/") + 1);
    document.getElementById("fr2").src = src_base + "test.html";
    document.getElementById("fr5").src = src_base + "testcase3.html";
  });

  test(function () {
    assert_equals(window.frameElement, null,
                  "The frameElement attribute should be null.");
  }, "The window's frameElement attribute must return null if it is not a nested browsing context");

  </script>
</body>