-
Notifications
You must be signed in to change notification settings - Fork 3.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Make popstate always fire synchronously
Interop discussion: whatwg/html#1792 Intent to ship: https://groups.google.com/a/chromium.org/g/blink-dev/c/HXRHWirKarU Bug: 1254926 Change-Id: I7e41ab603a15a14bf9df5000edca2724766a20e9 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3580022 Reviewed-by: Domenic Denicola <domenic@chromium.org> Commit-Queue: Nate Chapin <japhet@chromium.org> Cr-Commit-Position: refs/heads/main@{#996748}
- Loading branch information
1 parent
457b923
commit 681dc9c
Showing
11 changed files
with
334 additions
and
0 deletions.
There are no files selected for viewing
38 changes: 38 additions & 0 deletions
38
html/browsers/browsing-the-web/history-traversal/event-order/after-load-hash-twice.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
// 0 timeout is necessary because if we do location.hash assignment before load is finished firing it counts as a replacement. | ||
window.addEventListener("load", () => t.step_timeout(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
|
||
window.addEventListener("hashchange", t.step_func(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "popstate", "hashchange"]); | ||
|
||
window.addEventListener("hashchange", t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "popstate", "hashchange", "hashchange"]); | ||
})); | ||
}), { once: true }); | ||
|
||
location.hash = "#1"; | ||
assert_array_equals(window.eventOrder, ["load", "popstate"]); | ||
location.hash = "#2"; | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "popstate"]); | ||
}, 0)); | ||
}, "when changing hash, after the load event"); | ||
</script> |
32 changes: 32 additions & 0 deletions
32
html/browsers/browsing-the-web/history-traversal/event-order/after-load-hash.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
// 0 timeout is necessary because if we do location.hash assignment before load is finished firing it counts as a replacement. | ||
window.addEventListener("load", () => t.step_timeout(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
|
||
window.addEventListener("hashchange", t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "hashchange"]); | ||
})); | ||
|
||
location.hash = "#1"; | ||
assert_array_equals(window.eventOrder, ["load", "popstate"]); | ||
}, 0)); | ||
}, "when changing hash, after the load event"); | ||
</script> |
31 changes: 31 additions & 0 deletions
31
html/browsers/browsing-the-web/history-traversal/event-order/after-load-pushState.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
// 0 timeout is necessary because if we do pushState before load is finished firing it counts as a replacement. | ||
window.addEventListener("load", () => t.step_timeout(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
|
||
t.step_timeout(t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
}), 100); | ||
|
||
history.pushState({ state: "new state" }, ""); | ||
}, 0)); | ||
}, "when pushing state, after the load event"); | ||
</script> |
30 changes: 30 additions & 0 deletions
30
html/browsers/browsing-the-web/history-traversal/event-order/after-load-replaceState.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
window.addEventListener("load", t.step_func(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
|
||
t.step_timeout(t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
}), 100); | ||
|
||
history.replaceState({ state: "new state" }, ""); | ||
})); | ||
}, "when replacing state, after the load event"); | ||
</script> |
29 changes: 29 additions & 0 deletions
29
html/browsers/browsing-the-web/history-traversal/event-order/before-load-hash-twice.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
window.addEventListener("load", t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["popstate", "popstate", "hashchange", "hashchange", "load"]); | ||
})); | ||
|
||
location.hash = "#1"; | ||
assert_array_equals(window.eventOrder, ["popstate"]); | ||
location.hash = "#2"; | ||
assert_array_equals(window.eventOrder, ["popstate", "popstate"]); | ||
}, "when changing hash twice, before load"); | ||
</script> |
27 changes: 27 additions & 0 deletions
27
html/browsers/browsing-the-web/history-traversal/event-order/before-load-hash.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
window.addEventListener("load", t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["popstate", "hashchange", "load"]); | ||
})); | ||
|
||
location.hash = "#1"; | ||
assert_array_equals(window.eventOrder, ["popstate"]); | ||
}, "when changing hash, before load"); | ||
</script> |
28 changes: 28 additions & 0 deletions
28
html/browsers/browsing-the-web/history-traversal/event-order/before-load-pushState.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
window.addEventListener("load", t.step_func(() => { | ||
t.step_timeout(t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
}), 100); | ||
})); | ||
|
||
history.pushState({ state: "new state" }, ""); | ||
}, "when pushing state, before load"); | ||
</script> |
26 changes: 26 additions & 0 deletions
26
html/browsers/browsing-the-web/history-traversal/event-order/before-load-replaceState.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
t.step_timeout(t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
}), 100); | ||
|
||
history.replaceState({ state: "new state" }, ""); | ||
}, "when replacing state, before load"); | ||
</script> |
16 changes: 16 additions & 0 deletions
16
html/browsers/browsing-the-web/history-traversal/event-order/pushState-inside-popstate.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
<script> | ||
test(t => { | ||
let popstate_called = false; | ||
window.onpopstate = t.step_func(e => { | ||
popstate_called = true; | ||
history.pushState(2, null, "#2"); | ||
assert_not_equals(history.state, e.state); | ||
}); | ||
location.hash = "#1"; | ||
assert_true(popstate_called); | ||
}, "pushState inside popstate") | ||
</script> |
38 changes: 38 additions & 0 deletions
38
...sers/browsing-the-web/history-traversal/event-order/same-document-traverse-immediate.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
// 0 timeout is necessary because if we do location.hash assignment before load is finished firing it counts as a replacement. | ||
window.addEventListener("load", () => t.step_timeout(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
|
||
window.addEventListener("hashchange", t.step_func(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "hashchange"]); | ||
|
||
window.addEventListener("hashchange", t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "hashchange", "popstate", "hashchange"]); | ||
})); | ||
}), { once: true }); | ||
|
||
location.hash = "#1"; | ||
assert_array_equals(window.eventOrder, ["load", "popstate"]); | ||
history.back(); | ||
assert_array_equals(window.eventOrder, ["load", "popstate"]); | ||
}, 0)); | ||
}, "when traversing back, before hashchange"); | ||
</script> |
39 changes: 39 additions & 0 deletions
39
.../browsers/browsing-the-web/history-traversal/event-order/same-document-traverse-wait.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
<!DOCTYPE html> | ||
<meta charset="utf-8"> | ||
<title>Popstate/hashchange/load event ordering</title> | ||
|
||
<script> | ||
// Set these up super-early before we hit the network for the test harness, just in case. | ||
window.eventOrder = []; | ||
window.onhashchange = () => window.eventOrder.push("hashchange"); | ||
window.onpopstate = () => window.eventOrder.push("popstate"); | ||
window.onload = () => window.eventOrder.push("load"); | ||
</script> | ||
|
||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
|
||
<script> | ||
async_test(t => { | ||
assert_array_equals(window.eventOrder, []); | ||
|
||
// 0 timeout is necessary because if we do location.hash assignment before load is finished firing it counts as a replacement. | ||
window.addEventListener("load", () => t.step_timeout(() => { | ||
assert_array_equals(window.eventOrder, ["load"]); | ||
|
||
window.addEventListener("hashchange", t.step_func(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "hashchange"]); | ||
|
||
window.addEventListener("hashchange", t.step_func_done(() => { | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "hashchange", "popstate", "hashchange"]); | ||
})); | ||
|
||
history.back(); | ||
assert_array_equals(window.eventOrder, ["load", "popstate", "hashchange"]); | ||
}), { once: true }); | ||
|
||
location.hash = "#1"; | ||
assert_array_equals(window.eventOrder, ["load", "popstate"]); | ||
}, 0)); | ||
}, "when traversing back, after hashchange"); | ||
</script> |