2013-09-20 02:11:25 -07:00
|
|
|
function run_test()
|
|
|
|
{
|
2014-01-08 15:27:29 -08:00
|
|
|
do_get_profile();
|
|
|
|
|
2013-09-20 02:11:25 -07:00
|
|
|
if (!newCacheBackEndUsed()) {
|
|
|
|
do_check_true(true, "This test doesn't run when the old cache back end is used since the behavior is different");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Open for write, write
|
|
|
|
asyncOpenCacheEntry("http://200/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
|
|
|
new OpenCallback(NEW, "21m", "21d", function(entry) {
|
|
|
|
asyncOpenCacheEntry("http://200/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
|
|
|
new OpenCallback(NORMAL, "21m", "21d", function(entry) {
|
|
|
|
// Open normally but wait for validation from the server
|
|
|
|
asyncOpenCacheEntry("http://200/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
|
|
|
new OpenCallback(REVAL, "21m", "21d", function(entry) {
|
|
|
|
// emulate 200 from server (new content)
|
|
|
|
do_execute_soon(function() {
|
|
|
|
var entry2 = entry.recreate();
|
|
|
|
|
|
|
|
// now fill the new entry, use OpenCallback directly for it
|
|
|
|
(new OpenCallback(NEW, "22m", "22d", function() {}))
|
|
|
|
.onCacheEntryAvailable(entry2, true, null, Cr.NS_OK);
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
var mc = new MultipleCallbacks(3, finish_cache2_test);
|
|
|
|
|
|
|
|
asyncOpenCacheEntry("http://200/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
|
|
|
new OpenCallback(NORMAL, "22m", "22d", function(entry) {
|
|
|
|
mc.fired();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
asyncOpenCacheEntry("http://200/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
|
|
|
new OpenCallback(NORMAL, "22m", "22d", function(entry) {
|
|
|
|
mc.fired();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
asyncOpenCacheEntry("http://200/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
|
|
|
new OpenCallback(NORMAL, "22m", "22d", function(entry) {
|
|
|
|
mc.fired();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
do_test_pending();
|
|
|
|
}
|