netwerk/test/unit/test_bug667818.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 Cu.import("resource://gre/modules/Services.jsm");
michael@0 2
michael@0 3 function makeURI(str) {
michael@0 4 return Components.classes["@mozilla.org/network/io-service;1"]
michael@0 5 .getService(Components.interfaces.nsIIOService)
michael@0 6 .newURI(str, null, null);
michael@0 7 }
michael@0 8
michael@0 9 function run_test() {
michael@0 10 // Allow all cookies.
michael@0 11 Services.prefs.setIntPref("network.cookie.cookieBehavior", 0);
michael@0 12 var serv = Components.classes["@mozilla.org/cookieService;1"]
michael@0 13 .getService(Components.interfaces.nsICookieService);
michael@0 14 var uri = makeURI("http://example.com/");
michael@0 15 // Try an expiration time before the epoch
michael@0 16 serv.setCookieString(uri, null, "test=test; path=/; domain=example.com; expires=Sun, 31-Dec-1899 16:00:00 GMT;", null);
michael@0 17 do_check_eq(serv.getCookieString(uri, null), null);
michael@0 18 // Now sanity check
michael@0 19 serv.setCookieString(uri, null, "test2=test2; path=/; domain=example.com;", null);
michael@0 20 do_check_eq(serv.getCookieString(uri, null), "test2=test2");
michael@0 21 }

mercurial