Bug 639771 - Port Bug 597315 [Frameset history does not work properly when restoring a tab] to SeaMonkey. r=Neil
This commit is contained in:
Родитель
50ce7d99db
Коммит
d71a05e059
|
@ -1453,6 +1453,7 @@ SessionStoreService.prototype = {
|
|||
entry.cacheKey = cacheKey.data;
|
||||
}
|
||||
entry.ID = aEntry.ID;
|
||||
entry.docshellID = aEntry.docshellID;
|
||||
|
||||
if (aEntry.referrerURI)
|
||||
entry.referrer = aEntry.referrerURI.spec;
|
||||
|
@ -2532,7 +2533,15 @@ SessionStoreService.prototype = {
|
|||
|
||||
didStartLoad = true;
|
||||
try {
|
||||
browser.webNavigation.gotoIndex(activeIndex);
|
||||
// In order to work around certain issues in session history, we need to
|
||||
// force session history to update its internal index and call reload
|
||||
// instead of gotoIndex. c.f. bug 597315
|
||||
var sessionHistory = browser.webNavigation.sessionHistory;
|
||||
// delete this after 2.0
|
||||
sessionHistory.QueryInterface(Components.interfaces.nsISHistory_2_0_BRANCH);
|
||||
|
||||
sessionHistory.getEntryAtIndex(activeIndex, true);
|
||||
sessionHistory.reloadCurrentEntry();
|
||||
}
|
||||
catch (ex) {
|
||||
// ignore page load errors
|
||||
|
@ -2647,6 +2656,9 @@ SessionStoreService.prototype = {
|
|||
shEntry.ID = id;
|
||||
}
|
||||
|
||||
if (aEntry.docshellID)
|
||||
shEntry.docshellID = aEntry.docshellID;
|
||||
|
||||
if (aEntry.stateData) {
|
||||
shEntry.stateData = aEntry.stateData;
|
||||
}
|
||||
|
|
|
@ -92,6 +92,13 @@ _BROWSER_FILES = \
|
|||
browser_526613.js \
|
||||
browser_528776.js \
|
||||
browser_586068-cascaded_restore.js \
|
||||
browser_597315.js \
|
||||
browser_597315_index.html \
|
||||
browser_597315_a.html \
|
||||
browser_597315_b.html \
|
||||
browser_597315_c.html \
|
||||
browser_597315_c1.html \
|
||||
browser_597315_c2.html \
|
||||
browser_607016.js \
|
||||
browser_615394-SSWindowState_events.js \
|
||||
browser_isempty.js \
|
||||
|
|
|
@ -0,0 +1,100 @@
|
|||
/* ***** BEGIN LICENSE BLOCK *****
|
||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
||||
*
|
||||
* The contents of this file are subject to the Mozilla Public License Version
|
||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
* http://www.mozilla.org/MPL/
|
||||
*
|
||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
||||
* for the specific language governing rights and limitations under the
|
||||
* License.
|
||||
*
|
||||
* The Original Code is sessionstore test code.
|
||||
*
|
||||
* The Initial Developer of the Original Code is
|
||||
* Mozilla Foundation.
|
||||
* Portions created by the Initial Developer are Copyright (C) 2010
|
||||
* the Initial Developer. All Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
* Paul O’Shannessy <paul@oshannessy.com>
|
||||
*
|
||||
* Alternatively, the contents of this file may be used under the terms of
|
||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
||||
* of those above. If you wish to allow use of your version of this file only
|
||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
||||
* use your version of this file under the terms of the MPL, indicate your
|
||||
* decision by deleting the provisions above and replace them with the notice
|
||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
||||
* the provisions above, a recipient may use your version of this file under
|
||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
||||
*
|
||||
* ***** END LICENSE BLOCK ***** */
|
||||
|
||||
let ss = Components.classes["@mozilla.org/suite/sessionstore;1"]
|
||||
.getService(Components.interfaces.nsISessionStore);
|
||||
|
||||
let stateBackup = ss.getBrowserState();
|
||||
|
||||
function test() {
|
||||
/** Test for Bug 597315 - Frameset history does not work properly when restoring a tab **/
|
||||
waitForExplicitFinish();
|
||||
|
||||
Services.prefs.setIntPref("browser.tabs.max_tabs_undo", 0);
|
||||
|
||||
let testURL = getRootDirectory(gTestPath) + "browser_597315_index.html";
|
||||
let tab = getBrowser().addTab(testURL);
|
||||
getBrowser().selectedTab = tab;
|
||||
|
||||
waitForLoadsInBrowser(tab.linkedBrowser, 4, function() {
|
||||
let browser_b = tab.linkedBrowser.contentDocument.getElementsByTagName("frame")[1];
|
||||
let document_b = browser_b.contentDocument;
|
||||
let links = document_b.getElementsByTagName("a");
|
||||
|
||||
// We're going to click on the first link, so listen for another load event
|
||||
waitForLoadsInBrowser(tab.linkedBrowser, 1, function() {
|
||||
waitForLoadsInBrowser(tab.linkedBrowser, 1, function() {
|
||||
|
||||
getBrowser().removeTab(tab);
|
||||
// wait for 4 loads again...
|
||||
let newTab = ss.undoCloseTab(window, 0);
|
||||
|
||||
waitForLoadsInBrowser(newTab.linkedBrowser, 4, function() {
|
||||
getBrowser().goBack();
|
||||
waitForLoadsInBrowser(newTab.linkedBrowser, 1, function() {
|
||||
|
||||
let expectedURLEnds = ["a.html", "b.html", "c1.html"];
|
||||
let frames = newTab.linkedBrowser.contentDocument.getElementsByTagName("frame");
|
||||
for (let i = 0; i < frames.length; i++) {
|
||||
is(frames[i].contentDocument.location,
|
||||
getRootDirectory(gTestPath) + "browser_597315_" + expectedURLEnds[i],
|
||||
"frame " + i + " has the right url");
|
||||
}
|
||||
Services.prefs.clearUserPref("browser.tabs.max_tabs_undo");
|
||||
getBrowser().removeTab(newTab);
|
||||
ss.setBrowserState(stateBackup);
|
||||
executeSoon(finish);
|
||||
});
|
||||
});
|
||||
});
|
||||
EventUtils.sendMouseEvent({type:"click"}, links[1], browser_b.contentWindow);
|
||||
});
|
||||
EventUtils.sendMouseEvent({type:"click"}, links[0], browser_b.contentWindow);
|
||||
});
|
||||
}
|
||||
|
||||
// helper function
|
||||
function waitForLoadsInBrowser(aBrowser, aLoadCount, aCallback) {
|
||||
let loadCount = 0;
|
||||
aBrowser.addEventListener("load", function(aEvent) {
|
||||
if (++loadCount < aLoadCount)
|
||||
return;
|
||||
|
||||
aBrowser.removeEventListener("load", arguments.callee, true);
|
||||
aCallback();
|
||||
}, true);
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
<html>
|
||||
<body>
|
||||
I'm A!
|
||||
</body>
|
||||
</html>
|
|
@ -0,0 +1,10 @@
|
|||
<html>
|
||||
<body>
|
||||
I'm B!<br/>
|
||||
<a target="c" href="browser_597315_c1.html">click me first</a><br/>
|
||||
<a target="c" href="browser_597315_c2.html">then click me</a><br/>
|
||||
Close this tab.<br/>
|
||||
Restore this tab.<br/>
|
||||
Click back.<br/>
|
||||
</body>
|
||||
</html>
|
|
@ -0,0 +1,5 @@
|
|||
<html>
|
||||
<body>
|
||||
I'm C!
|
||||
</body>
|
||||
</html>
|
|
@ -0,0 +1,5 @@
|
|||
<html>
|
||||
<body>
|
||||
I'm C1!
|
||||
</body>
|
||||
</html>
|
|
@ -0,0 +1,5 @@
|
|||
<html>
|
||||
<body>
|
||||
I'm C2!
|
||||
</body>
|
||||
</html>
|
|
@ -0,0 +1,10 @@
|
|||
<html>
|
||||
<frameset cols="20%,80%">
|
||||
<frameset rows="30%,70%">
|
||||
<frame src="browser_597315_a.html"/>
|
||||
<frame src="browser_597315_b.html"/>
|
||||
</frameset>
|
||||
<frame src="browser_597315_c.html" name="c"/>
|
||||
</frameset>
|
||||
</html>
|
||||
|
Загрузка…
Ссылка в новой задаче