blob: cdfdff55f33ba591d5068ed0aea644527b12bc4e [file] [log] [blame]
<!DOCTYPE html>
<meta charset="utf-8">
<title>TestDriver actions: element timing</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-actions.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<style>
div#test1, div#test2 {
position: fixed;
top: 0;
left: 0;
width: 100px;
height: 100px;
background-color: blue;
}
div#test2 {
display: none;
left: -100px;
background-color: green;
}
</style>
<div id="test1">
</div>
<div id="test2">
</div>
<script>
let events = [];
async_test(t => {
let test1 = document.getElementById("test1");
let test2 = document.getElementById("test2");
document.getElementById("test1").addEventListener("click",
() => {test2.style.display = "block"; test2.style.top = "100px"; test2.style.left = "0"});
document.getElementById("test2").addEventListener("click",
e => {events.push(e.clientX); events.push(e.clientY)});
let div = document.getElementById("backing");
let actions = new test_driver.Actions()
.pointerMove(0, 0, {origin: test1})
.pointerDown()
.pointerUp()
.pointerMove(0, 0, {origin: test2})
.pointerDown()
.pointerUp()
.send()
.then(t.step_func_done(() => assert_array_equals(events, [50, 150])))
.catch(e => t.step_func(() => assert_unreached("Actions sequence failed " + e)));
});
</script>