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 | /* This Source Code Form is subject to the terms of the Mozilla Public |
michael@0 | 2 | * License, v. 2.0. If a copy of the MPL was not distributed with this |
michael@0 | 3 | * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
michael@0 | 4 | 'use strict'; |
michael@0 | 5 | |
michael@0 | 6 | const { id, preferencesBranch } = require('sdk/self'); |
michael@0 | 7 | const simple = require('sdk/simple-prefs'); |
michael@0 | 8 | const service = require('sdk/preferences/service'); |
michael@0 | 9 | const { AddonManager } = require('chrome').Cu.import('resource://gre/modules/AddonManager.jsm', {}); |
michael@0 | 10 | |
michael@0 | 11 | const expected_id = 'predefined-id@test'; |
michael@0 | 12 | |
michael@0 | 13 | exports.testExpectedID = function(assert) { |
michael@0 | 14 | assert.equal(id, expected_id, 'ID is as expected'); |
michael@0 | 15 | assert.equal(preferencesBranch, expected_id, 'preferences-branch is ' + expected_id); |
michael@0 | 16 | |
michael@0 | 17 | assert.equal(simple.prefs.test, 5, 'test pref is 5'); |
michael@0 | 18 | |
michael@0 | 19 | simple.prefs.test2 = '25'; |
michael@0 | 20 | assert.equal(service.get('extensions.'+expected_id+'.test2'), '25', 'test pref is 25'); |
michael@0 | 21 | assert.equal(service.get('extensions.'+expected_id+'.test2'), simple.prefs.test2, 'test pref is 25'); |
michael@0 | 22 | } |
michael@0 | 23 | |
michael@0 | 24 | exports.testSelfID = function(assert, done) { |
michael@0 | 25 | assert.equal(typeof(id), 'string', 'self.id is a string'); |
michael@0 | 26 | assert.ok(id.length > 0, 'self.id not empty'); |
michael@0 | 27 | |
michael@0 | 28 | AddonManager.getAddonByID(id, function(addon) { |
michael@0 | 29 | assert.equal(addon.id, id, 'found addon with self.id'); |
michael@0 | 30 | done(); |
michael@0 | 31 | }); |
michael@0 | 32 | } |
michael@0 | 33 | |
michael@0 | 34 | require('sdk/test/runner').runTestsFromModule(module); |