addon-sdk/source/test/addons/predefined-id-with-at/lib/main.js

Thu, 15 Jan 2015 15:59:08 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 15 Jan 2015 15:59:08 +0100
branch
TOR_BUG_9701
changeset 10
ac0c01689b40
permissions
-rw-r--r--

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);

mercurial