Index: third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-image-triggers-drag-n-drop.html |
diff --git a/third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-image-triggers-drag-n-drop.html b/third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-image-triggers-drag-n-drop.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..edb31acb9e76a77c13bdf67173a48608ac947139 |
--- /dev/null |
+++ b/third_party/WebKit/LayoutTests/fast/events/shift-drag-selection-on-image-triggers-drag-n-drop.html |
@@ -0,0 +1,41 @@ |
+<!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 an image.</p> |
+<span id='span' style='font-size: 30px; padding: 10px;'>Some text with an image <img id='img' src='resources/abe.png' width='50' height='50'> at end.</span> |
+<div id='log'></div> |
+ |
+<script> |
+test(function() { |
+ assert_not_equals(window.testRunner, undefined, 'Requires testRunner.'); |
+ assert_not_equals(window.eventSender, undefined, 'Requires eventSender.'); |
+ |
+ var span = document.getElementById('span'); |
+ span.focus(); |
+ |
+ var img = document.getElementById('img'); |
+ |
+ var dragStartCount = 0; |
+ document.addEventListener('dragstart', function (event) { dragStartCount++; }); |
+ |
+ 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(img.offsetLeft + img.offsetWidth / 2 , y); |
+ eventSender.mouseDown(0, ['shiftKey']); |
+ eventSender.leapForward(200); |
+ eventSender.mouseMoveTo(img.offsetLeft + img.offsetWidth / 2 , y + 120); |
+ eventSender.leapForward(200); |
+ eventSender.mouseUp(); |
+ |
+ assert_equals(dragStartCount, 1); |
+}); |
+</script> |