"use strict"; function run_test() { do_get_profile(); function NowSeconds() { return parseInt(new Date().getTime() / 1000); } function do_check_time(t, min, max) { Assert.ok(t >= min); Assert.ok(t <= max); } var timeStart = NowSeconds(); asyncOpenCacheEntry( "http://t/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null, new OpenCallback(NEW, "m", "d", function(entry) { var firstOpen = NowSeconds(); Assert.equal(entry.fetchCount, 1); do_check_time(entry.lastFetched, timeStart, firstOpen); do_check_time(entry.lastModified, timeStart, firstOpen); do_timeout(2000, () => { asyncOpenCacheEntry( "http://t/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null, new OpenCallback(NORMAL, "m", "d", function(entry) { var secondOpen = NowSeconds(); Assert.equal(entry.fetchCount, 2); do_check_time(entry.lastFetched, firstOpen, secondOpen); do_check_time(entry.lastModified, timeStart, firstOpen); finish_cache2_test(); }) ); }); }) ); do_test_pending(); }