<!DOCTYPE HTML> <html> <!-- https://bugzilla.mozilla.org/show_bug.cgi?id=345339 --> <head> <title>Test for Bug 345339</title> <script src="/tests/SimpleTest/SimpleTest.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=345339">Mozilla Bug 345339</a> <p id="display"></p> <div id="content" style="display: none"> </div> <iframe id="testframe" src="http://mochi.test:8888/tests/dom/base/test/345339_iframe.html"> </iframe> <pre id="test"> <script class="testbody" type="text/javascript"> /** Test for Bug 345339 **/ SimpleTest.waitForExplicitFinish(); const testData = "Test data\n"; let file = new File([testData], "345339_test.file", { type: "text/plain" }); function afterLoad() { var iframeDoc = $("testframe").contentDocument; /* change all the form controls */ iframeDoc.getElementById("select").selectedIndex = 1; iframeDoc.getElementById("radio2").checked = true; iframeDoc.getElementById("password").value = "123456"; iframeDoc.getElementById("hidden").value = "gecko"; // Toggle the one field to a password type then text type like password // visibility toggles on the web do. iframeDoc.getElementById("passwordToggle").type = "password"; iframeDoc.getElementById("passwordToggle").value = "abcdef"; iframeDoc.getElementById("passwordToggle").type = ""; SpecialPowers.wrap(iframeDoc).getElementById("file").mozSetFileArray([file]); /* Reload the page */ $("testframe").setAttribute("onload", "afterReload()"); iframeDoc.location.reload(); } addLoadEvent(afterLoad); function afterReload() { var iframeDoc = $("testframe").contentDocument; is(iframeDoc.getElementById("select").selectedIndex, 1, "select element selected index preserved"); is(iframeDoc.getElementById("radio1").checked, false, "radio button #1 value preserved"); is(iframeDoc.getElementById("radio2").checked, true, "radio button #2 value preserved"); isnot(iframeDoc.getElementById("password").value, "123456", "password field value forgotten"); is(iframeDoc.getElementById("hidden").value, "gecko", "hidden field value preserved"); is(iframeDoc.getElementById("passwordToggle").value, "", "former password field value not saved"); // The new file object isn't ===, but it's extensionally equal: let newFile = iframeDoc.getElementById("file").files[0]; for (let prop of ["name", "lastModified", "size", "type"]) { is(newFile[prop], file[prop], "file field " + prop + " property preserved"); } let reader = new FileReader(); reader.onloadend = function() { SimpleTest.finish(); }; reader.onload = function() { is(reader.result, testData, "file field contents preserved") }; reader.onerror = function() { is(reader.error, null, "FileReader error"); }; reader.readAsText(newFile); } </script> </pre> </body> </html>