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" });
|