Source code
Revision control
Copy as Markdown
Other Tools
Test Info: Warnings
- This test gets skipped with pattern: http3 OR http2
- Manifest: js/xpconnect/tests/mochitest/mochitest.toml
<!DOCTYPE HTML>
<html>
<!--
-->
<head>
<meta charset="utf-8">
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
<script type="application/javascript">
SimpleTest.waitForExplicitFinish();
var gLoadCount = 0;
function loaded() {
if (++gLoadCount == 2)
go();
}
async function go() {
// Both same-origin and cross-origin names should be visible if they're set
// on the iframe element.
ok('winA' in window, "same-origin named access works");
ok(winA instanceof winA.Window, "same-origin named access works");
ok('winB' in window, "cross-origin named access works when iframe name matches");
is(winB.parent, window, "cross-origin named access works when iframe name matches");
// Setting the 'name' attribute should propagate to the docshell.
var ifrB = document.getElementById('ifrB');
await SpecialPowers.spawn(ifrB, [], () => {
Assert.equal(this.content.name, 'winB',
'initial attribute value propagates to the docshell');
});
ifrB.setAttribute('name', 'foo');
await SpecialPowers.spawn(ifrB, [], () => {
Assert.equal(this.content.name, 'foo',
'attribute sets propagate to the docshell');
});
ok('foo' in window, "names are dynamic if updated via setAttribute");
is(foo.parent, window, "names are dynamic if updated via setAttribute");
// Setting window.name on the subframe should not propagate to the attribute.
await SpecialPowers.spawn(ifrB, [], () => {
this.content.name = "bar";
});
is(ifrB.getAttribute('name'), 'foo', 'docshell updates dont propagate to the attribute');
// When the frame element attribute and docshell name don't match, nothing is returned.
ok(!('foo' in window), "frame element name not resolved if it doesn't match the docshell");
ok(!('bar' in window), "docshell name not resolved if it doesn't match the frame element");
// This shouldn't assert.
function listener() {
document.body.appendChild(ifrA);
ifrA.name = "";
}
ifrA.addEventListener("DOMNodeInserted", listener, {once: true});
document.body.appendChild(ifrA);
SimpleTest.finish();
}
</script>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=916945">Mozilla Bug 916945</a>
<p id="display"></p>
<div id="content" style="display: none">
</div>
<iframe id="ifrA" name="winA" onload="loaded();" src="file_empty.html"></iframe>
<iframe id="ifrB" name="winB" onload="loaded();" src="http://example.org/tests/js/xpconnect/tests/mochitest/file_empty.html"></iframe>
<pre id="test">
</pre>
</body>
</html>