gecko-dev/dom/html/test/test_set_input_files.html
btian 9de84f5fed Bug 1390394 - Mochitest to ensure FormData gets the new files after setting <input type=file>.files. r=smaug
--HG--
extra : rebase_source : 1987a73e03ffa7191f95f0259ba15f131ce709ee
2017-08-17 17:09:41 +08:00

56 lines
1.5 KiB
HTML

<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=1384030
-->
<head>
<title>Test for Setting &lt;input type=file&gt;.files </title>
<script type="application/javascript" 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=1384030">Mozilla Bug 1384030</a>
<pre id="test">
<script type="application/javascript">
/** Test for Setting <input type=file>.files **/
function runTest()
{
const form = document.createElement("form");
const formInput = document.createElement("input");
formInput.type = "file";
formInput.name = "inputFile";
form.appendChild(formInput);
const input = document.createElement("input");
input.type = "file";
SpecialPowers.wrap(input).mozSetFileArray([
new File(["foo"], "foo"),
new File(["bar"], "bar")
]);
formInput.files = input.files;
const inputFiles = (new FormData(form)).getAll("inputFile");
is(inputFiles.length, 2, "FormData should contain two input files");
is(inputFiles[0].name, "foo", "Input file name should be 'foo'");
is(inputFiles[1].name, "bar", "Input file name should be 'bar'");
is(inputFiles[0], input.files[0],
"Expect the same File object as input file 'foo'");
is(inputFiles[1], input.files[1],
"Expect the same File object as input file 'bar'");
SimpleTest.finish();
}
SimpleTest.waitForExplicitFinish();
window.addEventListener('load', runTest);
</script>
</pre>
</body>
</html>