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.
michael@0 | 1 | <?xml version="1.0"?> |
michael@0 | 2 | <?xml-stylesheet href="chrome://global/skin" type="text/css"?> |
michael@0 | 3 | <?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css" |
michael@0 | 4 | type="text/css"?> |
michael@0 | 5 | <!-- |
michael@0 | 6 | https://bugzilla.mozilla.org/show_bug.cgi?id=720619 |
michael@0 | 7 | --> |
michael@0 | 8 | <window title="Mozilla Bug 720619" |
michael@0 | 9 | xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"> |
michael@0 | 10 | <script type="application/javascript" |
michael@0 | 11 | src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script> |
michael@0 | 12 | |
michael@0 | 13 | <!-- test results are displayed in the html:body --> |
michael@0 | 14 | <body xmlns="http://www.w3.org/1999/xhtml"> |
michael@0 | 15 | <a href="https://bugzilla.mozilla.org/show_bug.cgi?id=720619" |
michael@0 | 16 | target="_blank">Mozilla Bug 720619</a> |
michael@0 | 17 | |
michael@0 | 18 | <!-- test code goes here --> |
michael@0 | 19 | <script type="application/javascript"><![CDATA[ |
michael@0 | 20 | /** Test for Bug 720619 **/ |
michael@0 | 21 | const Cu = Components.utils; |
michael@0 | 22 | |
michael@0 | 23 | var obj = { |
michael@0 | 24 | valueOf: function () { |
michael@0 | 25 | return 42; |
michael@0 | 26 | }, |
michael@0 | 27 | toString: function () { |
michael@0 | 28 | return 'str'; |
michael@0 | 29 | } |
michael@0 | 30 | }; |
michael@0 | 31 | |
michael@0 | 32 | var content = new Cu.Sandbox("about:blank"); |
michael@0 | 33 | content.obj = obj; |
michael@0 | 34 | |
michael@0 | 35 | ok(Cu.evalInSandbox("obj + ''", content) == "[object Object]"); |
michael@0 | 36 | ok(Cu.evalInSandbox("'' + obj", content) == "[object Object]"); |
michael@0 | 37 | ok(isNaN(Cu.evalInSandbox("obj - 0", content))); |
michael@0 | 38 | ok(Cu.evalInSandbox("String(obj)", content) == "[object Object]"); |
michael@0 | 39 | |
michael@0 | 40 | var chrome = new Cu.Sandbox(window); |
michael@0 | 41 | chrome.obj = obj; |
michael@0 | 42 | |
michael@0 | 43 | ok(Cu.evalInSandbox("obj + ''", chrome) == "42"); |
michael@0 | 44 | ok(Cu.evalInSandbox("'' + obj", chrome) == "42"); |
michael@0 | 45 | ok(Cu.evalInSandbox("obj - 0", chrome) == 42); |
michael@0 | 46 | ok(Cu.evalInSandbox("String(obj)", chrome) == "str"); |
michael@0 | 47 | ]]></script> |
michael@0 | 48 | </body> |
michael@0 | 49 | </window> |