1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
<!DOCTYPE html>
<html>
<meta charset=utf-8 />
<title></title>
<style>
#targetDiv {
width: 200px;
height: 200px;
overflow: scroll;
}
#innerDiv {
width: 4000px;
height: 4000px;
}
</style>
<body style="margin:0">
<div id="targetDiv">
<div id="innerDiv">
</div>
</div>
<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>
<script src=resources/event-timing-test-utils.js></script>
<script>
let event_count = 0;
function validateEntries(entries) {
assert_equals(entries.length, 2, "two pointerdown entries should be received");
let entry = entries[0];
assert_equals(entry.name, 'pointerdown');
assert_equals(entry.interactionId, 0);
entry = entries[1];
assert_equals(entry.name, 'pointerdown');
assert_equals(entry.interactionId, 0);
}
promise_test(async t => {
assert_implements(window.PerformanceEventTiming, 'Event Timing is not supported.');
// Skip the test on a Mac as they do not support touch screens.
const isMac = navigator.platform.toUpperCase().indexOf('MAC')>=0;
if (isMac)
return;
// Wait for load event so we can interact on the page.
await new Promise(resolve => {
window.addEventListener('load', resolve);
});
let observedEntries = [];
const observerPromise = new Promise(resolve => {
let pointerdown_count = 0;
new PerformanceObserver(entryList => {
entryList.getEntries().forEach(e => {
if(e.name.includes('pointerdown')) {
pointerdown_count += 1;
observedEntries.push(e);
}
if(pointerdown_count == 2){
resolve(observedEntries);
}
});
}).observe({type: 'event',
durationThreshold: 0,
buffered: true});
})
const target = document.getElementById('targetDiv');
await interactAndObserve('fling-tap', target, observerPromise);
validateEntries(observedEntries);
}, "Event Timing: test that the second pointerdown event that happens during fling does not have interaction id.");
</script>
</body>
</html>
|