Source code
Revision control
Copy as Markdown
Other Tools
Test Info: Warnings
- This test gets skipped with pattern: (verify && !debug && (os == 'win'))
- Manifest: docshell/test/mochitest/mochitest.toml
<!DOCTYPE HTML>
<html>
<!--
-->
<head>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="/tests/SimpleTest/EventUtils.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=580069">Mozilla Bug 580069</a>
<script type="application/javascript">
add_task(async function() {
let iframe = document.createElement("iframe");
iframe.setAttribute("src", "file_bug580069_1.html");
// Insert the initial <iframe> document, and wait for page1Load to be called
// after it loads.
document.body.appendChild(iframe);
await new Promise(resolve => {
window.page1Load = resolve;
});
let iframeCw = iframe.contentWindow;
info("iframe's location is: " + iframeCw.location + "\n");
// Submit the forum and wait for the initial page load using a POST load.
iframeCw.document.getElementById("form").submit();
let method1 = await new Promise(resolve => {
window.page2Load = resolve;
});
info("iframe's location is: " + iframeCw.location + ", method is " + method1 + "\n");
is(method1, "POST", "Method for first load should be POST.");
// Push a new state, and refresh the page. This refresh shouldn't pop up the
// "are you sure you want to refresh a page with POST data?" dialog. If it
// does, this test will hang and fail, and we'll see 'Refreshing iframe...' at
// the end of the test log.
iframeCw.history.replaceState("", "", "?replaced");
info("Refreshing iframe...\n");
iframeCw.location.reload();
let method2 = await new Promise(resolve => {
window.page2Load = resolve;
});
info("iframe's location is: " + iframeCw.location + ", method is " + method2 + "\n");
is(method2, "GET", "Method for second load should be GET.");
is(iframeCw.location.search, "?replaced", "Wrong search on iframe after refresh.");
});
</script>
</body>
</html>