зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1741132 - Correctly evict entries with session history in parent. r=smaug
Differential Revision: https://phabricator.services.mozilla.com/D131894
This commit is contained in:
Родитель
00ffaf83c0
Коммит
afd1bab71f
|
@ -2143,6 +2143,8 @@ void CanonicalBrowsingContext::HistoryCommitIndexAndLength(
|
|||
|
||||
GetChildSessionHistory()->SetIndexAndLength(index, length, aChangeID);
|
||||
|
||||
shistory->EvictOutOfRangeContentViewers(index);
|
||||
|
||||
Group()->EachParent([&](ContentParent* aParent) {
|
||||
Unused << aParent->SendHistoryCommitIndexAndLength(this, index, length,
|
||||
aChangeID);
|
||||
|
|
|
@ -0,0 +1,28 @@
|
|||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<script>
|
||||
window.addEventListener("pageshow", ({ persisted }) => {
|
||||
let bc = new BroadcastChannel("bug1741132");
|
||||
bc.addEventListener("message", ({ data: { cmd, arg } }) => {
|
||||
switch (cmd) {
|
||||
case "load":
|
||||
bc.close();
|
||||
document.location = arg;
|
||||
break;
|
||||
case "go":
|
||||
history.go(arg);
|
||||
break;
|
||||
case "close":
|
||||
window.close();
|
||||
break;
|
||||
}
|
||||
});
|
||||
bc.postMessage(persisted);
|
||||
});
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
</body>
|
||||
</html>
|
|
@ -121,6 +121,9 @@ support-files =
|
|||
support-files =
|
||||
file_bug1740517.html
|
||||
file_bug1740517.html^headers^
|
||||
[test_bug1741132.html]
|
||||
support-files =
|
||||
file_bug1741132.html
|
||||
[test_close_onpagehide_by_history_back.html]
|
||||
[test_close_onpagehide_by_window_close.html]
|
||||
[test_compressed_multipart.html]
|
||||
|
|
|
@ -0,0 +1,66 @@
|
|||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Test form restoration for no-store pages</title>
|
||||
<script src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
|
||||
<script>
|
||||
// The number of entries which we keep in the BFCache (see nsSHistory.h).
|
||||
const VIEWER_WINDOW = 3;
|
||||
|
||||
SimpleTest.waitForExplicitFinish();
|
||||
|
||||
function runTest() {
|
||||
let bc = new BroadcastChannel("bug1741132");
|
||||
|
||||
let load = new Promise(resolve => {
|
||||
bc.addEventListener("message", resolve, { once: true });
|
||||
window.open("file_bug1741132.html", "", "noopener");
|
||||
});
|
||||
// We want to try to keep one entry too many in the BFCache,
|
||||
// so we ensure that there's at least VIEWER_WINDOW + 2
|
||||
// entries in session history (with one for the displayed
|
||||
// page).
|
||||
for (let i = 0; i < VIEWER_WINDOW + 2; ++i) {
|
||||
load = load.then(() => {
|
||||
return new Promise((resolve) => {
|
||||
bc.addEventListener("message", resolve, { once: true });
|
||||
bc.postMessage({ cmd: "load", arg: `file_bug1741132.html?${i}` });
|
||||
});
|
||||
});
|
||||
}
|
||||
load.then(() => {
|
||||
return new Promise((resolve) => {
|
||||
bc.addEventListener("message", ({ data: persisted }) => {
|
||||
resolve(persisted);
|
||||
}, { once: true });
|
||||
// Go back past the first entry that should be in the BFCache.
|
||||
bc.postMessage({ cmd: "go", arg: -(VIEWER_WINDOW + 1) });
|
||||
});
|
||||
}).then((persisted) => {
|
||||
ok(!persisted, "Only 3 pages should be kept in the BFCache");
|
||||
}).then(() => {
|
||||
return new Promise((resolve) => {
|
||||
bc.addEventListener("message", ({ data: persisted }) => {
|
||||
resolve(persisted);
|
||||
}, { once: true });
|
||||
// Go forward to the first entry that should be in the BFCache.
|
||||
bc.postMessage({ cmd: "go", arg: 1 });
|
||||
});
|
||||
}).then((persisted) => {
|
||||
ok(persisted, "3 pages should be kept in the BFCache");
|
||||
|
||||
bc.postMessage("close");
|
||||
|
||||
SimpleTest.finish();
|
||||
});
|
||||
}
|
||||
</script>
|
||||
</head>
|
||||
<body onload="runTest();">
|
||||
<p id="display"></p>
|
||||
<div id="content" style="display: none"></div>
|
||||
<pre id="test"></pre>
|
||||
</body>
|
||||
</html>
|
Загрузка…
Ссылка в новой задаче