diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/canvas/test/test_imagebitmap_on_worker.html | |
parent | Initial commit. (diff) | |
download | firefox-esr-upstream.tar.xz firefox-esr-upstream.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/canvas/test/test_imagebitmap_on_worker.html')
-rw-r--r-- | dom/canvas/test/test_imagebitmap_on_worker.html | 142 |
1 files changed, 142 insertions, 0 deletions
diff --git a/dom/canvas/test/test_imagebitmap_on_worker.html b/dom/canvas/test/test_imagebitmap_on_worker.html new file mode 100644 index 0000000000..bc7ebe11e8 --- /dev/null +++ b/dom/canvas/test/test_imagebitmap_on_worker.html @@ -0,0 +1,142 @@ +<!DOCTYPE HTML> +<title>Test ImageBitmap on Worker</title> +<meta charset="utf-8"> +<script src="/tests/SimpleTest/SimpleTest.js"></script> +<link rel="stylesheet" href="/tests/SimpleTest/test.css"> +<body> +<script type="text/javascript"> + +// The following tests is not enabled in Worker now: +// create from a HTMLImageElement +// create from a HTMLVideoElement +// create from a HTMLCanvasElement +// create from a CanvasRenderingContext2D +// call CanvasRenderingContext2D.drawImage() +// call CanvasRenderingContext2D.createPaattern() +// test security error from an unclean HTHMLImageElemnt +// test security error from an unclean HTHMLVideoElemnt +// test security error from an tainted HTHMLCanvasElemnt +// test security error from an tainted CanvasRenderingContext2D + +// Task constructor function +function Task(aType, aWidth, aHeight, aMsg, aSource) { + this.type = aType; + this.width = aWidth; + this.height = aHeight; + this.msg = aMsg; + this.source = aSource; +} + +function TaskWithCrop(aType, aWidth, aHeight, aMsg, aSource, aSx, aSy, aSw, aSh) { + Task.call(this, aType, aWidth, aHeight, aMsg, aSource); + this.sx = aSx; + this.sy = aSy; + this.sw = aSw; + this.sh = aSh; +} +TaskWithCrop.prototype = Object.create(Task.prototype); +TaskWithCrop.prototype.constructor = TaskWithCrop; + +var WORKER_TASKS = { + tasks: [], // an arrayf of Task objects + dispatch() { + if (this.tasks.length) { + worker.postMessage(this.tasks.pop()); + } else { + worker.terminate(); + SimpleTest.finish(); + } + }, +}; + +var worker = new Worker("imagebitmap_on_worker.js"); +worker.onmessage = function(event) { + if (event.data.type == "status") { + ok(event.data.status, event.data.msg); + } else if (event.data.type == "doneTask") { + WORKER_TASKS.dispatch(); + } +} + +function runTests() { + ok(worker, "Worker created successfully."); + + // prepare an ImageData object + var image = document.createElement('img'); + var canvas = document.createElement('canvas'); + var ctx = canvas.getContext('2d'); + var imageData; + image.src = "image_rgrg-256x256.png"; + image.onload = function() { + var width = image.naturalWidth; + var height = image.naturalHeight; + + canvas.width = image.naturalWidth; + canvas.height = image.naturalHeight; + ctx.drawImage(image, 0, 0, image.naturalWidth, image.naturalHeight); + + imageData = ctx.getImageData(0, 0, image.naturalWidth, image.naturalHeight); + + // task: test soruce: an ImageData + WORKER_TASKS.tasks.push(new Task("testImageData", width, height, "", imageData)); + + // task: test soruce: an ImageBitmap + WORKER_TASKS.tasks.push(new Task("testImageBitmap", width, height, "", imageData)); + + // task: test soruce: a Blob + canvas.toBlob(function(aBlob) { + WORKER_TASKS.tasks.push(new Task("testBlob", width, height, "", aBlob)); + }); + }; + + // task: throw exception: general: sw == 0 || sh == 0 + WORKER_TASKS.tasks.push(new TaskWithCrop("testException", 0, 0, "createImageBitmap should throw with 0 width/height", imageData, 0, 0, 0, 0)); + + // task: throw exception: general: source is a null + WORKER_TASKS.tasks.push(new TaskWithCrop("testException", 0, 0, "createImageBitmap should throw with null source", null, 0, 0, 0, 0)); + + // task: throw exception: ImageData: an ImageData object whose data attribute is backed by a detached buffer + var neuturedImageData = function getNeuturedImageData(iData) { + worker.postMessage(iData.data.buffer, [iData.data.buffer]); + return iData; + }(ctx.getImageData(0, 0, 50, 50)); + WORKER_TASKS.tasks.push(new TaskWithCrop("testException", neuturedImageData.width, neuturedImageData.height, + "createImageBitmap should throw with neutured ImageData", + neuturedImageData, 0, 0, neuturedImageData.width, neuturedImageData.height)); + + // task: throw exception: Blob: a corrupted blob + function getCorruptedBlob(fileName) { + var xhr = new XMLHttpRequest(); + xhr.open("GET", fileName); + xhr.responseType = "blob";//force the HTTP response, response-type header to be blob + xhr.onload = function() { + WORKER_TASKS.tasks.push(new Task("testException", 0, 0, "createImageBitmap should reject promise with corrupted blob", xhr.response)); + } + xhr.send(); + } + getCorruptedBlob("image_error-early.png"); + + // task: throw exception: Blob: non-image file + function getNonImageFile(fileName) { + var xhr = new XMLHttpRequest(); + xhr.open("GET", fileName); + xhr.responseType = "blob";//force the HTTP response, response-type header to be blob + xhr.onload = function() { + WORKER_TASKS.tasks.push(new Task("testException", 0, 0, "createImageBitmap should reject promise with non-image blob", xhr.response)); + + // start to dispatch tasks to worker + WORKER_TASKS.dispatch(); + } + xhr.send(); + } + getNonImageFile("imagebitmap_on_worker.js"); + + // task: test bug : bug 1239300 + WORKER_TASKS.tasks.push(new Task("testBug1239300")); +} + +SimpleTest.waitForExplicitFinish(); +addLoadEvent(runTests); + +</script> +</body> |