File: synced-state.https.html

package info (click to toggle)
firefox-esr 68.10.0esr-1~deb9u1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 3,143,932 kB
  • sloc: cpp: 5,227,879; javascript: 4,315,531; ansic: 2,467,042; python: 794,975; java: 349,993; asm: 232,034; xml: 228,320; sh: 82,008; lisp: 41,202; makefile: 22,347; perl: 15,555; objc: 5,277; cs: 4,725; yacc: 1,778; ada: 1,681; pascal: 1,673; lex: 1,417; exp: 527; php: 436; ruby: 225; awk: 162; sed: 53; csh: 44
file content (93 lines) | stat: -rw-r--r-- 3,765 bytes parent folder | download | duplicates (29)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<!doctype html>
<title>ServiceWorker: worker objects have synced state</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helpers.sub.js"></script>
<script>
// Tests that ServiceWorker objects representing the same Service Worker
// entity have the same state. JS-level equality is now required according to
// the spec.
'use strict';

function nextChange(worker) {
  return new Promise(function(resolve, reject) {
      worker.addEventListener('statechange', function handler(event) {
          try {
            worker.removeEventListener('statechange', handler);
            resolve(event.currentTarget.state);
          } catch (err) {
            reject(err);
          }
        });
    });
}

promise_test(function(t) {
    var scope = 'resources/synced-state';
    var script = 'resources/empty-worker.js';
    var registration, worker;

    return service_worker_unregister_and_register(t, script, scope)
      .then(function(r) {
          registration = r;
          worker = registration.installing;

          t.add_cleanup(function() {
              return r.unregister();
            });

          return nextChange(worker);
        })
      .then(function(state) {
          assert_equals(state, 'installed',
                        'original SW should be installed');
          assert_equals(registration.installing, null,
                        'in installed, .installing should be null');
          assert_equals(registration.waiting, worker,
                        'in installed, .waiting should be equal to the ' +
                          'original worker');
          assert_equals(registration.waiting.state, 'installed',
                        'in installed, .waiting should be installed');
          assert_equals(registration.active, null,
                        'in installed, .active should be null');

          return nextChange(worker);
        })
      .then(function(state) {
          assert_equals(state, 'activating',
                        'original SW should be activating');
          assert_equals(registration.installing, null,
                        'in activating, .installing should be null');
          assert_equals(registration.waiting, null,
                        'in activating, .waiting should be null');
          assert_equals(registration.active, worker,
                        'in activating, .active should be equal to the ' +
                          'original worker');
          assert_equals(
              registration.active.state, 'activating',
              'in activating, .active should be activating');

          return nextChange(worker);
        })
      .then(function(state) {
          assert_equals(state, 'activated',
                        'original SW should be activated');
          assert_equals(registration.installing, null,
                        'in activated, .installing should be null');
          assert_equals(registration.waiting, null,
                        'in activated, .waiting should be null');
          assert_equals(registration.active, worker,
                        'in activated, .active should be equal to the ' +
                          'original worker');
          assert_equals(registration.active.state, 'activated',
                        'in activated .active should be activated');
        })
      .then(function() {
          return navigator.serviceWorker.getRegistration(scope);
        })
      .then(function(r) {
          assert_equals(r, registration, 'getRegistration should return the ' +
                                         'same object');
        });
  }, 'worker objects for the same entity have the same state');
</script>