<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
<head>
<script src="../../resources/testharness.js"></script>
<script src="../../resources/testharnessreport.js"></script>
</head>
<body>
<script>
function createCanvas(width, height) {
var canvas = document.createElement("canvas");
canvas.width = width;
canvas.height = height;
return canvas;
}
test(function() {
var width = 50;
var height = 50;
var canvas1 = createCanvas(width, height);
var offscreenCanvas1;
try {
offscreenCanvas1 = canvas1.transferControlToOffscreen();
assert_equals(offscreenCanvas1.width, width);
assert_equals(offscreenCanvas1.height, height);
} catch (ex) {
assert_false(ex.message);
}
}, "Tests whether transferControlToOffscreen can be run correctly.");
test(function() {
var canvas2a = createCanvas(50, 50);
var offscreenCanvas2a;
var ctx = canvas2a.getContext("2d");
assert_throws_dom("InvalidStateError", function() {
offscreenCanvas2a = canvas2a.transferControlToOffscreen();
assert_false("transferControlToOffscreen from a canvas with context didn't throw an exception.");
}, "transferControlToOffscreen from a canvas with context throws an exception");
var canvas2b = createCanvas(10, 10);
var offscreenCanvas2b = canvas2b.transferControlToOffscreen();
assert_throws_dom("InvalidStateError", function() {
var anotherOffscreenCanvas = canvas2b.transferControlToOffscreen();
}, "canvas.transferControlToOffscreen() is not allowed to called more than once for the same canvas.");
}, "Tests whether transferControlToOffscreen throws exception correctly.");
test(function() {
var canvas4 = createCanvas(10, 10);
var offscreenCanvas4 = canvas4.transferControlToOffscreen();
assert_throws_dom("InvalidStateError", function() {
canvas4.getContext("2d");
}, "canvas.getContext() is not allowed after transferring control to offscreen.");
}, "Test that getContext throw an exception if called after transferControlToOffscreen.");
</script>
</body>
</html>