gecko-dev/toolkit/components/thumbnails/test/browser_thumbnails_bg_captureIfMissing.js
Mike Conley fac08e5f9c Bug 1591495 - Update thumbnail tests to use more modern primitives, like add_task. r=Gijs
Depends on D50851

Differential Revision: https://phabricator.services.mozilla.com/D50852

--HG--
extra : moz-landing-system : lando
2019-11-01 22:55:11 +00:00

37 lines
1.4 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
add_task(async function thumbnails_bg_captureIfMissing() {
let numNotifications = 0;
function observe(subject, topic, data) {
is(topic, "page-thumbnail:create", "got expected topic");
numNotifications += 1;
}
Services.obs.addObserver(observe, "page-thumbnail:create");
let url = "http://example.com/";
let file = thumbnailFile(url);
ok(!file.exists(), "Thumbnail file should not already exist.");
let [capturedURL] = await bgCaptureIfMissing(url);
is(numNotifications, 1, "got notification of item being created.");
is(capturedURL, url, "Captured URL should be URL passed to capture");
ok(file.exists(url), "Thumbnail should be cached after capture");
let past = Date.now() - 1000000000;
let pastFudge = past + 30000;
file.lastModifiedTime = past;
ok(file.lastModifiedTime < pastFudge, "Last modified time should stick!");
[capturedURL] = await bgCaptureIfMissing(url);
is(numNotifications, 1, "still only 1 notification of item being created.");
is(capturedURL, url, "Captured URL should be URL passed to second capture");
ok(file.exists(), "Thumbnail should remain cached after second capture");
ok(
file.lastModifiedTime < pastFudge,
"File should not have been overwritten"
);
file.remove(false);
Services.obs.removeObserver(observe, "page-thumbnail:create");
});