blob: 88ba82102a6a280beab79f72463aa039bab62850 (
plain)
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
|
<!doctype html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<body>
<div style="height: 1000px; width: 1000px;"></div>
<div id="frag"></div>
<script>
promise_test(async t => {
// Wait for after the load event so that the navigation doesn't get converted
// into a replace navigation.
await new Promise(resolve => window.onload = () => t.step_timeout(resolve, 0));
assert_equals(window.scrollY, 0);
await navigation.navigate("#frag").finished;
assert_not_equals(window.scrollY, 0);
window.onpopstate = t.step_func(() => assert_not_equals(window.scrollY, 0));
window.onhashchange = t.step_func(() => assert_not_equals(window.scrollY, 0));
// The scroll restore should take place before navigatesuccess fires.
let navigatesuccess_called = false;
navigation.onnavigatesuccess = t.step_func(() => {
navigatesuccess_called = true;
assert_equals(window.scrollY, 0);
});
let back_promises = navigation.back();
navigation.onnavigate = t.step_func(e => {
e.intercept({ scroll: "after-transition",
handler: async () => {
// The ordering here should be:
// * intercept() is called
// * back_promises.committed is resolved
// * this handler runs.
// If this handler incorrectly blocks back_promises.committed,
// this test will hang.
await back_promises.committed;
assert_not_equals(window.scrollY, 0);
}
});
assert_not_equals(window.scrollY, 0);
});
await back_promises.finished;
assert_equals(window.scrollY, 0);
assert_true(navigatesuccess_called);
}, "scroll: after-transition should scroll when back completes, just before navigatesuccess");
</script>
</body>
|