| <!DOCTYPE HTML> |
| <script src="../../../resources/js-test.js"></script> |
| <style> |
| div.box { |
| height: 100px; |
| width: 100px; |
| background-color: red; |
| } |
| </style> |
| |
| <div class="box" id="target"></div> |
| |
| <div id="console"></div> |
| |
| <script> |
| description("Verifies that canceling pointerdowns for touches correctly suppresses mouseevents."); |
| |
| var preventDefaultPrimary = false; |
| |
| function init() { |
| var events = [ |
| "mouseup", |
| "mousedown", |
| "mousemove", |
| "pointerup", |
| "pointerdown", |
| "pointermove", |
| "pointercancel", |
| "click", |
| "touchstart", |
| "touchend", |
| "touchmove", |
| "touchcancel", |
| ]; |
| |
| events.forEach(function(event) { |
| document.getElementById("target").addEventListener(event, function(e) { |
| var isPrimary = e.isPrimary; |
| var desc = []; |
| if (e.type.startsWith("pointer") && isPrimary) |
| desc.push("primary"); |
| if (e.type == "pointerdown" && preventDefaultPrimary == isPrimary) { |
| e.preventDefault(); |
| desc.push("canceled"); |
| } |
| debug("Received " + e.type + " " + desc); |
| }); |
| }); |
| } |
| |
| function testTapWithPairedGE() { |
| var rect = document.getElementById("target").getBoundingClientRect(); |
| var x = rect.left + 50; |
| var y = rect.top + 50; |
| |
| var uniqueId = 1234; |
| var tapWidth = 30; |
| var tapHeight = 30; |
| |
| eventSender.addTouchPoint(x, y); |
| eventSender.touchStart(uniqueId); |
| eventSender.gestureTapDown(x, y, tapWidth, tapHeight, uniqueId); |
| |
| eventSender.releaseTouchPoint(0); |
| eventSender.touchEnd(); |
| eventSender.gestureTap(x, y); |
| } |
| |
| function testTapWithoutPairedGE() { |
| var rect = document.getElementById("target").getBoundingClientRect(); |
| var x = rect.left + 50; |
| var y = rect.top + 50; |
| |
| var uniqueId = 1234; |
| var tapWidth = 30; |
| var tapHeight = 30; |
| |
| eventSender.addTouchPoint(x, y); |
| eventSender.touchStart(uniqueId); |
| eventSender.releaseTouchPoint(0); |
| eventSender.touchEnd(); |
| |
| eventSender.addTouchPoint(x, y); |
| eventSender.touchStart(uniqueId+1); |
| eventSender.releaseTouchPoint(0); |
| eventSender.touchEnd(); |
| |
| eventSender.gestureTapDown(x, y, tapWidth, tapHeight, uniqueId+1); |
| eventSender.gestureTap(x, y); |
| |
| eventSender.gestureTapDown(x, y, tapWidth, tapHeight, uniqueId+2); |
| eventSender.gestureTap(x, y); |
| } |
| |
| function testLongPressWithPairedGE() { |
| var rect = document.getElementById("target").getBoundingClientRect(); |
| var x = rect.left + 50; |
| var y = rect.top + 50; |
| |
| var uniqueId = 1234; |
| var tapWidth = 30; |
| var tapHeight = 30; |
| |
| eventSender.addTouchPoint(x, y); |
| eventSender.touchStart(uniqueId); |
| eventSender.gestureTapDown(x, y, tapWidth, tapHeight, uniqueId); |
| |
| eventSender.cancelTouchPoint(0); |
| eventSender.touchCancel(); |
| |
| eventSender.gestureLongPress(x, y, tapWidth, tapHeight, uniqueId); |
| eventSender.gestureLongTap(x, y, tapWidth, tapHeight, uniqueId + 1); |
| } |
| |
| function testLongPressWithoutPairedGE() { |
| var rect = document.getElementById("target").getBoundingClientRect(); |
| var x = rect.left + 50; |
| var y = rect.top + 50; |
| |
| var uniqueId = 1234; |
| var tapWidth = 30; |
| var tapHeight = 30; |
| |
| eventSender.addTouchPoint(x, y); |
| eventSender.touchStart(uniqueId); |
| eventSender.cancelTouchPoint(0); |
| eventSender.touchCancel(); |
| |
| eventSender.gestureTapDown(x, y, tapWidth, tapHeight, uniqueId+1); |
| eventSender.gestureLongPress(x, y); |
| eventSender.gestureLongTap(x, y); |
| |
| eventSender.gestureTapDown(x, y, tapWidth, tapHeight, uniqueId+2); |
| eventSender.gestureLongPress(x, y); |
| eventSender.gestureLongTap(x, y); |
| } |
| |
| function runTests() { |
| [false, true, false].forEach(function(boolVal) { |
| debug("=== With primary pointerdown " + (boolVal ? "canceled" : "uncanceled") +" ==="); |
| preventDefaultPrimary = boolVal; |
| |
| debug("-- Tap with paired GEs --"); |
| testTapWithPairedGE(); |
| |
| debug("-- Tap without paired GEs --"); |
| testTapWithoutPairedGE(); |
| |
| debug("-- Long-press with paired GEs --"); |
| testLongPressWithPairedGE(); |
| |
| debug("-- Long-press without paired GEs --"); |
| testLongPressWithoutPairedGE(); |
| |
| debug(""); |
| }); |
| } |
| |
| init(); |
| if (window.eventSender) |
| runTests(); |
| else |
| debug("This test requires eventSender"); |
| |
| </script> |