blob: 5c1055f96099be78c68125f4da9678b9a14d6723 [file] [log] [blame]
<!DOCTYPE html>
<html>
<head>
<script src="../../http/tests/inspector/resources/inspector-test.js"></script>
<script src="resources/recording-utilities.js"></script>
<script>
let ctx = null;
let redImage = new Image;
redImage.src = "";
let blueImage = new Image;
blueImage.src = "";
let transparentImage = new Image;
transparentImage.src = "";
// Blank canvas
let canvas = document.createElement("canvas");
canvas.width = 2;
canvas.height = 2;
function load() {
ctx = canvas.getContext("bitmaprenderer");
cancelActions();
runTest();
}
function ignoreException(func){
try {
func();
} catch (e) { }
}
let requestAnimationFrameId = NaN;
function cancelActions() {
cancelAnimationFrame(requestAnimationFrameId);
requestAnimationFrameId = NaN;
createImageBitmap(transparentImage).then((transparentBitmap) => {
ctx.transferFromImageBitmap(transparentBitmap);
});
}
async function performActions() {
let redBitmap = await createImageBitmap(redImage);
let frames = [
() => {
ctx.transferFromImageBitmap(redBitmap);
},
() => {
ctx.canvas.width;
ctx.canvas.width = 2;
},
() => {
ctx.canvas.height;
ctx.canvas.height = 2;
},
() => {
TestPage.dispatchEventToFrontend("LastFrame");
},
];
let index = 0;
function executeFrameFunction() {
frames[index++]();
if (index < frames.length)
requestAnimationFrameId = requestAnimationFrame(executeFrameFunction);
};
executeFrameFunction();
}
async function performConsoleActions() {
let [redBitmap, blueBitmap] = await Promise.all([
createImageBitmap(redImage),
createImageBitmap(blueImage),
]);
console.record(ctx, {name: "TEST"});
ctx.transferFromImageBitmap(redBitmap);
console.recordEnd(ctx);
ctx.transferFromImageBitmap(blueBitmap);
}
function test() {
let suite = InspectorTest.createAsyncSuite("Canvas.recordingBitmapRenderer");
suite.addTestCase({
name: "Canvas.recordingBitmapRenderer.singleFrame",
description: "Check that the recording is stopped after a single frame.",
test(resolve, reject) {
startRecording(WI.Canvas.ContextType.BitmapRenderer, resolve, reject, {frameCount: 1});
},
});
suite.addTestCase({
name: "Canvas.recordingBitmapRenderer.multipleFrames",
description: "Check that recording data is serialized correctly for multiple frames.",
test(resolve, reject) {
startRecording(WI.Canvas.ContextType.BitmapRenderer, resolve, reject);
},
});
suite.addTestCase({
name: "Canvas.recordingBitmapRenderer.memoryLimit",
description: "Check that the recording is stopped when it reaches the memory limit.",
test(resolve, reject) {
startRecording(WI.Canvas.ContextType.BitmapRenderer, resolve, reject, {memoryLimit: 10});
},
});
suite.addTestCase({
name: "Canvas.recordingBitmapRenderer.Console",
description: "Check that a recording can be triggered by console.record().",
test(resolve, reject) {
consoleRecord(WI.Canvas.ContextType.BitmapRenderer, resolve, reject);
},
});
suite.runTestCasesAndFinish();
}
</script>
</head>
<body onload="load()">
<p>Test that CanvasManager is able to record actions made to BitmapRenderer canvas contexts.</p>
</body>
</html>