Thu, 15 Jan 2015 15:59:08 +0100
Implement a real Private Browsing Mode condition by changing the API/ABI;
This solves Tor bug #9701, complying with disk avoidance documented in
https://www.torproject.org/projects/torbrowser/design/#disk-avoidance.
michael@0 | 1 | 'use strict'; |
michael@0 | 2 | |
michael@0 | 3 | const { Ci } = require('chrome'); |
michael@0 | 4 | const { openTab, closeTab } = require('sdk/tabs/utils'); |
michael@0 | 5 | const { browserWindows } = require('sdk/windows'); |
michael@0 | 6 | const { getOwnerWindow } = require('sdk/private-browsing/window/utils'); |
michael@0 | 7 | const { isPrivate } = require('sdk/private-browsing'); |
michael@0 | 8 | |
michael@0 | 9 | exports.testIsPrivateOnTab = function(assert) { |
michael@0 | 10 | let window = browserWindows.activeWindow; |
michael@0 | 11 | |
michael@0 | 12 | let chromeWindow = getOwnerWindow(window); |
michael@0 | 13 | |
michael@0 | 14 | assert.ok(chromeWindow instanceof Ci.nsIDOMWindow, 'associated window is found'); |
michael@0 | 15 | assert.ok(!isPrivate(chromeWindow), 'the top level window is not private'); |
michael@0 | 16 | |
michael@0 | 17 | let rawTab = openTab(chromeWindow, 'data:text/html,<h1>Hi!</h1>', { |
michael@0 | 18 | isPrivate: true |
michael@0 | 19 | }); |
michael@0 | 20 | |
michael@0 | 21 | // test that the tab is private |
michael@0 | 22 | assert.ok(rawTab.browser.docShell.QueryInterface(Ci.nsILoadContext).usePrivateBrowsing); |
michael@0 | 23 | assert.ok(isPrivate(rawTab.browser.contentWindow)); |
michael@0 | 24 | assert.ok(isPrivate(rawTab.browser)); |
michael@0 | 25 | |
michael@0 | 26 | closeTab(rawTab); |
michael@0 | 27 | }; |