addon-sdk/source/test/test-ui-id.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 { identify } = require('sdk/ui/id');
michael@0 7 const { Class } = require('sdk/core/heritage');
michael@0 8
michael@0 9 const signature = /{[0-9a-f\-]+}/;
michael@0 10
michael@0 11 exports['test generate id'] = function(assert) {
michael@0 12 let first = identify({});
michael@0 13 let second = identify({});
michael@0 14
michael@0 15 assert.ok(signature.test(first), 'first id has a correct signature');
michael@0 16 assert.ok(signature.test(second), 'second id has a correct signature');
michael@0 17
michael@0 18 assert.notEqual(first, identify({}), 'identify generated new uuid [1]');
michael@0 19 assert.notEqual(first, second, 'identify generated new uuid [2]');
michael@0 20 };
michael@0 21
michael@0 22 exports['test get id'] = function(assert) {
michael@0 23 let thing = {};
michael@0 24 let thingID = identify(thing);
michael@0 25
michael@0 26 assert.equal(thingID, identify(thing), 'ids for things are cached by default');
michael@0 27 assert.notEqual(identify(thing), identify({}), 'new ids for new things');
michael@0 28 };
michael@0 29
michael@0 30 exports['test custom id definition for classes'] = function(assert) {
michael@0 31 let Thing = Class({});
michael@0 32 let thing = Thing();
michael@0 33 let counter = 0;
michael@0 34
michael@0 35 identify.define(Thing, function(thing) {
michael@0 36 return ++counter;
michael@0 37 });
michael@0 38
michael@0 39 assert.equal(identify(thing), counter, 'it is possible to define custom identifications');
michael@0 40 assert.ok(signature.test(identify({})), 'defining a custom identification does not affect the default behavior');
michael@0 41 }
michael@0 42
michael@0 43 require('sdk/test').run(exports);

mercurial