Index: third_party/WebKit/LayoutTests/external/wpt/service-workers/service-worker/request-end-to-end.https.html |
diff --git a/third_party/WebKit/LayoutTests/external/wpt/service-workers/service-worker/request-end-to-end.https.html b/third_party/WebKit/LayoutTests/external/wpt/service-workers/service-worker/request-end-to-end.https.html |
index d061a6d1c476f4a5b8db60d8e9259968e89d09a1..7b594aac57d439f0f5b4918869bf1625436525bf 100644 |
--- a/third_party/WebKit/LayoutTests/external/wpt/service-workers/service-worker/request-end-to-end.https.html |
+++ b/third_party/WebKit/LayoutTests/external/wpt/service-workers/service-worker/request-end-to-end.https.html |
@@ -1,75 +1,40 @@ |
<!DOCTYPE html> |
-<title>Service Worker: Request end-to-end</title> |
+<title>Service Worker: FetchEvent.request passed to onfetch</title> |
<script src="/resources/testharness.js"></script> |
<script src="/resources/testharnessreport.js"></script> |
<script src="resources/test-helpers.sub.js"></script> |
<script> |
-var t = async_test('Request: end-to-end'); |
-t.step(function() { |
- var url = 'resources/request-end-to-end-worker.js'; |
- var scope = 'resources/blank.html?request-end-to-end'; |
- |
- service_worker_unregister_and_register(t, url, scope) |
- .then(onRegister) |
- .catch(unreached_rejection(t)); |
- |
- function sendMessagePort(worker) { |
- var messageChannel = new MessageChannel(); |
- worker.postMessage({port:messageChannel.port2}, [messageChannel.port2]); |
- return messageChannel.port1; |
- } |
- |
- function onRegister(registration) { |
- var sw = registration.installing; |
- sw.addEventListener('statechange', t.step_func(function(event) { |
- if (event.target.state == 'activated') { |
- onActive(sw); |
- } |
- })); |
- } |
+'use strict'; |
- function onActive(sw) { |
- var port = sendMessagePort(sw); |
- port.addEventListener('message', t.step_func(function(event) { |
- onMessage(event); |
- }), false); |
- port.start(); |
- } |
- |
- function onMessage(event) { |
- if (event.data === 'received port') { |
- onPortReady(); |
- } else { |
- onResult(event); |
- } |
- } |
- |
- function onPortReady() { |
- // The only purpose of the iframe created here is to generate an HTTP |
- // request, so the element may be removed as soon as the frame has |
- // completed loading. |
- with_iframe(scope).then(function(f) { f.remove(); }) |
- .catch(unreached_rejection(t)); |
- } |
+promise_test(t => { |
+ var url = 'resources/request-end-to-end-worker.js'; |
+ var scope = 'resources/blank.html'; |
+ return service_worker_unregister_and_register(t, url, scope) |
+ .then(r => { |
+ add_completion_callback(() => { r.unregister(); }); |
+ return wait_for_state(t, r.installing, 'activated'); |
+ }) |
+ .then(() => { return with_iframe(scope); }) |
+ .then(frame => { |
+ add_completion_callback(() => { frame.remove(); }); |
- function onResult(event) { |
- assert_equals( |
- event.data.url, |
- location.href.substring(0, location.href.lastIndexOf('/') + 1) + |
- scope, |
- 'request.url should be passed to onfetch event.'); |
- assert_equals(event.data.mode, 'navigate', |
- 'request.mode should be passed to onfetch event.'); |
- assert_equals(event.data.method, 'GET', |
- 'request.method should be passed to onfetch event.'); |
- assert_equals(event.data.referrer, location.href, |
- 'request.referrer should be passed to onfetch event.'); |
- assert_equals(event.data.headers['user-agent'], undefined, |
- 'Default User-Agent header should not be passed to onfetch event.') |
- assert_equals(event.data.errorNameWhileAppendingHeader, 'TypeError', |
- 'Appending a new header to the request must throw a ' + |
- 'TypeError.') |
- service_worker_unregister_and_done(t, scope); |
- } |
-}); |
+ var result = JSON.parse(frame.contentDocument.body.textContent); |
+ assert_equals(result.url, frame.src, 'request.url'); |
+ assert_equals(result.method, 'GET', 'request.method'); |
+ assert_equals(result.referrer, location.href, 'request.referrer'); |
+ assert_equals(result.mode, 'navigate', 'request.mode'); |
+ assert_equals(result.request_construct_error, 'TypeError', |
+ 'Constructing a Request with a Request whose mode ' + |
+ 'is navigate and non-empty RequestInit must throw a ' + |
+ 'TypeError.') |
+ assert_equals(result.credentials, 'include', 'request.credentials'); |
+ assert_equals(result.redirect, 'manual', 'request.redirect'); |
+ assert_equals(result.headers['user-agent'], undefined, |
+ 'Default User-Agent header should not be passed to ' + |
+ 'onfetch event.') |
+ assert_equals(result.append_header_error, 'TypeError', |
+ 'Appending a new header to the request must throw a ' + |
+ 'TypeError.') |
+ }); |
+ }, 'Test FetchEvent.request passed to onfetch'); |
</script> |