Sat, 03 Jan 2015 20:18:00 +0100
Conditionally enable double key logic according to:
private browsing mode or privacy.thirdparty.isolate preference and
implement in GetCookieStringCommon and FindCookie where it counts...
With some reservations of how to convince FindCookie users to test
condition and pass a nullptr when disabling double key logic.
1 const Cu = Components.utils;
2 function run_test() {
3 var sb = new Cu.Sandbox('http://www.example.com');
5 sb.obj = { priv: 42, __exposedProps__ : {} };
6 Object.defineProperty(sb.obj, 'readable', { get: function() { return this.priv; }, set: function(x) { this.priv = x; }} );
7 sb.obj.__exposedProps__.readable = 'r';
8 do_check_eq(Cu.evalInSandbox('Object.getOwnPropertyDescriptor(obj, "readable").get.call(obj)', sb), 42);
9 sb.obj.readable = 32;
10 do_check_eq(Cu.evalInSandbox('Object.getOwnPropertyDescriptor(obj, "readable").get.call(obj);', sb), 32);
11 do_check_eq(Cu.evalInSandbox('Object.__lookupGetter__.call(obj, "readable").call(obj);', sb), 32);
12 Object.getOwnPropertyDescriptor(sb.obj, "readable").set.call(sb.obj, 22);
13 do_check_eq(sb.obj.readable, 22);
14 Object.__lookupSetter__.call(sb.obj, "readable").call(sb.obj, 21);
15 do_check_eq(sb.obj.readable, 21);
16 checkThrows(sb, 'obj.readable = 11;');
17 do_check_eq(Cu.evalInSandbox('Object.getOwnPropertyDescriptor(obj, "readable").set', sb), null);
18 do_check_eq(Cu.evalInSandbox('Object.__lookupSetter__.call(obj, "readable")', sb), null);
19 do_check_eq(sb.obj.readable, 21);
20 }
22 function checkThrows(sb, expression) {
23 var result = Cu.evalInSandbox('(function() { try { ' + expression + ' return "success"; } catch (e) { return e.toString(); } })();', sb);
24 dump("Result: " + result);
25 do_check_true(!!/denied/.exec(result));
26 }