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

Unified Diff: third_party/WebKit/LayoutTests/http/tests/serviceworker/resources/registration-tests.js

Issue 1781783002: Implement support for link type serviceworker in link elements. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: move scope parsing to LinkServiceWorker Created 4 years, 9 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: third_party/WebKit/LayoutTests/http/tests/serviceworker/resources/registration-tests.js
diff --git a/third_party/WebKit/LayoutTests/http/tests/serviceworker/resources/registration-tests.js b/third_party/WebKit/LayoutTests/http/tests/serviceworker/resources/registration-tests.js
new file mode 100644
index 0000000000000000000000000000000000000000..053635646f869af9b4ff4a3442a7adf771e5b096
--- /dev/null
+++ b/third_party/WebKit/LayoutTests/http/tests/serviceworker/resources/registration-tests.js
@@ -0,0 +1,391 @@
+function registration_tests(register_method, check_error_types) {
+ function get_newest_worker(registration) {
falken 2016/03/18 01:11:43 Many of our tests use registration.installing in t
Marijn Kruisselbrink 2016/03/18 21:20:06 Done
+ if (registration.installing)
+ return registration.installing;
+ if (registration.waiting)
+ return registration.waiting;
+ if (registration.active)
+ return registration.active;
+ }
+
+ promise_test(function(t) {
+ var script = 'resources/registration-worker.js';
+ var scope = 'resources/registration/normal';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(registration.constructor.name,
+ 'ServiceWorkerRegistration',
+ 'Successfully registered.');
+ service_worker_unregister_and_done(t, scope);
+ })
+ }, 'Registering normal scope');
+
+ promise_test(function(t) {
+ var script = 'resources/registration-worker.js';
+ var scope = 'resources/registration/scope-with-fragment#ref';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(registration.constructor.name,
+ 'ServiceWorkerRegistration',
+ 'Successfully registered.');
+ assert_equals(
+ registration.scope,
+ normalizeURL('resources/registration/scope-with-fragment'),
+ 'A fragment should be removed from scope')
+ service_worker_unregister_and_done(t, scope);
+ })
+ }, 'Registering scope with fragment');
+
+ promise_test(function(t) {
+ var script = 'resources/registration-worker.js';
+ var scope = 'resources/';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(registration.constructor.name,
+ 'ServiceWorkerRegistration',
+ 'Successfully registered.');
+ service_worker_unregister_and_done(t, scope);
+ })
+ }, 'Registering same scope as the script directory');
+
+ promise_test(function(t) {
+ var script = 'resources/registration-worker.js';
+ var scope = 'resources';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registering same scope as the script directory without the last ' +
+ 'slash should fail with SecurityError.');
+ }, 'Registering same scope as the script directory without the last slash');
+
+ promise_test(function(t) {
+ var script = 'resources/registration-worker.js';
+ var scope = 'different-directory/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registration scope outside the script directory should fail ' +
+ 'with SecurityError.');
+ }, 'Registration scope outside the script directory');
+
+ promise_test(function(t) {
+ var script = 'resources/registration-worker.js';
+ var scope = 'http://example.com/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registration scope outside domain should fail with SecurityError.');
+ }, 'Registering scope outside domain');
+
+ promise_test(function(t) {
+ var script = 'http://example.com/worker.js';
+ var scope = 'http://example.com/scope/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registration script outside domain should fail with SecurityError.');
+ }, 'Registering script outside domain');
+
+ promise_test(function(t) {
+ var script = 'resources/no-such-worker.js';
+ var scope = 'resources/scope/no-such-worker';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'NetworkError' : null,
+ navigator.serviceWorker.register(script, {scope: scope}),
+ 'Registration of non-existent script should fail.');
+ }, 'Registering non-existent script');
+
+ promise_test(function(t) {
+ var script = 'resources/invalid-chunked-encoding.php';
+ var scope = 'resources/scope/invalid-chunked-encoding/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'NetworkError' : null,
+ 'Registration of invalid chunked encoding script should fail.');
+ }, 'Registering invalid chunked encoding script');
+
+ promise_test(function(t) {
+ var script = 'resources/invalid-chunked-encoding-with-flush.php';
+ var scope = 'resources/scope/invalid-chunked-encoding-with-flush/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'NetworkError' : null,
+ 'Registration of invalid chunked encoding script should fail.');
+ }, 'Registering invalid chunked encoding script with flush');
+
+ promise_test(function(t) {
+ var script = 'resources/mime-type-worker.php';
+ var scope = 'resources/scope/no-mime-type-worker/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registration of no MIME type script should fail.');
+ }, 'Registering script with no MIME type');
+
+ promise_test(function(t) {
+ var script = 'resources/mime-type-worker.php?mime=text/plain';
+ var scope = 'resources/scope/bad-mime-type-worker/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registration of plain text script should fail.');
+ }, 'Registering script with bad MIME type');
+
+ promise_test(function(t) {
+ var script = 'resources/redirect.php?Redirect=' +
+ encodeURIComponent('/resources/registration-worker.js');
+ var scope = 'resources/scope/redirect/';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registration of redirected script should fail.');
+ }, 'Registering redirected script');
+
+ promise_test(function(t) {
+ var script = 'resources/malformed-worker.php?parse-error';
+ var scope = 'resources/scope/parse-error';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'AbortError' : null,
+ 'Registration of script including parse error should fail.');
+ }, 'Registering script including parse error');
+
+ promise_test(function(t) {
+ var script = 'resources/malformed-worker.php?undefined-error';
+ var scope = 'resources/scope/undefined-error';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'AbortError' : null,
+ 'Registration of script including undefined error should fail.');
+ }, 'Registering script including undefined error');
+
+ promise_test(function(t) {
+ var script = 'resources/malformed-worker.php?uncaught-exception';
+ var scope = 'resources/scope/uncaught-exception';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'AbortError' : null,
+ 'Registration of script including uncaught exception should fail.');
+ }, 'Registering script including uncaught exception');
+
+ promise_test(function(t) {
+ var script = 'resources/malformed-worker.php?caught-exception';
+ var scope = 'resources/scope/caught-exception';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(registration.constructor.name,
+ 'ServiceWorkerRegistration',
+ 'Successfully registered.');
+ service_worker_unregister_and_done(t, scope);
+ })
+ }, 'Registering script including caught exception');
+
+ promise_test(function(t) {
+ var script = 'resources/malformed-worker.php?import-malformed-script';
+ var scope = 'resources/scope/import-malformed-script';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'AbortError' : null,
+ 'Registration of script importing malformed script should fail.');
+ }, 'Registering script importing malformed script');
+
+ promise_test(function(t) {
+ var script = 'resources/malformed-worker.php?import-no-such-script';
+ var scope = 'resources/scope/import-no-such-script';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'AbortError' : null,
+ 'Registration of script importing non-existent script should fail.');
+ }, 'Registering script importing non-existent script');
+
+ promise_test(function(t) {
+ // URL-encoded full-width 'scope'.
+ var name = '%ef%bd%93%ef%bd%83%ef%bd%8f%ef%bd%90%ef%bd%85';
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/' + name + '/escaped-multibyte-character-scope';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(
+ registration.scope,
+ normalizeURL(scope),
+ 'URL-encoded multibyte characters should be available.');
+ service_worker_unregister_and_done(t, scope);
+ });
+ }, 'Scope including URL-encoded multibyte characters');
+
+ promise_test(function(t) {
+ // Non-URL-encoded full-width "scope".
+ var name = String.fromCodePoint(0xff53, 0xff43, 0xff4f, 0xff50, 0xff45);
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/' + name + '/non-escaped-multibyte-character-scope';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(
+ registration.scope,
+ normalizeURL(scope),
+ 'Non-URL-encoded multibyte characters should be available.');
+ service_worker_unregister_and_done(t, scope);
+ });
+ }, 'Scope including non-escaped multibyte characters');
+
+ promise_test(function(t) {
+ var script = 'resources%2fempty-worker.js';
+ var scope = 'resources/scope/encoded-slash-in-script-url';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? new TypeError : null,
+ 'URL-encoded slash in the script URL should be rejected.');
+ }, 'Script URL including URL-encoded slash');
+
+ promise_test(function(t) {
+ var script = 'resources%2Fempty-worker.js';
+ var scope = 'resources/scope/encoded-slash-in-script-url';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? new TypeError : null,
+ 'URL-encoded slash in the script URL should be rejected.');
+ }, 'Script URL including uppercase URL-encoded slash');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/scope%2fencoded-slash-in-scope';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? new TypeError : null,
+ 'URL-encoded slash in the scope should be rejected.');
+ }, 'Scope including URL-encoded slash');
+
+ promise_test(function(t) {
+ var script = 'resources%5cempty-worker.js';
+ var scope = 'resources/scope/encoded-slash-in-script-url';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? new TypeError : null,
+ 'URL-encoded backslash in the script URL should be rejected.');
+ }, 'Script URL including URL-encoded backslash');
+
+ promise_test(function(t) {
+ var script = 'resources%5Cempty-worker.js';
+ var scope = 'resources/scope/encoded-slash-in-script-url';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? new TypeError : null,
+ 'URL-encoded backslash in the script URL should be rejected.');
+ }, 'Script URL including uppercase URL-encoded backslash');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/scope%5cencoded-slash-in-scope';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? new TypeError : null,
+ 'URL-encoded backslash in the scope should be rejected.');
+ }, 'Scope including URL-encoded backslash');
+
+ promise_test(function(t) {
+ var script = 'resources/././empty-worker.js';
+ var scope = 'resources/scope/parent-reference-in-script-url';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(
+ get_newest_worker(registration).scriptURL,
+ normalizeURL('resources/empty-worker.js'),
+ 'Script URL including self-reference should be normalized.');
+ service_worker_unregister_and_done(t, scope);
+ });
+ }, 'Script URL including self-reference');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/././scope/self-reference-in-scope';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(
+ registration.scope,
+ normalizeURL('resources/scope/self-reference-in-scope'),
+ 'Scope including self-reference should be normalized.');
+ service_worker_unregister_and_done(t, scope);
+ });
+ }, 'Scope including self-reference');
+
+ promise_test(function(t) {
+ var script = 'resources/../resources/empty-worker.js';
+ var scope = 'resources/scope/parent-reference-in-script-url';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(
+ get_newest_worker(registration).scriptURL,
+ normalizeURL('resources/empty-worker.js'),
+ 'Script URL including parent-reference should be normalized.');
+ service_worker_unregister_and_done(t, scope);
+ });
+ }, 'Script URL including parent-reference');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/../resources/scope/parent-reference-in-scope';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ assert_equals(
+ registration.scope,
+ normalizeURL('resources/scope/parent-reference-in-scope'),
+ 'Scope including parent-reference should be normalized.');
+ service_worker_unregister_and_done(t, scope);
+ });
+ }, 'Scope including parent-reference');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/../scope/parent-reference-in-scope';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Scope not under the script directory should be rejected.');
+ }, 'Scope including parent-reference and not under the script directory');
+
+ promise_test(function(t) {
+ var script = 'resources////empty-worker.js';
+ var scope = 'resources/scope/consecutive-slashes-in-script-url';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Consecutive slashes in the script url should not be unified.');
+ }, 'Script URL including consecutive slashes');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'resources/scope////consecutive-slashes-in-scope';
+ return register_method(script, {scope: scope})
+ .then(function(registration) {
+ // Although consecutive slashes in the scope are not unified, the
+ // scope is under the script directory and registration should
+ // succeed.
+ assert_equals(
+ registration.scope,
+ normalizeURL(scope),
+ 'Should successfully be registered.');
+ service_worker_unregister_and_done(t, scope);
+ })
+ }, 'Scope including consecutive slashes');
+
+ promise_test(function(t) {
+ var script = 'filesystem:' + normalizeURL('resources/empty-worker.js');
+ var scope = 'resources/scope/filesystem-script-url';
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registering a script which has same-origin filesystem: URL should ' +
+ 'fail with SecurityError.');
+ }, 'Script URL is same-origin filesystem: URL');
+
+ promise_test(function(t) {
+ var script = 'resources/empty-worker.js';
+ var scope = 'filesystem:' + normalizeURL('resources/scope/filesystem-scope-url');
+ return assert_promise_rejects(
+ register_method(script, {scope: scope}),
+ check_error_types ? 'SecurityError' : null,
+ 'Registering with the scope that has same-origin filesystem: URL ' +
+ 'should fail with SecurityError.');
+ }, 'Scope URL is same-origin filesystem: URL');
+}

Powered by Google App Engine
This is Rietveld 408576698