fune/browser/components/sessionstore/test/browser_687710.js
Jared Wein a54eda04ca Bug 1348068 - Enable the key-spacing rule for eslint and fix the related issues. r=standard8
Running eslint with --fix didn't fix many of the issues. The majority here had to be fixed by hand but a significant majority of the issues were related to a few files that I was able to use find-and-replace with. I regret not making this in to separate commits of the hand-fixes and the fixes from --fix but I don't recall --fix fixing any of the issues.

MozReview-Commit-ID: ANyg2qfo3Qx

--HG--
extra : rebase_source : 61d2aa91bf9474af3d72a5dea41b25dca442c1b7
2017-03-21 14:29:43 -04:00

48 lines
1.2 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
// Test that sessionrestore handles cycles in the shentry graph properly.
//
// These cycles shouldn't be there in the first place, but they cause hangs
// when they mysteriously appear (bug 687710). Docshell code assumes this
// graph is a tree and tires to walk to the root. But if there's a cycle,
// there is no root, and we loop forever.
var stateBackup = ss.getBrowserState();
var state = {windows: [{tabs: [{entries: [
{
docIdentifier: 1,
url: "http://example.com",
triggeringPrincipal_base64,
children: [
{
docIdentifier: 2,
url: "http://example.com",
triggeringPrincipal_base64,
}
]
},
{
docIdentifier: 2,
url: "http://example.com",
triggeringPrincipal_base64,
children: [
{
docIdentifier: 1,
url: "http://example.com",
triggeringPrincipal_base64,
}
]
}
]}]}]}
function test() {
registerCleanupFunction(function() {
ss.setBrowserState(stateBackup);
});
/* This test fails by hanging. */
ss.setBrowserState(JSON.stringify(state));
ok(true, "Didn't hang!");
}