summaryrefslogtreecommitdiffstats
path: root/dom/canvas/test/test_canvas_focusring.html
diff options
context:
space:
mode:
Diffstat (limited to 'dom/canvas/test/test_canvas_focusring.html')
-rw-r--r--dom/canvas/test/test_canvas_focusring.html100
1 files changed, 100 insertions, 0 deletions
diff --git a/dom/canvas/test/test_canvas_focusring.html b/dom/canvas/test/test_canvas_focusring.html
new file mode 100644
index 000000000..9e2e832b3
--- /dev/null
+++ b/dom/canvas/test/test_canvas_focusring.html
@@ -0,0 +1,100 @@
+<!DOCTYPE HTML>
+<title>Canvas Tests</title>
+<script src="/tests/SimpleTest/SimpleTest.js"></script>
+<link rel="stylesheet" href="/tests/SimpleTest/test.css">
+<body>
+<script>
+
+SimpleTest.waitForExplicitFinish();
+const Cc = SpecialPowers.Cc;
+const Cr = SpecialPowers.Cr;
+SpecialPowers.setBoolPref("canvas.focusring.enabled", true);
+SpecialPowers.setBoolPref("canvas.customfocusring.enabled", true);
+</script>
+
+<p>Canvas test: drawCustomFocusRing</p>
+<canvas id="c688" class="output" width="100" height="50">+
+ <input id="button1" type="range" min="1" max="12"></input>
+ <input id="button2" type="range" min="1" max="12"></input>
+</canvas>
+<script type="text/javascript">
+function test_drawCustomFocusRing_canvas() {
+ var c = document.getElementById("c688");
+ var ctx = c.getContext("2d");
+ ctx.beginPath();
+ var b1 = document.getElementById('button1');
+ var b2 = document.getElementById('button2');
+ ok(!ctx.drawCustomFocusRing(b1), "button 1 is focused");
+ ok(!ctx.drawCustomFocusRing(b2), "button 2 is focused");
+ b1.focus();
+ ok(ctx.drawCustomFocusRing(b1), "button 1 should not be focused");
+}
+</script>
+
+<p>Canvas test: drawFocusIfNeeded</p>
+<canvas id="c689" class="output" width="50" height="25">
+ <input id="button3" type="range" min="1" max="12"></input>
+ <input id="button4" type="range" min="1" max="12"></input>
+</canvas>
+<script type="text/javascript">
+function isEmptyCanvas(ctx, w, h) {
+ var imgdata = ctx.getImageData(0, 0, w, h);
+ for(var x = 0; x < w*h*4; x++)
+ if(imgdata.data[x] != 0)
+ return false;
+ return true;
+}
+
+function test_drawFocusIfNeeded_canvas() {
+ var c = document.getElementById("c689");
+ var ctx = c.getContext("2d");
+ var b1 = document.getElementById('button3');
+ var b2 = document.getElementById('button4');
+ ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
+ ctx.beginPath();
+ ctx.rect(10, 10, 30, 30);
+ ctx.drawFocusIfNeeded(b1);
+ ok(isEmptyCanvas(ctx, ctx.canvas.width, ctx.canvas.height), "focus of button 1 is drawn");
+
+ ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
+ ctx.beginPath();
+ ctx.rect(50, 10, 30, 30);
+ ctx.drawFocusIfNeeded(b2);
+ ctx.rect(50, 10, 30, 30);
+ ctx.drawFocusIfNeeded(b2);
+ ok(isEmptyCanvas(ctx, ctx.canvas.width, ctx.canvas.height), "focus of button 2 is drawn");
+
+ b1.focus();
+ ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
+ ctx.beginPath();
+ ctx.rect(10, 10, 30, 30);
+ ctx.drawFocusIfNeeded(b1);
+ ok(!isEmptyCanvas(ctx, ctx.canvas.width, ctx.canvas.height) , "focus of button 1 is not drawn");
+}
+</script>
+
+
+<script>
+
+function runTests() {
+ try {
+ test_drawCustomFocusRing_canvas();
+ } catch(e) {
+ throw e;
+ ok(false, "unexpected exception thrown in: test_drawCustomFocusRing_canvas");
+ }
+ try {
+ test_drawFocusIfNeeded_canvas();
+ } catch(e) {
+ throw e;
+ ok(false, "unexpected exception thrown in: test_drawFocusIfNeeded_canvas");
+ }
+
+ SpecialPowers.setBoolPref("canvas.focusring.enabled", false);
+ SpecialPowers.setBoolPref("canvas.customfocusring.enabled", false);
+ SimpleTest.finish();
+}
+
+addLoadEvent(runTests);
+
+</script>