netwerk/test/unit/test_cache2-21-anon-storage.js

Thu, 15 Jan 2015 15:59:08 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Thu, 15 Jan 2015 15:59:08 +0100
branch
TOR_BUG_9701
changeset 10
ac0c01689b40
permissions
-rw-r--r--

Implement a real Private Browsing Mode condition by changing the API/ABI;
This solves Tor bug #9701, complying with disk avoidance documented in
https://www.torproject.org/projects/torbrowser/design/#disk-avoidance.

michael@0 1 Components.utils.import('resource://gre/modules/LoadContextInfo.jsm');
michael@0 2
michael@0 3 function run_test()
michael@0 4 {
michael@0 5 do_get_profile();
michael@0 6
michael@0 7 if (!newCacheBackEndUsed()) {
michael@0 8 do_check_true(true, "This test doesn't run when the old cache back end is used since the behavior is different");
michael@0 9 return;
michael@0 10 }
michael@0 11
michael@0 12 // Create and check an entry anon disk storage
michael@0 13 asyncOpenCacheEntry("http://anon1/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, LoadContextInfo.anonymous,
michael@0 14 new OpenCallback(NEW, "an1", "an1", function(entry) {
michael@0 15 asyncOpenCacheEntry("http://anon1/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, LoadContextInfo.anonymous,
michael@0 16 new OpenCallback(NORMAL, "an1", "an1", function(entry) {
michael@0 17 // Create and check an entry non-anon disk storage
michael@0 18 asyncOpenCacheEntry("http://anon1/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, LoadContextInfo.default,
michael@0 19 new OpenCallback(NEW, "na1", "na1", function(entry) {
michael@0 20 asyncOpenCacheEntry("http://anon1/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, LoadContextInfo.default,
michael@0 21 new OpenCallback(NORMAL, "na1", "na1", function(entry) {
michael@0 22 // check the anon entry is still there and intact
michael@0 23 asyncOpenCacheEntry("http://anon1/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, LoadContextInfo.anonymous,
michael@0 24 new OpenCallback(NORMAL, "an1", "an1", function(entry) {
michael@0 25 finish_cache2_test();
michael@0 26 })
michael@0 27 );
michael@0 28 })
michael@0 29 );
michael@0 30 })
michael@0 31 );
michael@0 32 })
michael@0 33 );
michael@0 34 })
michael@0 35 );
michael@0 36
michael@0 37 do_test_pending();
michael@0 38 }

mercurial