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 | // {has,add,remove}Debuggee throw a TypeError if the argument is invalid. |
michael@0 | 2 | |
michael@0 | 3 | load(libdir + "asserts.js"); |
michael@0 | 4 | |
michael@0 | 5 | var dbg = new Debugger; |
michael@0 | 6 | |
michael@0 | 7 | function check(val) { |
michael@0 | 8 | assertThrowsInstanceOf(function () { dbg.hasDebuggee(val); }, TypeError); |
michael@0 | 9 | assertThrowsInstanceOf(function () { dbg.addDebuggee(val); }, TypeError); |
michael@0 | 10 | assertThrowsInstanceOf(function () { dbg.removeDebuggee(val); }, TypeError); |
michael@0 | 11 | } |
michael@0 | 12 | |
michael@0 | 13 | // Primitive values are invalid. |
michael@0 | 14 | check(undefined); |
michael@0 | 15 | check(null); |
michael@0 | 16 | check(false); |
michael@0 | 17 | check(1); |
michael@0 | 18 | check(NaN); |
michael@0 | 19 | check("ok"); |
michael@0 | 20 | |
michael@0 | 21 | // A Debugger.Object that belongs to a different Debugger object is invalid. |
michael@0 | 22 | var g = newGlobal(); |
michael@0 | 23 | var dbg2 = new Debugger; |
michael@0 | 24 | var w = dbg2.addDebuggee(g); |
michael@0 | 25 | assertEq(w instanceof Debugger.Object, true); |
michael@0 | 26 | check(w); |