Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(233)

Unified Diff: LayoutTests/http/tests/serviceworker/windowclient-navigate.html

Issue 1211253007: ServiceWorker: Add LayoutTest for WindowClient.navigate(). (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: LayoutTests/http/tests/serviceworker/windowclient-navigate.html
diff --git a/LayoutTests/http/tests/serviceworker/windowclient-navigate.html b/LayoutTests/http/tests/serviceworker/windowclient-navigate.html
new file mode 100644
index 0000000000000000000000000000000000000000..1748c1e54435445960a881d00bfd1731808bb5ef
--- /dev/null
+++ b/LayoutTests/http/tests/serviceworker/windowclient-navigate.html
@@ -0,0 +1,81 @@
+<!DOCTYPE html>
+<title>Service Worker: WindowClient.navigate() tests</title>
+<script src="../resources/testharness.js"></script>
+<script src="../resources/testharnessreport.js"></script>
+<script src="../resources/get-host-info.js"></script>
+<script src="resources/test-helpers.js"></script>
+<script>
+
+var scope = 'resources/blank.html?windowclient-navigate';
+var client_frame;
+var message_frame;
+var test;
+
+var current_index = 0;
+var test_list = [
+ { url : 'blank.html' },
+ { url : 'blank.html', init : 'uncontrolled/blank.html' },
+ { url : get_host_info()['HTTP_REMOTE_ORIGIN'] +
+ '/serviceworker/resources/blank.html' },
+ { url : 'http://[test].com' },
+ { url : 'view-source://http://test.com' },
nhiroki 2015/09/28 08:59:21 'view-source:http://example.com'? - '//' before
zino 2015/10/07 02:30:41 Done.
+ { url : 'file:///' },
+ { url : 'about:blank' },
+ { url : 'about:crash' }
+];
+
+var expected = [
+ location.origin + '/serviceworker/resources/blank.html',
+ 'UnknownError',
nhiroki 2015/09/28 08:59:21 According to the spec, navigation for uncontrolled
zino 2015/10/07 02:30:41 I tried it but I faced some troubles. So, I filed
nhiroki 2015/10/08 07:52:09 Acknowledged.
+ null,
+ 'TypeError',
+ 'UnknownError',
nhiroki 2015/09/28 08:59:21 The spec does not mention 'view-source', but "Type
zino 2015/10/07 02:30:41 ditto
+ 'SecurityError',
+ 'TypeError',
+ 'TypeError'
+];
+
+var actual = [];
+
+async_test(function(t) {
+ test = t;
+ return service_worker_unregister_and_register(
+ test, 'resources/windowclient-navigate.js', scope)
nhiroki 2015/09/28 08:59:21 Could you add "-worker.js" suffix? "windowclient-
zino 2015/10/07 02:30:41 Done.
+ .then(function(registration) {
+ return wait_for_state(test, registration.installing, 'activated');
+ })
nhiroki 2015/09/28 08:59:21 Could you insert more indents like this? return s
zino 2015/10/07 02:30:41 Done.
+ .then(function() {
+ var init_url = test_list[current_index].init || scope;
+ return with_iframe(init_url + '#client');
+ })
+ .then(function(f) {
+ client_frame = f;
+ return with_iframe(scope + '#message');
+ })
+ .then(function(f) {
+ message_frame = f;
nhiroki 2015/09/28 08:59:21 Why doesn't this toplevel frame (not |message_fram
zino 2015/10/07 02:30:41 Done.
+ var worker = f.contentWindow.navigator.serviceWorker;
+ worker.onmessage = test.step_func(on_message);
+ worker.controller.postMessage(test_list[current_index++].url);
+ })
+ .catch(unreached_rejection(t));
+}, 'WindowClient.navigate() test');
+
+function on_message(e) {
+ var message = e.data;
+
+ actual.push(message);
+ if (expected.length == actual.length) {
+ assert_array_equals(actual, expected);
+ service_worker_unregister_and_done(test, scope);
+ } else {
+ client_frame.remove();
+ var init_url = test_list[current_index].init || scope;
+ with_iframe(init_url + '#client').then(function(f) {
+ client_frame = f;
+ e.source.postMessage(test_list[current_index++].url);
+ });
nhiroki 2015/09/28 08:59:21 nit: indent with_iframe(...).then(function(f) {
zino 2015/10/07 02:30:41 Done.
+ }
+}
+
+</script>

Powered by Google App Engine
This is Rietveld 408576698