function run_test()
{
  do_get_profile();
  function NowSeconds() {
    return parseInt((new Date()).getTime() / 1000);
  }
  function do_check_time(t, min, max) {
    do_check_true(t >= min);
    do_check_true(t <= max);
  }

  var timeStart = NowSeconds();

  asyncOpenCacheEntry("http://t/", "disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
    new OpenCallback(NEW, "m", "d", function(entry) {

      var firstOpen = NowSeconds();
      do_check_eq(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();
            do_check_eq(entry.fetchCount, 2);
            do_check_time(entry.lastFetched, firstOpen, secondOpen);
            do_check_time(entry.lastModified, timeStart, firstOpen);

            finish_cache2_test();
          })
        );
      })
    })
  );

  do_test_pending();
}