summaryrefslogtreecommitdiffstats
path: root/dom/workers/test/onLine_worker_child.js
blob: a8577fb541cbe7b85ccb47d8989e925ee38e284a (plain)
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
/*
 * Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/licenses/publicdomain/
 */

/*
 * Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/licenses/publicdomain/
 */

function info(text) {
  dump("Test for Bug 925437: worker: " + text + "\n");
}

function ok(test, message) {
  postMessage({ type: "ok", test, message });
}

/**
 * Returns a handler function for an online/offline event. The returned handler
 * ensures the passed event object has expected properties and that the handler
 * is called at the right moment (according to the gState variable).
 * @param nameTemplate The string identifying the hanlder. '%1' in that
 *                     string will be replaced with the event name.
 * @param eventName 'online' or 'offline'
 * @param expectedState value of gState at the moment the handler is called.
 *                       The handler increases gState by one before checking
 *                       if it matches expectedState.
 */
function makeHandler(nameTemplate, eventName, expectedState, prefix, custom) {
  prefix += ": ";
  return function(e) {
    var name = nameTemplate.replace(/%1/, eventName);
    ok(e.constructor == Event, prefix + "event should be an Event");
    ok(e.type == eventName, prefix + "event type should be " + eventName);
    ok(!e.bubbles, prefix + "event should not bubble");
    ok(!e.cancelable, prefix + "event should not be cancelable");
    ok(
      e.target == self,
      prefix + "the event target should be the worker scope"
    );
    ok(
      eventName == "online" ? navigator.onLine : !navigator.onLine,
      prefix +
        "navigator.onLine " +
        navigator.onLine +
        " should reflect event " +
        eventName
    );

    if (custom) {
      custom();
    }
  };
}

var lastTest = false;

function lastTestTest() {
  if (lastTest) {
    postMessage({ type: "finished" });
    close();
  }
}

for (var event of ["online", "offline"]) {
  addEventListener(
    event,
    makeHandler(
      "addEventListener('%1', ..., false)",
      event,
      1,
      "Child Worker",
      lastTestTest
    ),
    false
  );
}

onmessage = function(e) {
  if (e.data.type === "lastTest") {
    lastTest = true;
  } else if (e.data.type === "navigatorState") {
    ok(
      e.data.state === navigator.onLine,
      "Child and parent navigator state should match"
    );
  }
};

postMessage({ type: "ready" });