1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-14 19:37:59 -05:00
denoland-deno/cli/tests/unit/image_data_test.ts
Jamie 8c0fb9003d
feat(ext/web): add ImageData Web API (#21183)
Fixes #19288

Adds the `ImageData` Web API. 

This would be beneficial to projects using `ImageData` as a convenient
transport layer for pixel data. This is common in Web Assembly projects
that manipulate images. Having this global available in Deno would
improve compatibility of existing JS libraries.

**References**
- [MDN ImageData Web
API](https://developer.mozilla.org/en-US/docs/Web/API/ImageData)
- [whatwg HTML Standard Canvas
Spec](https://html.spec.whatwg.org/multipage/canvas.html#pixel-manipulation)
2023-12-06 14:20:28 +01:00

53 lines
1.7 KiB
TypeScript

// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
import { assertEquals } from "./test_util.ts";
Deno.test(function imageDataInitializedWithSourceWidthAndHeight() {
const imageData = new ImageData(16, 9);
assertEquals(imageData.width, 16);
assertEquals(imageData.height, 9);
assertEquals(imageData.data.length, 16 * 9 * 4); // width * height * 4 (RGBA pixels)
assertEquals(imageData.colorSpace, "srgb");
});
Deno.test(function imageDataInitializedWithImageDataAndWidth() {
const imageData = new ImageData(new Uint8ClampedArray(16 * 9 * 4), 16);
assertEquals(imageData.width, 16);
assertEquals(imageData.height, 9);
assertEquals(imageData.data.length, 16 * 9 * 4); // width * height * 4 (RGBA pixels)
assertEquals(imageData.colorSpace, "srgb");
});
Deno.test(
function imageDataInitializedWithImageDataAndWidthAndHeightAndColorSpace() {
const imageData = new ImageData(new Uint8ClampedArray(16 * 9 * 4), 16, 9, {
colorSpace: "display-p3",
});
assertEquals(imageData.width, 16);
assertEquals(imageData.height, 9);
assertEquals(imageData.data.length, 16 * 9 * 4); // width * height * 4 (RGBA pixels)
assertEquals(imageData.colorSpace, "display-p3");
},
);
Deno.test(
async function imageDataUsedInWorker() {
const { promise, resolve } = Promise.withResolvers<void>();
const url = import.meta.resolve(
"../testdata/workers/image_data_worker.ts",
);
const expectedData = 16;
const worker = new Worker(url, { type: "module" });
worker.onmessage = function (e) {
assertEquals(expectedData, e.data);
worker.terminate();
resolve();
};
await promise;
},
);