/* 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/. */ function test() { // initialization waitForExplicitFinish(); let windowsToClose = []; let innerID; let beforeEvents; let afterEvents; let storageShouldOccur; let consoleObserver; let testURI = "http://example.com/browser/dom/tests/browser/test-console-api.html"; let ConsoleAPIStorage = Cc["@mozilla.org/consoleAPI-storage;1"].getService( Ci.nsIConsoleAPIStorage ); function getInnerWindowId(aWindow) { return aWindow.windowGlobalChild.innerWindowId; } function whenNewWindowLoaded(aOptions, aCallback) { let win = OpenBrowserWindow(aOptions); win.addEventListener( "load", function() { aCallback(win); }, { once: true } ); } function doTest(aIsPrivateMode, aWindow, aCallback) { BrowserTestUtils.browserLoaded(aWindow.gBrowser.selectedBrowser).then( () => { consoleObserver = { observe(aSubject, aTopic, aData) { if (aTopic == "console-api-log-event") { afterEvents = ConsoleAPIStorage.getEvents(innerID); is( beforeEvents.length == afterEvents.length - 1, storageShouldOccur, "storage should" + (storageShouldOccur ? "" : " not") + " occur" ); executeSoon(function() { Services.obs.removeObserver( consoleObserver, "console-api-log-event" ); aCallback(); }); } }, }; aWindow.Services.obs.addObserver( consoleObserver, "console-api-log-event" ); aWindow.nativeConsole.log( "foo bar baz (private: " + aIsPrivateMode + ")" ); } ); // We expect that console API messages are always stored. storageShouldOccur = true; innerID = getInnerWindowId(aWindow); beforeEvents = ConsoleAPIStorage.getEvents(innerID); BrowserTestUtils.loadURI(aWindow.gBrowser.selectedBrowser, testURI); } function testOnWindow(aOptions, aCallback) { whenNewWindowLoaded(aOptions, function(aWin) { windowsToClose.push(aWin); // execute should only be called when need, like when you are opening // web pages on the test. If calling executeSoon() is not necesary, then // call whenNewWindowLoaded() instead of testOnWindow() on your test. executeSoon(() => aCallback(aWin)); }); } // this function is called after calling finish() on the test. registerCleanupFunction(function() { windowsToClose.forEach(function(aWin) { aWin.close(); }); }); // test first when not on private mode testOnWindow({}, function(aWin) { doTest(false, aWin, function() { // then test when on private mode testOnWindow({ private: true }, function(aWin) { doTest(true, aWin, finish); }); }); }); }