https://github.com/web-platform-tests/wpt
Revision 36857c5f01b941752b8877902dccd8b7b01202be authored by Tooru Fujisawa on 02 October 2018, 08:23:59 UTC, committed by moz-wptsync-bot on 02 October 2018, 08:23:59 UTC
bugzilla-url: https://bugzilla.mozilla.org/show_bug.cgi?id=1495601
gecko-commit: 6568853848ac62384a094e521965e101978b1f62
gecko-integration-branch: mozilla-inbound
gecko-reviewers: sfink
1 parent b7fcdf3
Raw File
Tip revision: 36857c5f01b941752b8877902dccd8b7b01202be authored by Tooru Fujisawa on 02 October 2018, 08:23:59 UTC
Do not raise error if jstests.py is executed without virtualenv on non-automation.
Tip revision: 36857c5
shownotification-resolve-manual.https.html
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<body>
<script>
const worker = 'resources/shownotification-sw.js';

function reset() {
  return navigator.serviceWorker.getRegistrations().then(registrations => {
    return Promise.all(registrations.map(r => r.unregister()));
  });
}

function getNewestWorker(reg) {
  return reg.installing || reg.waiting || reg.active;
}

function registerSwAndGetWorker() {
  return reset()
    .then(() => navigator.serviceWorker.register(worker))
    .then(getNewestWorker);
}

promise_test(() => {
  // Get notification permission
  return Notification.requestPermission().then(permission => {
    if (permission != "granted") {
      throw Error('You must allow notifications for this origin before running this test.');
    }
    return registerSwAndGetWorker();
  }).then(worker => {
    return new Promise(resolve => {
      // Wait for the service worker to post a message with type 'notification-data'.
      navigator.serviceWorker.onmessage = event => {
        if (event.data && event.data.type == 'notification-data') {
          resolve(event.data);
          navigator.serviceWorker.onmessage = null;
        }
      };

      // Ask the service worker to run the test.
      worker.postMessage('test-shownotification');
    })
  }).then(result => {
    assert_true(result.notificationReturned, `Notification appeared in getNotifications`);
    // The icon is delayed by 2000ms, so showNotification should have taken at least 1900 to resolve.
    assert_greater_than(result.resolveDuration, 1900, `showNotification appeared to wait for icon load`);
  });
}, 'showNotification resolves after icon fetch');

</script>
</body>
back to top