js/xpconnect/tests/chrome/test_bug771429.xul

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 <?xml version="1.0"?>
michael@0 2 <?xml-stylesheet type="text/css" href="chrome://global/skin"?>
michael@0 3 <?xml-stylesheet type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css"?>
michael@0 4 <!--
michael@0 5 https://bugzilla.mozilla.org/show_bug.cgi?id=771429
michael@0 6 -->
michael@0 7 <window title="Mozilla Bug 771429"
michael@0 8 xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
michael@0 9 <script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"/>
michael@0 10
michael@0 11 <!-- test results are displayed in the html:body -->
michael@0 12 <body xmlns="http://www.w3.org/1999/xhtml">
michael@0 13 <a href="https://bugzilla.mozilla.org/show_bug.cgi?id=771429"
michael@0 14 target="_blank">Mozilla Bug 771429</a>
michael@0 15 </body>
michael@0 16
michael@0 17 <!-- test code goes here -->
michael@0 18 <script type="application/javascript">
michael@0 19 <![CDATA[
michael@0 20 /** Test for Bug 771429 **/
michael@0 21 function f() {}
michael@0 22 function g() { return this; }
michael@0 23 function h() { "use strict"; return this; }
michael@0 24 function ctor() { this.x = 1; }
michael@0 25 f.x = 2;
michael@0 26 f.g = g;
michael@0 27 var Cu = Components.utils;
michael@0 28 var s = new Cu.Sandbox(window, { sandboxPrototype: window } );
michael@0 29 try {
michael@0 30 is(Cu.evalInSandbox('g()', s), window,
michael@0 31 "Should get window as this object of non-strict global function");
michael@0 32 is(Cu.evalInSandbox('h()', s), undefined,
michael@0 33 "Should get undefined as this object of strict global function");
michael@0 34 is(Cu.evalInSandbox('f.x', s), 2,
michael@0 35 "Should have gotten the right thing back");
michael@0 36 is(Cu.evalInSandbox('f.g()', s), f,
michael@0 37 "Should have the right function object");
michael@0 38 is(Cu.evalInSandbox('var x = { z: 7 }; g.call(x).z', s), 7,
michael@0 39 "Should not rebind calls that are already bound");
michael@0 40 // And test what happens when we use the normal Function.prototype.call
michael@0 41 // on g instead of whatever our proxies happen to return.
michael@0 42 is(Cu.evalInSandbox('var x = { z: 7 }; Function.prototype.call.call(g, x).z', s), 7,
michael@0 43 "Should not rebind calls that are already bound");
michael@0 44 is(Cu.evalInSandbox('new ctor();', s).x, 1,
michael@0 45 "Should get a properly constructed object out of the sandbox");
michael@0 46 } catch (e) {
michael@0 47 ok(false, "Should not get an exception: " + e);
michael@0 48 }
michael@0 49 ]]>
michael@0 50 </script>
michael@0 51 </window>

mercurial