chromium/third_party/blink/web_tests/editing/selection/drag-start-event-client-x-y.html

<html>
    <head>
        <title>Test for WebKit bug 26723: clientX,Y , screenX , Y always (0, 0) in dragstart event</title>
        <style type="text/css">
            #draggable {
                background-color: #ccc;
                border: 1px solid #333;
                width: 200px;
                text-align: center;
                margin: 10px;
                -webkit-user-drag: element;
                -webkit-user-select: none;
            }

            .fail {
                color: red;
            }

            .success {
                color: green;
            }
        </style>

        <script type="text/javascript">
        
        Function.prototype.bind = function(thisObject) {
            var func = this;
            var args = Array.prototype.slice.call(arguments, 1);
            return function() { return func.apply(thisObject, args.concat(Array.prototype.slice.call(arguments, 0))) };
        }
        
        function shouldBe(resultElement, name, expected, actual) {
            var msg = document.createElement('p');
            if (Math.abs(expected - actual) < 1) {
                msg.innerHTML = "<span class='success'>SUCCESS</span> Expected " + expected + " for " + name + " and got it.";
            } else {
                msg.innerHTML = "<span class='fail'>FAIL</span> Expected " + expected + " for " + name + " but got " + actual + ".";
            }
            resultElement.appendChild(msg);
        }

        var Test = { 

            dragStartHandler: function(dragStart, dragDistance) {
                var resultElement = document.getElementById("result");
                shouldBe(resultElement, "clientX", dragStart.x, event.clientX);
                shouldBe(resultElement, "clientY", dragStart.y, event.clientY);
                shouldBe(resultElement, "pageX", dragStart.x, event.pageX);
                shouldBe(resultElement, "pageY", dragStart.y, event.pageY);
            },

            runTest: function() {
                if (!window.eventSender)
                    return;

                if (window.testRunner)
                    testRunner.dumpAsText();
                
                var element = document.getElementById("draggable");
                var dragStart = { x: element.offsetLeft + element.offsetWidth / 2, y:  element.offsetTop + 1.0 };
                var dragDistance = 10.0;
                element.ondragstart = this.dragStartHandler.bind(this, dragStart, dragDistance);
                
                eventSender.mouseMoveTo(dragStart.x, dragStart.y);
                eventSender.mouseDown();
                eventSender.mouseMoveTo(dragStart.x + dragDistance, dragStart.y + dragDistance);
                eventSender.mouseUp();
             }
             
        }
        </script>
    </head>
    <body onload="Test.runTest()">
        <h3>Test for <a href='https://bugs.webkit.org/show_bug.cgi?id=26723'>WebKit bug 26723</a>: clientX,Y , screenX , Y always (0, 0) in dragstart event</h3>
        <div id="draggable" class="test">
            DRAG ME!
        </div>
        <div id="result"></div>
    </body>
</html>