mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
126 lines
5.1 KiB
JavaScript
126 lines
5.1 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
"use strict";
|
|
|
|
/**
|
|
* This test ensures that the preferences (added in bug 943339) that control how
|
|
* many back and forward button session history entries we store work correctly.
|
|
*
|
|
* It adds a number of entries to the session history, restores them and checks
|
|
* that the restored state matches the preferences.
|
|
*/
|
|
|
|
add_task(function *test_history_cap() {
|
|
const baseURL = "http://example.com/browser_history_cap#"
|
|
const maxEntries = 9; // The number of generated session history entries.
|
|
const middleEntry = 4; // The zero-based index of the middle entry.
|
|
|
|
const maxBack1 = 2; // The history cap settings used for the first test,
|
|
const maxFwd1 = 3; // where maxBack1 + 1 + maxFwd1 < maxEntries.
|
|
|
|
const maxBack2 = 5; // The history cap settings used for the other tests,
|
|
const maxFwd2 = 5; // where maxBack2 + 1 + maxFwd2 > maxEntries.
|
|
|
|
// Set the relevant preferences for the first test.
|
|
gPrefService.setIntPref("browser.sessionhistory.max_entries", maxEntries);
|
|
gPrefService.setIntPref("browser.sessionstore.max_serialize_back", maxBack1);
|
|
gPrefService.setIntPref("browser.sessionstore.max_serialize_forward", maxFwd1);
|
|
|
|
// Make sure the settings we modify are reset afterward.
|
|
registerCleanupFunction(() => {
|
|
gPrefService.clearUserPref("browser.sessionhistory.max_entries");
|
|
gPrefService.clearUserPref("browser.sessionstore.max_serialize_back");
|
|
gPrefService.clearUserPref("browser.sessionstore.max_serialize_forward");
|
|
});
|
|
|
|
let tab = gBrowser.addTab();
|
|
let browser = tab.linkedBrowser;
|
|
yield promiseBrowserLoaded(browser);
|
|
|
|
// Generate the tab state entries and set the one-based
|
|
// tab-state index to the middle session history entry.
|
|
let tabState = {entries: [], index: middleEntry + 1};
|
|
for (let i = 0; i < maxEntries; i++) {
|
|
tabState.entries.push({url: baseURL + i});
|
|
}
|
|
|
|
info("Testing situation where only a subset of session history entries should be restored.");
|
|
|
|
ss.setTabState(tab, JSON.stringify(tabState));
|
|
yield promiseTabRestored(tab);
|
|
SyncHandlers.get(tab.linkedBrowser).flush();
|
|
|
|
let restoredTabState = JSON.parse(ss.getTabState(tab));
|
|
is(restoredTabState.entries.length, maxBack1 + 1 + maxFwd1,
|
|
"The expected number of session history entries was restored.");
|
|
is(restoredTabState.index, maxBack1 + 1, "The restored tab-state index is correct");
|
|
|
|
let indexURLOffset = middleEntry - (restoredTabState.index - 1);
|
|
for (let i = 0; i < restoredTabState.entries.length; i++) {
|
|
is(restoredTabState.entries[i].url, baseURL + (i + indexURLOffset),
|
|
"URL of restored entry matches the expected URL.");
|
|
}
|
|
|
|
// Set the relevant preferences for the other tests.
|
|
gPrefService.setIntPref("browser.sessionstore.max_serialize_back", maxBack2);
|
|
gPrefService.setIntPref("browser.sessionstore.max_serialize_forward", maxFwd2);
|
|
|
|
info("Testing situation where all of the entries in the session history should be restored.");
|
|
|
|
ss.setTabState(tab, JSON.stringify(tabState));
|
|
yield promiseTabRestored(tab);
|
|
SyncHandlers.get(tab.linkedBrowser).flush();
|
|
|
|
restoredTabState = JSON.parse(ss.getTabState(tab));
|
|
is(restoredTabState.entries.length, maxEntries,
|
|
"The expected number of session history entries was restored.");
|
|
is(restoredTabState.index, middleEntry + 1, "The restored tab-state index is correct");
|
|
|
|
for (let i = middleEntry - 2; i <= middleEntry + 2; i++) {
|
|
is(restoredTabState.entries[i].url, baseURL + i,
|
|
"URL of restored entry matches the expected URL.");
|
|
}
|
|
|
|
info("Testing situation where only the 1 + maxFwd2 oldest entries should be restored.");
|
|
|
|
// Set the one-based tab-state index to the oldest session history entry.
|
|
tabState.index = 1;
|
|
|
|
ss.setTabState(tab, JSON.stringify(tabState));
|
|
yield promiseTabRestored(tab);
|
|
SyncHandlers.get(tab.linkedBrowser).flush();
|
|
|
|
restoredTabState = JSON.parse(ss.getTabState(tab));
|
|
is(restoredTabState.entries.length, 1 + maxFwd2,
|
|
"The expected number of session history entries was restored.");
|
|
is(restoredTabState.index, 1, "The restored tab-state index is correct");
|
|
|
|
for (let i = 0; i <= 2; i++) {
|
|
is(restoredTabState.entries[i].url, baseURL + i,
|
|
"URL of restored entry matches the expected URL.");
|
|
}
|
|
|
|
info("Testing situation where only the maxBack2 + 1 newest entries should be restored.");
|
|
|
|
// Set the one-based tab-state index to the newest session history entry.
|
|
tabState.index = maxEntries;
|
|
|
|
ss.setTabState(tab, JSON.stringify(tabState));
|
|
yield promiseTabRestored(tab);
|
|
SyncHandlers.get(tab.linkedBrowser).flush();
|
|
|
|
restoredTabState = JSON.parse(ss.getTabState(tab));
|
|
is(restoredTabState.entries.length, maxBack2 + 1,
|
|
"The expected number of session history entries was restored.");
|
|
is(restoredTabState.index, maxBack2 + 1, "The restored tab-state index is correct");
|
|
|
|
indexURLOffset = (maxEntries - 1) - maxBack2;
|
|
for (let i = maxBack2 - 2; i <= maxBack2; i++) {
|
|
is(restoredTabState.entries[i].url, baseURL + (i + indexURLOffset),
|
|
"URL of restored entry matches the expected URL.");
|
|
}
|
|
|
|
gBrowser.removeTab(tab);
|
|
});
|