Index: third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-link-triggers-drag-n-drop.html |
diff --git a/third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-link-triggers-drag-n-drop.html b/third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-link-triggers-drag-n-drop.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..44e91b02fea3f2e5e51b95b4259a6ec533beb92e |
--- /dev/null |
+++ b/third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-link-triggers-drag-n-drop.html |
@@ -0,0 +1,42 @@ |
+<!DOCTYPE html> |
+<script src="../../resources/testharness.js"></script> |
+<script src="../../resources/testharnessreport.js"></script> |
+<p>This test ensures drag-n-drop does start when extending an existing selecting with shift + mouse drag, starting over a link.</p> |
+<span style='font-size: 30px; padding: 10px;'>Some text with a <a href=#>link in the end of sentence</a>.</span> |
+<script> |
+test(function() { |
+ var span = document.getElementsByTagName('span')[0]; |
+ span.focus(); |
+ |
+ var dragStartCount = 0; |
+ document.addEventListener('dragstart', function (event) { dragStartCount++; }); |
+ |
+ if (!window.testRunner || !window.eventSender) |
+ document.write('This test requires eventSender'); |
+ else { |
+ testRunner.dumpAsText(); |
+ |
+ var y = span.offsetTop + span.offsetHeight / 2; |
+ eventSender.mouseMoveTo(span.offsetLeft + 5, y); |
+ eventSender.mouseDown(); |
+ eventSender.leapForward(200); |
+ eventSender.mouseUp(); |
+ |
+ eventSender.mouseMoveTo(span.offsetLeft + span.offsetWidth / 4, y); |
+ eventSender.mouseDown(0, ['shiftKey']); |
+ eventSender.leapForward(200); |
+ eventSender.mouseUp(); |
+ |
+ eventSender.mouseMoveTo(span.offsetLeft + span.offsetWidth * .75 , y); |
+ eventSender.mouseDown(0, ['shiftKey']); |
+ eventSender.leapForward(200); |
+ eventSender.mouseMoveTo(span.offsetLeft + span.offsetWidth * .75, y + 120); |
+ eventSender.leapForward(200); |
+ eventSender.mouseUp(); |
+ |
+ assert_equals(dragStartCount, 1); |
+ |
+ span.parentNode.removeChild(span); |
+ } |
+}); |
+</script> |