mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 943339 - Part 2: Add tests to make sure the new preferences work as expected. r=Yoric
This commit is contained in:
parent
b6d8b26178
commit
9f76dc71d9
@ -68,6 +68,7 @@ support-files =
|
||||
[browser_frametree.js]
|
||||
[browser_frame_history.js]
|
||||
[browser_global_store.js]
|
||||
[browser_history_cap.js]
|
||||
[browser_label_and_icon.js]
|
||||
[browser_merge_closed_tabs.js]
|
||||
[browser_pageStyle.js]
|
||||
|
125
browser/components/sessionstore/test/browser_history_cap.js
Normal file
125
browser/components/sessionstore/test/browser_history_cap.js
Normal file
@ -0,0 +1,125 @@
|
||||
/* 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);
|
||||
});
|
Loading…
Reference in New Issue
Block a user