js/src/tests/js1_8_5/extensions/reflect-parse-proxy.js

Sat, 03 Jan 2015 20:18:00 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Sat, 03 Jan 2015 20:18:00 +0100
branch
TOR_BUG_3246
changeset 7
129ffea94266
permissions
-rw-r--r--

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.

michael@0 1 // |reftest| skip-if(!xulRuntime.shell)
michael@0 2 // bug 905774
michael@0 3
michael@0 4 // Proxy options
michael@0 5 var opts = new Proxy({loc: false}, {});
michael@0 6 assertEq(Reflect.parse("0;", opts).loc === null, true);
michael@0 7 opts.loc = true;
michael@0 8 assertEq(Reflect.parse("0;", opts).loc !== null, true);
michael@0 9 delete opts.loc;
michael@0 10 assertEq(Reflect.parse("0;", opts).loc !== null, true); // default is true
michael@0 11
michael@0 12 // Proxy builder
michael@0 13 var builder = {
michael@0 14 program: function (body) { return body.join(); },
michael@0 15 expressionStatement: function (expr) { return expr + ";" },
michael@0 16 literal: function (val) { return "" + val; }
michael@0 17 };
michael@0 18 opts = {builder: new Proxy(builder, {})};
michael@0 19 assertEq(Reflect.parse("0xff;", opts), "255;");
michael@0 20
michael@0 21 reportCompare(0, 0, 'ok');

mercurial