4 <script src="../../js/resources/js-test-pre.js"></script>
5 <div id="touchtarget" style="width: 100px; height: 100px; background-color: blue"></div>
6 <p id="description"></p>
7 <div id="console"></div>
9 var div = document.getElementById("touchtarget");
11 var touchEventsReceived = 0;
12 var EXPECTED_TOUCH_EVENTS_TOTAL = 3;
14 function touchEventCallback() {
15 if (window.eventSender) {
17 verifyTouch(touchEventsReceived++);
21 if (window.testRunner && touchEventsReceived == EXPECTED_TOUCH_EVENTS_TOTAL) {
22 window.internals.settings.setTouchEventEmulationEnabled(false);
27 function mouseMoveCallback(e) {
29 debug("Unexpected mousemove event received before touchstart");
32 div.addEventListener("touchstart", touchEventCallback, false);
33 div.addEventListener("touchmove", touchEventCallback, false);
34 div.addEventListener("touchend", touchEventCallback, false);
35 div.addEventListener("mousemove", mouseMoveCallback, false);
37 function verifyTouchEvent(type, totalTouchCount, changedTouchCount, targetTouchCount)
39 shouldBeEqualToString("lastEvent.type", type);
40 shouldBe("lastEvent.touches.length", totalTouchCount.toString());
41 shouldBe("lastEvent.changedTouches.length", changedTouchCount.toString());
42 shouldBe("lastEvent.targetTouches.length", targetTouchCount.toString());
43 shouldBe("lastEvent.pageX", "0");
44 shouldBe("lastEvent.pageY", "0");
47 function verifyTouchPoint(list, point, x, y, id)
49 shouldBe("lastEvent." + list + "[" + point + "].pageX", x.toString());
50 shouldBe("lastEvent." + list + "[" + point + "].pageY", y.toString());
51 shouldBe("lastEvent." + list + "[" + point + "].clientX", x.toString());
52 shouldBe("lastEvent." + list + "[" + point + "].clientY", y.toString());
53 shouldBe("lastEvent." + list + "[" + point + "].identifier", id.toString());
56 function verifyTouch(which) {
59 verifyTouchEvent("touchstart", 1, 1, 1);
60 shouldBe("lastEvent.shiftKey", "true");
61 shouldBe("lastEvent.altKey", "true");
62 shouldBe("lastEvent.ctrlKey", "false");
63 shouldBe("lastEvent.metaKey", "false");
64 shouldBeEqualToString("lastEvent.touches[0].target.id", "touchtarget");
65 verifyTouchPoint("touches", 0, 10, 10, 0);
66 verifyTouchPoint("changedTouches", 0, 10, 10, 0);
67 verifyTouchPoint("targetTouches", 0, 10, 10, 0);
70 verifyTouchEvent("touchmove", 1, 1, 1);
71 verifyTouchPoint("touches", 0, 20, 30, 0);
74 verifyTouchEvent("touchend", 0, 1, 0);
75 verifyTouchPoint("changedTouches", 0, 20, 30, 0);
76 shouldBe("lastEvent.shiftKey", "false");
77 shouldBe("lastEvent.altKey", "true");
78 shouldBe("lastEvent.ctrlKey", "true");
79 shouldBe("lastEvent.metaKey", "false");
82 testFailed("Wrong number of touch events! (" + which + ")");
86 function mouseEventSequence()
88 eventSender.mouseMoveTo(10, 10);
89 eventSender.mouseDown(0, ["shiftKey", "altKey"]);
90 eventSender.mouseMoveTo(20, 30);
91 eventSender.mouseUp(0, ["altKey", "ctrlKey"]);
94 if (window.eventSender && window.internals && window.internals.settings) {
95 description("This tests single touch event emulation using mouse events.");
97 window.eventSender.dragMode = false;
98 window.jsTestIsAsync = true;
99 window.internals.settings.setTouchEventEmulationEnabled(true);
101 shouldBe("'ontouchstart' in window", "true");
102 shouldBe("'ontouchend' in document", "true");
104 mouseEventSequence();
106 debug("This test requires DumpRenderTree. Tap on the blue rect to log.");
108 <script src="../../js/resources/js-test-post.js"></script>