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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
<!DOCTYPE html>
<meta charset="utf-8">
<title>Service Worker: Registration for iframe</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helpers.sub.js"></script>
<script>
// Set script url and scope url relative to the calling frame's document's url.
// Assert the implementation parses the urls against the calling frame's
// document's url.
async_test(function(t) {
var url = 'resources/blank.html';
var scope = 'resources/registration-for-iframe-from-calling-frame';
var parsed_scope = normalizeURL(scope);
var script = 'resources/empty-worker.js';
var parsed_script = normalizeURL(script);
var frame;
var registration;
service_worker_unregister(t, scope)
.then(function() { return with_iframe(url); })
.then(function(f) {
frame = f;
return frame.contentWindow.navigator.serviceWorker.register(
script,
{ scope: scope });
})
.then(function(r) {
registration = r;
return wait_for_state(t, r.installing, 'activated');
})
.then(function() {
assert_equals(
registration.scope, parsed_scope,
'registration\'s scope must be the scope parsed against calling ' +
'document\'s url');
assert_equals(
registration.active.scriptURL, parsed_script,
'worker\'s script must be the url parsed against calling ' +
'document\'s url');
frame.remove();
return service_worker_unregister_and_done(t, scope);
})
.catch(unreached_rejection(t));
}, 'Subframe\'s container\'s register method should use calling frame\'s ' +
'document\'s url as a base url for parsing its script url and scope url ' +
'- normal case');
// Set script url and scope url relative to the iframe's document's url.
// Assert the implementation throws a NetworkError exception.
async_test(function(t) {
var url = 'resources/blank.html';
var scope = 'registration-for-iframe-from-calling-frame';
var script = 'empty-worker.js';
var frame;
var registration;
service_worker_unregister(t, scope)
.then(function() { return with_iframe(url); })
.then(function(f) {
frame = f;
return frame.contentWindow.navigator.serviceWorker.register(
script,
{ scope: scope });
})
.then(
function() {
assert_unreached('register() should reject');
},
function(e) {
assert_equals(e.name, 'TypeError');
frame.remove();
return service_worker_unregister_and_done(t, scope);
})
.catch(unreached_rejection(t));
}, 'Subframe\'s container\'s register method should use calling frame\'s ' +
'document\'s url as a base url for parsing its script url and scope url ' +
'- error case');
// Set the scope url to a non-subdirectory of the script url.
// Assert the implementation throws a SecurityError exception.
async_test(function(t) {
var url = 'resources/blank.html';
var scope = 'registration-for-iframe-from-calling-frame';
var script = 'resources/empty-worker.js';
var frame;
var registration;
service_worker_unregister(t, scope)
.then(function() { return with_iframe(url); })
.then(function(f) {
frame = f;
return frame.contentWindow.navigator.serviceWorker.register(
script,
{ scope: scope });
})
.then(
function() {
assert_unreached('register() should reject');
},
function(e) {
assert_equals(e.name, 'SecurityError');
frame.remove();
return service_worker_unregister_and_done(t, scope);
})
.catch(unreached_rejection(t));
}, 'A scope url should start with the given script url');
</script>
|