| let contexts = []; |
| |
| function createAttachedCanvas(contextType) { |
| let canvas = document.body.appendChild(document.createElement("canvas")); |
| contexts.push(canvas.getContext(contextType)); |
| } |
| |
| function createDetachedCanvas(contextType) { |
| contexts.push(document.createElement("canvas").getContext(contextType)); |
| } |
| |
| function createCSSCanvas(contextType, canvasName) { |
| contexts.push(document.getCSSCanvasContext(contextType, canvasName, 10, 10)); |
| } |
| |
| function destroyCanvases() { |
| for (let context of contexts) { |
| let canvasElement = context.canvas; |
| if (canvasElement && canvasElement.parentNode) |
| canvasElement.remove(); |
| } |
| |
| contexts = []; |
| |
| // Force GC to make sure the canvas element is destroyed, otherwise the frontend |
| // does not receive WI.CanvasManager.Event.CanvasWasRemoved events. |
| setTimeout(() => { GCController.collect(); }, 0); |
| } |
| |
| TestPage.registerInitializer(() => { |
| let suite = null; |
| |
| function awaitCanvasAdded(contextType) { |
| return WI.canvasManager.awaitEvent(WI.CanvasManager.Event.CanvasWasAdded) |
| .then((event) => { |
| let canvas = event.data.canvas; |
| let contextDisplayName = WI.Canvas.displayNameForContextType(contextType); |
| InspectorTest.expectEqual(canvas.contextType, contextType, `Canvas context should be ${contextDisplayName}.`); |
| |
| return canvas; |
| }); |
| } |
| |
| function awaitCanvasRemoved(canvasIdentifier) { |
| return WI.canvasManager.awaitEvent(WI.CanvasManager.Event.CanvasWasRemoved) |
| .then((event) => { |
| let canvas = event.data.canvas; |
| InspectorTest.expectEqual(canvas.identifier, canvasIdentifier, "Removed canvas has expected ID."); |
| }); |
| } |
| |
| window.initializeTestSuite = function(name) { |
| suite = InspectorTest.createAsyncSuite(name); |
| |
| suite.addTestCase({ |
| name: `${suite.name}.NoCanvases`, |
| description: "Check that the CanvasManager has no canvases initially.", |
| test(resolve, reject) { |
| InspectorTest.expectEqual(WI.canvasManager.canvases.length, 0, "CanvasManager should have no canvases."); |
| resolve(); |
| } |
| }); |
| |
| return suite; |
| }; |
| |
| window.addSimpleTestCase = function({name, description, expression, contextType}) { |
| suite.addTestCase({ |
| name: suite.name + "." + name, |
| description, |
| test(resolve, reject) { |
| awaitCanvasAdded(contextType) |
| .then((canvas) => { |
| if (canvas.cssCanvasName) { |
| InspectorTest.log("CSS canvas will not be destroyed"); |
| resolve(); |
| return; |
| } |
| |
| let promise = awaitCanvasRemoved(canvas.identifier); |
| InspectorTest.evaluateInPage(`destroyCanvases()`); |
| return promise; |
| }) |
| .then(resolve, reject); |
| |
| InspectorTest.evaluateInPage(expression); |
| }, |
| }); |
| }; |
| |
| let previousCSSCanvasContextType = null; |
| window.addCSSCanvasTestCase = function(contextType) { |
| InspectorTest.assert(!previousCSSCanvasContextType || previousCSSCanvasContextType === contextType, "addCSSCanvasTestCase cannot be called more than once with different context types."); |
| if (!previousCSSCanvasContextType) |
| previousCSSCanvasContextType = contextType; |
| |
| suite.addTestCase({ |
| name: `${suite.name}.CSSCanvas`, |
| description: "Check that CSS canvases have the correct name and type.", |
| test(resolve, reject) { |
| awaitCanvasAdded(contextType) |
| .then((canvas) => { |
| InspectorTest.expectEqual(canvas.cssCanvasName, "css-canvas", "Canvas name should equal the identifier passed to -webkit-canvas."); |
| }) |
| .then(resolve, reject); |
| |
| let contextId = contextType === WI.Canvas.ContextType.Canvas2D ? "2d" : contextType; |
| InspectorTest.log(`Create CSS canvas from -webkit-canvas(css-canvas).`); |
| InspectorTest.evaluateInPage(`createCSSCanvas("${contextId}", "css-canvas")`); |
| }, |
| }); |
| }; |
| }); |