diff -r 000000000000 -r 6474c204b198 browser/components/sessionstore/test/browser_597071.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/browser/components/sessionstore/test/browser_597071.js Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,38 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ */ + +/** + * Bug 597071 - Closed windows should only be resurrected when there is a single + * popup window + */ +add_task(function test_close_last_nonpopup_window() { + // Purge the list of closed windows. + while (ss.getClosedWindowCount()) { + ss.forgetClosedWindow(0); + } + + let oldState = ss.getWindowState(window); + + let popupState = {windows: [ + {tabs: [{entries: []}], isPopup: true, hidden: "toolbar"} + ]}; + + // Set this window to be a popup. + ss.setWindowState(window, JSON.stringify(popupState), true); + + // Open a new window with a tab. + let win = yield promiseNewWindowLoaded({private: false}); + let tab = win.gBrowser.addTab("http://example.com/"); + yield promiseBrowserLoaded(tab.linkedBrowser); + + // Make sure sessionstore sees this window. + let state = JSON.parse(ss.getBrowserState()); + is(state.windows.length, 2, "sessionstore knows about this window"); + + // Closed the window and check the closed window count. + yield promiseWindowClosed(win); + is(ss.getClosedWindowCount(), 1, "correct closed window count"); + + // Cleanup. + ss.setWindowState(window, oldState, true); +});