mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
401 lines
14 KiB
HTML
401 lines
14 KiB
HTML
<!DOCTYPE HTML>
|
|
<html>
|
|
<head>
|
|
<!--
|
|
https://bugzilla.mozilla.org/show_bug.cgi?id=575946
|
|
-->
|
|
<title>Test for Bug 575946</title>
|
|
<script type="text/javascript" src="/MochiKit/packed.js"></script>
|
|
<script type="text/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=575946">Mozilla Bug 575946</a>
|
|
<p id="display">
|
|
<canvas id=canvas width=1000 height=1000 hidden></canvas>
|
|
<canvas id=testcanvas hidden></canvas>
|
|
<input id="fileList" type="file"></input>
|
|
</p>
|
|
<div id="content" style="display: none">
|
|
</div>
|
|
|
|
<pre id="test">
|
|
<script class="testbody" type="text/javascript">
|
|
var fileNum = 1;
|
|
var testRanCounter = 0;
|
|
var expectedTestCount = 0;
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
// Create files containing data we'll test with. We'll want long
|
|
// strings to ensure they span multiple buffers while loading
|
|
|
|
// Create a decent-sized image
|
|
cx = $("canvas").getContext('2d');
|
|
var s = cx.canvas.width;
|
|
var grad = cx.createLinearGradient(0, 0, s-1, s-1);
|
|
for (i = 0; i < 0.95; i += .1) {
|
|
grad.addColorStop(i, "white");
|
|
grad.addColorStop(i + .05, "black");
|
|
}
|
|
grad.addColorStop(1, "white");
|
|
cx.fillStyle = grad;
|
|
cx.fillRect(0, 0, s-1, s-1);
|
|
cx.fillStyle = "rgba(200, 0, 0, 0.9)";
|
|
cx.fillRect(.1 * s, .1 * s, .7 * s, .7 * s);
|
|
cx.strokeStyle = "rgba(0, 0, 130, 0.5)";
|
|
cx.lineWidth = .14 * s;
|
|
cx.beginPath();
|
|
cx.arc(.6 * s, .6 * s, .3 * s, 0, Math.PI*2, true);
|
|
cx.stroke();
|
|
cx.closePath();
|
|
cx.fillStyle = "rgb(0, 255, 0)";
|
|
cx.beginPath();
|
|
cx.arc(.1 * s, .8 * s, .1 * s, 0, Math.PI*2, true);
|
|
cx.fill();
|
|
cx.closePath();
|
|
|
|
|
|
var fileData =
|
|
atob(cx.canvas.toDataURL("image/png").substring("data:text/png;base64,".length + 1));
|
|
var memFile = cx.canvas.mozGetAsFile("image/png");
|
|
var fileFile = createFileWithData(fileData);
|
|
var size = fileData.length;
|
|
|
|
// This might fail if we dramatically improve the png encoder. If that happens
|
|
// please increase the complexity or size of the image generated above to ensure
|
|
// that we're testing with files that are large enough.
|
|
ok(size > 65536, "test data sufficiently large");
|
|
|
|
|
|
// Test that basic properties work
|
|
function testFile(file, size, type, contents, fileType) {
|
|
is(file.type, type, fileType + " file is correct type");
|
|
is(file.size, size, fileType + " file is correct size");
|
|
ok(file instanceof File, fileType + " file is a File");
|
|
ok(file instanceof Blob, fileType + " file is also a Blob");
|
|
|
|
var slice = file.mozSlice(0, size);
|
|
ok(slice instanceof Blob, fileType + " fullsize slice is a Blob");
|
|
ok(!(slice instanceof File), fileType + " fullsize slice is not a File");
|
|
|
|
slice = file.mozSlice(0, 1234);
|
|
ok(slice instanceof Blob, fileType + " sized slice is a Blob");
|
|
ok(!(slice instanceof File), fileType + " sized slice is not a File");
|
|
|
|
slice = file.mozSlice(0, size, "foo/bar");
|
|
is(slice.type, "foo/bar", fileType + " fullsize slice foo/bar type");
|
|
|
|
slice = file.mozSlice(0, 5432, "foo/bar");
|
|
is(slice.type, "foo/bar", fileType + " sized slice foo/bar type");
|
|
|
|
is(slice.mozSlice(0, 10).type, "", fileType + " slice-slice type");
|
|
is(slice.mozSlice(0, 10).size, 10, fileType + " slice-slice size");
|
|
is(slice.mozSlice(0, 10, "hello/world").type, "hello/world", fileType + " slice-slice hello/world type");
|
|
is(slice.mozSlice(0, 10, "hello/world").size, 10, fileType + " slice-slice hello/world size");
|
|
|
|
var indexes = [[0, size, size],
|
|
[0, 1234, 1234],
|
|
[size-500, size, 500],
|
|
[size-500, size+500, 500],
|
|
[size+500, size+1500, 0],
|
|
[0, 0, 0],
|
|
[1000, 1000, 0],
|
|
[size, size, 0],
|
|
[0, undefined, size],
|
|
[100, undefined, size-100],
|
|
[-100, undefined, 100],
|
|
[100, -100, size-200],
|
|
[-size-100, undefined, size],
|
|
[-2*size-100, 500, 500],
|
|
[0, -size-100, 0],
|
|
[100, -size-100, 0],
|
|
[50, -size+100, 50],
|
|
[0, 33000, 33000],
|
|
[1000, 34000, 33000],
|
|
];
|
|
|
|
for (var i = 0; i < indexes.length; ++i) {
|
|
var sliceContents;
|
|
var testName;
|
|
if (indexes[i][1] == undefined) {
|
|
slice = file.mozSlice(indexes[i][0]);
|
|
sliceContents = contents.slice(indexes[i][0]);
|
|
testName = fileType + " slice(" + indexes[i][0] + ")";
|
|
}
|
|
else {
|
|
slice = file.mozSlice(indexes[i][0], indexes[i][1]);
|
|
sliceContents = contents.slice(indexes[i][0], indexes[i][1]);
|
|
testName = fileType + " slice(" + indexes[i][0] + ", " + indexes[i][1] + ")";
|
|
}
|
|
is(slice.type, "", testName + " type");
|
|
is(slice.size, indexes[i][2], testName + " size");
|
|
is(sliceContents.length, indexes[i][2], testName + " data size");
|
|
checkFileContents(slice, sliceContents, testName);
|
|
}
|
|
|
|
// Slice of slice
|
|
var slice = file.mozSlice(0, 40000);
|
|
checkFileContents(slice.mozSlice(5000, 42000), contents.slice(5000, 40000), "file slice slice");
|
|
|
|
// ...of slice of slice
|
|
slice = slice.mozSlice(5000, 42000).mozSlice(400, 700);
|
|
gc();
|
|
checkFileContents(slice, contents.slice(5400, 5700), "file slice slice slice");
|
|
}
|
|
|
|
testFile(memFile, size, "image/png", fileData, "memFile");
|
|
testFile(fileFile, size, "", fileData, "fileFile");
|
|
|
|
|
|
// Try loading directly from slice into an image
|
|
var testBinaryData = "";
|
|
for (var i = 0; i < 256; i++) {
|
|
testBinaryData += String.fromCharCode(i);
|
|
}
|
|
while (testBinaryData.length < 20000) {
|
|
testBinaryData += testBinaryData;
|
|
}
|
|
function imageLoadHandler(event) {
|
|
var origcanvas = $("canvas");
|
|
var testcanvas = $("testcanvas");
|
|
var image = event.target;
|
|
is(image.naturalWidth, origcanvas.width, "width correct");
|
|
is(image.naturalHeight, origcanvas.height, "height correct");
|
|
|
|
testcanvas.width = origcanvas.width;
|
|
testcanvas.height = origcanvas.height;
|
|
testcanvas.getContext("2d").drawImage(image, 0, 0);
|
|
// Do not use |is(testcanvas.toDataURL("image/png"), origcanvas.toDataURL("image/png"), "...");| that results in a _very_ long line.
|
|
var origDataURL = origcanvas.toDataURL("image/png");
|
|
var testDataURL = testcanvas.toDataURL("image/png");
|
|
is(testDataURL.length, origDataURL.length,
|
|
"Length of correct image data");
|
|
ok(testDataURL == origDataURL,
|
|
"Content of correct image data");
|
|
|
|
testHasRun();
|
|
}
|
|
|
|
// image in the middle
|
|
var imgfile = createFileWithData(testBinaryData + fileData + testBinaryData);
|
|
is(imgfile.size, size + testBinaryData.length * 2, "correct file size (middle)");
|
|
var img = new Image;
|
|
img.src = URL.createObjectURL(imgfile.mozSlice(testBinaryData.length, testBinaryData.length + size));
|
|
img.onload = imageLoadHandler;
|
|
expectedTestCount++;
|
|
|
|
// image at start
|
|
var imgfile = createFileWithData(fileData + testBinaryData);
|
|
is(imgfile.size, size + testBinaryData.length, "correct file size (start)");
|
|
var img = new Image;
|
|
img.src = URL.createObjectURL(imgfile.mozSlice(0, size));
|
|
img.onload = imageLoadHandler;
|
|
expectedTestCount++;
|
|
|
|
// image at end
|
|
var imgfile = createFileWithData(testBinaryData + fileData);
|
|
is(imgfile.size, size + testBinaryData.length, "correct file size (end)");
|
|
var img = new Image;
|
|
img.src = URL.createObjectURL(imgfile.mozSlice(testBinaryData.length, testBinaryData.length + size));
|
|
img.onload = imageLoadHandler;
|
|
expectedTestCount++;
|
|
|
|
// image past end
|
|
var imgfile = createFileWithData(testBinaryData + fileData);
|
|
is(imgfile.size, size + testBinaryData.length, "correct file size (past end)");
|
|
var img = new Image;
|
|
img.src = URL.createObjectURL(imgfile.mozSlice(testBinaryData.length, testBinaryData.length + size + 1000));
|
|
img.onload = imageLoadHandler;
|
|
expectedTestCount++;
|
|
|
|
|
|
// Utility functions
|
|
function checkFileContents(file, contents, test) {
|
|
SimpleTest.requestLongerTimeout(2);
|
|
|
|
// Load file using FileReader
|
|
var r = new FileReader();
|
|
r.onload = getFileReaderLoadHandler(contents, contents.length, "FileReader.readAsBinaryString of " + test);
|
|
r.readAsBinaryString(file);
|
|
expectedTestCount++;
|
|
|
|
// Load file using URL.createObjectURL and XMLHttpRequest
|
|
var xhr = new XMLHttpRequest;
|
|
xhr.open("GET", URL.createObjectURL(file));
|
|
xhr.onload = getXHRLoadHandler(contents, contents.length, false,
|
|
"XMLHttpRequest load of " + test);
|
|
xhr.overrideMimeType('text/plain; charset=x-user-defined');
|
|
xhr.send();
|
|
expectedTestCount++;
|
|
|
|
// Send file to server using FormData and XMLHttpRequest
|
|
xhr = new XMLHttpRequest();
|
|
xhr.onload = function(event) {
|
|
checkMPSubmission(JSON.parse(event.target.responseText),
|
|
[{ name: "hello", value: "world"},
|
|
{ name: "myfile",
|
|
value: contents,
|
|
fileName: file.name || "",
|
|
contentType: file.type || "application/octet-stream" }]);
|
|
testHasRun();
|
|
}
|
|
xhr.open("POST", "../../html/content/test/form_submit_server.sjs");
|
|
var fd = new FormData;
|
|
fd.append("hello", "world");
|
|
fd.append("myfile", file);
|
|
xhr.send(fd);
|
|
expectedTestCount++;
|
|
|
|
// Send file to server using plain XMLHttpRequest
|
|
var xhr = new XMLHttpRequest;
|
|
xhr.open("POST", "file_XHRSendData.sjs");
|
|
xhr.onload = function (event) {
|
|
is(event.target.getResponseHeader("Result-Content-Type"),
|
|
file.type ? file.type : null,
|
|
"request content-type in XMLHttpRequest send of " + test);
|
|
is(event.target.getResponseHeader("Result-Content-Length"),
|
|
file.size,
|
|
"request content-length in XMLHttpRequest send of " + test);
|
|
};
|
|
xhr.addEventListener("load",
|
|
getXHRLoadHandler(contents, contents.length, true,
|
|
"XMLHttpRequest send of " + test),
|
|
false);
|
|
xhr.overrideMimeType('text/plain; charset=x-user-defined');
|
|
xhr.send(file);
|
|
expectedTestCount++;
|
|
}
|
|
|
|
function getFileReaderLoadHandler(expectedResult, expectedLength, testName) {
|
|
return function (event) {
|
|
is(event.target.readyState, FileReader.DONE,
|
|
"[FileReader] readyState in test " + testName);
|
|
is(event.target.error, null,
|
|
"[FileReader] no error in test " + testName);
|
|
// Do not use |is(event.target.result, expectedResult, "...");| that may output raw binary data.
|
|
is(event.target.result.length, expectedResult.length,
|
|
"[FileReader] Length of result in test " + testName);
|
|
ok(event.target.result == expectedResult,
|
|
"[FileReader] Content of result in test " + testName);
|
|
is(event.lengthComputable, true,
|
|
"[FileReader] lengthComputable in test " + testName);
|
|
is(event.loaded, expectedLength,
|
|
"[FileReader] Loaded length in test " + testName);
|
|
is(event.total, expectedLength,
|
|
"[FileReader] Total length in test " + testName);
|
|
testHasRun();
|
|
}
|
|
}
|
|
|
|
function getXHRLoadHandler(expectedResult, expectedLength, statusWorking, testName) {
|
|
return function (event) {
|
|
is(event.target.readyState, 4,
|
|
"[XHR] readyState in test " + testName);
|
|
if (statusWorking) {
|
|
is(event.target.status, 200,
|
|
"[XHR] no error in test " + testName);
|
|
}
|
|
else {
|
|
todo(event.target.status, 200,
|
|
"[XHR] no error in test " + testName);
|
|
}
|
|
// Do not use |is(convertXHRBinary(event.target.responseText), expectedResult, "...");| that may output raw binary data.
|
|
var convertedData = convertXHRBinary(event.target.responseText);
|
|
is(convertedData.length, expectedResult.length,
|
|
"[XHR] Length of result in test " + testName);
|
|
ok(convertedData == expectedResult,
|
|
"[XHR] Content of result in test " + testName);
|
|
is(event.lengthComputable, true,
|
|
"[XHR] lengthComputable in test " + testName);
|
|
is(event.loaded, expectedLength,
|
|
"[XHR] Loaded length in test " + testName);
|
|
is(event.total, expectedLength,
|
|
"[XHR] Total length in test " + testName);
|
|
|
|
testHasRun();
|
|
}
|
|
}
|
|
|
|
function convertXHRBinary(s) {
|
|
var res = "";
|
|
for (var i = 0; i < s.length; ++i) {
|
|
res += String.fromCharCode(s.charCodeAt(i) & 255);
|
|
}
|
|
return res;
|
|
}
|
|
|
|
function testHasRun() {
|
|
//alert(testRanCounter);
|
|
++testRanCounter;
|
|
if (testRanCounter == expectedTestCount) {
|
|
SimpleTest.finish();
|
|
}
|
|
}
|
|
|
|
function createFileWithData(fileData) {
|
|
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
|
|
var dirSvc = Components.classes["@mozilla.org/file/directory_service;1"].getService(Components.interfaces.nsIProperties);
|
|
var testFile = dirSvc.get("ProfD", Components.interfaces.nsIFile);
|
|
testFile.append("fileAPItestfile2-" + fileNum);
|
|
fileNum++;
|
|
var outStream = Components.classes["@mozilla.org/network/file-output-stream;1"].createInstance(Components.interfaces.nsIFileOutputStream);
|
|
outStream.init(testFile, 0x02 | 0x08 | 0x20, // write, create, truncate
|
|
0666, 0);
|
|
outStream.write(fileData, fileData.length);
|
|
outStream.close();
|
|
|
|
var fileList = document.getElementById('fileList');
|
|
fileList.value = testFile.path;
|
|
|
|
return fileList.files[0];
|
|
}
|
|
|
|
function gc() {
|
|
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
|
|
window.QueryInterface(Components.interfaces.nsIInterfaceRequestor)
|
|
.getInterface(Components.interfaces.nsIDOMWindowUtils)
|
|
.garbageCollect();
|
|
}
|
|
|
|
function checkMPSubmission(sub, expected) {
|
|
function getPropCount(o) {
|
|
var x, l = 0;
|
|
for (x in o) ++l;
|
|
return l;
|
|
}
|
|
|
|
is(sub.length, expected.length,
|
|
"Correct number of items");
|
|
var i;
|
|
for (i = 0; i < expected.length; ++i) {
|
|
if (!("fileName" in expected[i])) {
|
|
is(sub[i].headers["Content-Disposition"],
|
|
"form-data; name=\"" + expected[i].name + "\"",
|
|
"Correct name (A)");
|
|
is (getPropCount(sub[i].headers), 1,
|
|
"Wrong number of headers (A)");
|
|
}
|
|
else {
|
|
is(sub[i].headers["Content-Disposition"],
|
|
"form-data; name=\"" + expected[i].name + "\"; filename=\"" +
|
|
expected[i].fileName + "\"",
|
|
"Correct name (B)");
|
|
is(sub[i].headers["Content-Type"],
|
|
expected[i].contentType,
|
|
"Correct content type (B)");
|
|
is (getPropCount(sub[i].headers), 2,
|
|
"Wrong number of headers (B)");
|
|
}
|
|
// Do not use |is(sub[i].body, expected[i].value, "...");| that may output raw binary data.
|
|
is(sub[i].body.length, expected[i].value.length,
|
|
"Length of correct value");
|
|
ok(sub[i].body == expected[i].value,
|
|
"Content of correct value");
|
|
}
|
|
}
|
|
|
|
</script>
|
|
</pre>
|
|
</body> </html>
|