Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / third_party / WebKit / LayoutTests / fast / events / touch / gesture / gesture-tap-div-removed.html
blob576072fe604ad60bc51bfb11f35d663d5ea04302
1 <!DOCTYPE HTML>
2 <script src="../../../../resources/js-test.js"></script>
3 <style>
4 #target {
5 position: absolute;
6 right: 10px;
7 top: 10px;
8 border: 1px solid blue;
10 </style>
11 <div id=target>
12 Tap me
13 </div>
14 <script>
15 function eventLogger(e) {
16 debug("Received " + e.type + " on " + (e.currentTarget.id || e.currentTarget.nodeName));
19 function logAndRemove(e) {
20 eventLogger(e);
21 e.currentTarget.parentNode.removeChild(e.currentTarget);
22 debug("Removed element");
23 e = null;
24 gc();
27 function logAndFail(e) {
28 eventLogger(e);
29 testFailed("Received unexpected event.");
32 function getTargetPoint() {
33 // Note that we don't want any reference to the node to escape this function
34 // so that it's elligble for garbage collection.
35 var target = document.getElementById('target');
36 target.addEventListener('mousemove', logAndRemove);
37 target.addEventListener('mousedown', logAndFail);
38 target.addEventListener('mouseup', logAndFail);
39 target.addEventListener('click', logAndFail);
40 document.addEventListener('mousemove', eventLogger);
41 document.addEventListener('mousedown', eventLogger);
42 document.addEventListener('mouseup', eventLogger);
43 document.addEventListener('click', eventLogger);
45 var rect = target.getBoundingClientRect();
46 return {
47 x: rect.left + rect.width / 2,
48 y: rect.top + rect.height / 2
52 onload = function() {
53 description("Verifies that deleting the element being tapped during the event sequence doesn't cause any problems. Succeeds if the expected events are delivered, events after removal go to the new node at the point of tap, and we don't crash.");
55 var point = getTargetPoint();
57 if (!window.eventSender) {
58 debug("This test requires eventSender");
59 return;
62 debug("Sending GestureTapDown");
63 eventSender.gestureTapDown(point.x, point.y);
65 debug("Sending GestureShowPress");
66 eventSender.gestureShowPress(point.x, point.y);
68 debug("Sending GestureTap");
69 eventSender.gestureTap(point.x, point.y);
72 </script>