browser_console_clear.js
Go to the documentation of this file.
1 /* ***** BEGIN LICENSE BLOCK *****
2  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
3  *
4  * The contents of this file are subject to the Mozilla Public License Version
5  * 1.1 (the "License"); you may not use this file except in compliance with
6  * the License. You may obtain a copy of the License at
7  * http://www.mozilla.org/MPL/
8  *
9  * Software distributed under the License is distributed on an "AS IS" basis,
10  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
11  * for the specific language governing rights and limitations under the
12  * License.
13  *
14  * The Original Code is Private Browsing Tests.
15  *
16  * The Initial Developer of the Original Code is
17  * Ehsan Akhgari.
18  * Portions created by the Initial Developer are Copyright (C) 2008
19  * the Initial Developer. All Rights Reserved.
20  *
21  * Contributor(s):
22  * Ehsan Akhgari <ehsan.akhgari@gmail.com> (Original Author)
23  *
24  * Alternatively, the contents of this file may be used under the terms of
25  * either of the GNU General Public License Version 2 or later (the "GPL"),
26  * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27  * in which case the provisions of the GPL or the LGPL are applicable instead
28  * of those above. If you wish to allow use of your version of this file only
29  * under the terms of either the GPL or the LGPL, and not to allow others to
30  * use your version of this file under the terms of the MPL, indicate your
31  * decision by deleting the provisions above and replace them with the notice
32  * and other provisions required by the GPL or the LGPL. If you do not delete
33  * the provisions above, a recipient may use your version of this file under
34  * the terms of any one of the MPL, the GPL or the LGPL.
35  *
36  * ***** END LICENSE BLOCK ***** */
37 
38 // This test makes sure that the error console is cleared after leaving the
39 // private browsing mode.
40 
41 function test() {
42  // initialization
43  let prefBranch = Cc["@mozilla.org/preferences-service;1"].
44  getService(Ci.nsIPrefBranch);
45  prefBranch.setBoolPref("browser.privatebrowsing.keep_current_session", true);
46  let pb = Cc["@mozilla.org/privatebrowsing;1"].
47  getService(Ci.nsIPrivateBrowsingService);
48  let consoleService = Cc["@mozilla.org/consoleservice;1"].
49  getService(Ci.nsIConsoleService);
50  const kExitMessage = "Message to signal the end of the test";
52 
53  let consoleObserver = {
54  observe: function (aMessage) {
55  if (!aMessage.message)
56  this.gotNull = true;
57  else if (aMessage.message == kExitMessage) {
58  // make sure that the null message was received
59  ok(this.gotNull, "Console should be cleared after leaving the private mode");
60  // make sure the console does not contain kTestMessage
61  ok(!messageExists(), "Message should not exist after leaving the private mode");
62 
63  consoleService.unregisterListener(consoleObserver);
64  prefBranch.clearUserPref("browser.privatebrowsing.keep_current_session");
65  finish();
66  }
67  },
68  gotNull: false
69  };
70  consoleService.registerListener(consoleObserver);
71 
72  function messageExists() {
73  let out = {};
74  consoleService.getMessageArray(out, {});
75  let messages = out.value;
76  if (!messages)
77  messages = [];
78  let found = false;
79  for (let i = 0; i < messages.length; ++i)
80  if (messages[i].message == kTestMessage) {
81  found = true;
82  break;
83  }
84  return found;
85  }
86 
87  const kTestMessage = "Test message from the private browsing test";
88  // make sure that the console is not empty
89  consoleService.logStringMessage(kTestMessage);
90  ok(!consoleObserver.gotNull, "Console shouldn't be cleared yet");
91  ok(messageExists(), "Message should exist before leaving the private mode");
92 
93  pb.privateBrowsingEnabled = true;
94  ok(!consoleObserver.gotNull, "Console shouldn't be cleared yet");
95  ok(messageExists(), "Message should exist after entering the private mode");
96  pb.privateBrowsingEnabled = false;
97 
98  // signal the end of the test
99  consoleService.logStringMessage(kExitMessage);
100 }
const Cc
getService(Ci.sbIFaceplateManager)
waitForExplicitFinish()
GstMessage * message
const Ci
_getSelectedPageStyle s i
function test()
sbDeviceFirmwareAutoCheckForUpdate prototype observe