mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
118 lines
5.0 KiB
JavaScript
118 lines
5.0 KiB
JavaScript
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
let stateBackup = ss.getBrowserState();
|
|
|
|
function cleanup() {
|
|
// Reset the pref
|
|
try {
|
|
Services.prefs.clearUserPref("browser.sessionstore.restore_on_demand");
|
|
} catch (e) {}
|
|
ss.setBrowserState(stateBackup);
|
|
executeSoon(finish);
|
|
}
|
|
|
|
function test() {
|
|
/** Bug 607016 - If a tab is never restored, attributes (eg. hidden) aren't updated correctly **/
|
|
waitForExplicitFinish();
|
|
ignoreAllUncaughtExceptions();
|
|
|
|
// Set the pref to true so we know exactly how many tabs should be restoring at
|
|
// any given time. This guarantees that a finishing load won't start another.
|
|
Services.prefs.setBoolPref("browser.sessionstore.restore_on_demand", true);
|
|
|
|
// We have our own progress listener for this test, which we'll attach before our state is set
|
|
let progressListener = {
|
|
onStateChange: function (aBrowser, aWebProgress, aRequest, aStateFlags, aStatus) {
|
|
if (aBrowser.__SS_restoreState == TAB_STATE_RESTORING &&
|
|
aStateFlags & Ci.nsIWebProgressListener.STATE_STOP &&
|
|
aStateFlags & Ci.nsIWebProgressListener.STATE_IS_NETWORK &&
|
|
aStateFlags & Ci.nsIWebProgressListener.STATE_IS_WINDOW)
|
|
progressCallback(aBrowser);
|
|
}
|
|
}
|
|
|
|
let state = { windows: [{ tabs: [
|
|
{ entries: [{ url: "http://example.org#1" }], extData: { "uniq": r() } },
|
|
{ entries: [{ url: "http://example.org#2" }], extData: { "uniq": r() } }, // overwriting
|
|
{ entries: [{ url: "http://example.org#3" }], extData: { "uniq": r() } }, // hiding
|
|
{ entries: [{ url: "http://example.org#4" }], extData: { "uniq": r() } }, // adding
|
|
{ entries: [{ url: "http://example.org#5" }], extData: { "uniq": r() } }, // deleting
|
|
{ entries: [{ url: "http://example.org#6" }] } // creating
|
|
], selected: 1 }] };
|
|
|
|
function progressCallback(aBrowser) {
|
|
// We'll remove the progress listener after the first one because we aren't
|
|
// loading any other tabs
|
|
window.gBrowser.removeTabsProgressListener(progressListener);
|
|
|
|
let curState = JSON.parse(ss.getBrowserState());
|
|
for (let i = 0; i < curState.windows[0].tabs.length; i++) {
|
|
let tabState = state.windows[0].tabs[i];
|
|
let tabCurState = curState.windows[0].tabs[i];
|
|
if (tabState.extData) {
|
|
is(tabCurState.extData["uniq"], tabState.extData["uniq"],
|
|
"sanity check that tab has correct extData");
|
|
}
|
|
else {
|
|
// We aren't expecting there to be any data on extData, but panorama
|
|
// may be setting something, so we need to make sure that if we do have
|
|
// data, we just don't have anything for "uniq".
|
|
ok(!("extData" in tabCurState) || !("uniq" in tabCurState.extData),
|
|
"sanity check that tab doesn't have extData or extData doesn't have 'uniq'");
|
|
}
|
|
}
|
|
|
|
// Now we'll set a new unique value on 1 of the tabs
|
|
let newUniq = r();
|
|
ss.setTabValue(gBrowser.tabs[1], "uniq", newUniq);
|
|
gBrowser.removeTab(gBrowser.tabs[1]);
|
|
let closedTabData = (JSON.parse(ss.getClosedTabData(window)))[0];
|
|
is(closedTabData.state.extData.uniq, newUniq,
|
|
"(overwriting) new data is stored in extData");
|
|
|
|
// hide the next tab before closing it
|
|
gBrowser.hideTab(gBrowser.tabs[1]);
|
|
gBrowser.removeTab(gBrowser.tabs[1]);
|
|
closedTabData = (JSON.parse(ss.getClosedTabData(window)))[0];
|
|
ok(closedTabData.state.hidden, "(hiding) tab data has hidden == true");
|
|
|
|
// set data that's not in a conflicting key
|
|
let stillUniq = r();
|
|
ss.setTabValue(gBrowser.tabs[1], "stillUniq", stillUniq);
|
|
gBrowser.removeTab(gBrowser.tabs[1]);
|
|
closedTabData = (JSON.parse(ss.getClosedTabData(window)))[0];
|
|
is(closedTabData.state.extData.stillUniq, stillUniq,
|
|
"(adding) new data is stored in extData");
|
|
|
|
// remove the uniq value and make sure it's not there in the closed data
|
|
ss.deleteTabValue(gBrowser.tabs[1], "uniq");
|
|
gBrowser.removeTab(gBrowser.tabs[1]);
|
|
closedTabData = (JSON.parse(ss.getClosedTabData(window)))[0];
|
|
// Since Panorama might have put data in, first check if there is extData.
|
|
// If there is explicitly check that "uniq" isn't in it. Otherwise, we're ok
|
|
if ("extData" in closedTabData.state) {
|
|
ok(!("uniq" in closedTabData.state.extData),
|
|
"(deleting) uniq not in existing extData");
|
|
}
|
|
else {
|
|
ok(true, "(deleting) no data is stored in extData");
|
|
}
|
|
|
|
// set unique data on the tab that never had any set, make sure that's saved
|
|
let newUniq2 = r();
|
|
ss.setTabValue(gBrowser.tabs[1], "uniq", newUniq2);
|
|
gBrowser.removeTab(gBrowser.tabs[1]);
|
|
closedTabData = (JSON.parse(ss.getClosedTabData(window)))[0];
|
|
is(closedTabData.state.extData.uniq, newUniq2,
|
|
"(creating) new data is stored in extData where there was none");
|
|
|
|
cleanup();
|
|
}
|
|
|
|
window.gBrowser.addTabsProgressListener(progressListener);
|
|
ss.setBrowserState(JSON.stringify(state));
|
|
}
|
|
|