Chromium Code Reviews| Index: third_party/WebKit/LayoutTests/fast/domurl/url-searchparams.html |
| diff --git a/third_party/WebKit/LayoutTests/fast/domurl/url-searchparams.html b/third_party/WebKit/LayoutTests/fast/domurl/url-searchparams.html |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..20f8790cfeee56a1473c1b305ef65de128a21ddb |
| --- /dev/null |
| +++ b/third_party/WebKit/LayoutTests/fast/domurl/url-searchparams.html |
| @@ -0,0 +1,67 @@ |
| +<!DOCTYPE html> |
| +<link rel="help" href="https://url.spec.whatwg.org/#interface-urlsearchparams"> |
| +<script src="../../resources/testharness.js"></script> |
| +<script src="../../resources/testharnessreport.js"></script> |
| +<script> |
| +function assert_type_error(f, msg) { |
| + assert_throws(TypeError(), f, msg); |
| +} |
| + |
| +test(function() { |
| + var url = new URL('http://example.org/?a=b'); |
| + var searchParams = url.searchParams; |
| + assert_true(url.searchParams === searchParams, 'Object identity should hold.'); |
| +}, 'URL.searchParams getter'); |
| + |
| +test(function() { |
| + var url = new URL('http://example.org/?a=b'); |
| + var searchParams = url.searchParams; |
| + assert_equals(searchParams.toString(), 'a=b'); |
| + |
| + searchParams.set('a', 'b'); |
| + assert_equals(url.searchParams.toString(), 'a=b'); |
| + assert_equals(url.search, '?a=b'); |
| + url.search = ''; |
| + assert_equals(url.searchParams.toString(), ''); |
| + assert_equals(url.search, ''); |
| + assert_equals(searchParams.toString(), ''); |
| +}, 'URL.searchParams updating, clearing'); |
| + |
| +test(function() { |
| + 'use strict'; |
|
Mike West
2016/04/05 12:43:51
Why do we need strict mode for this test?
sof
2016/04/05 15:23:18
Assignment to readonly attributes will be ignored
|
| + var urlString = 'http://example.org'; |
| + var url = new URL(urlString); |
| + assert_type_error(function() { url.searchParams = new URLSearchParams(urlString); }); |
| + assert_type_error(function() { url.searchParams = null; }); |
| + assert_type_error(function() { url.searchParams = 2; }); |
| + assert_type_error(function() { url.searchParams = {}; }); |
| +}, 'URL.searchParams setter, invalid values'); |
| + |
| +test(function() { |
| + var url = new URL('http://example.org/file?a=b&c=d'); |
| + var searchParams = url.searchParams; |
| + assert_equals(url.search, '?a=b&c=d'); |
| + assert_equals(searchParams.toString(), 'a=b&c=d'); |
| + |
| + // Test that setting 'search' propagates to the URL object's query |
| + // object. |
| + url.search = 'e=f&g=h'; |
|
Mike West
2016/04/05 12:43:51
Can you add a test that verifies that `?e=f&g=h` h
sof
2016/04/05 15:23:18
Done.
|
| + assert_equals(url.search, '?e=f&g=h'); |
| + assert_equals(searchParams.toString(), 'e=f&g=h'); |
| + |
| + // And in the other direction; altering searchParams propagates |
| + // back to 'search'. |
| + searchParams.append('i', ' j '); |
| + assert_equals(url.search, '?e=f&g=h&i=+j+'); |
| + assert_equals(url.searchParams.toString(), 'e=f&g=h&i=+j+'); |
| + assert_equals(searchParams.get('i'), ' j '); |
| + |
| + searchParams.set('e', 'updated'); |
| + assert_equals(url.search, '?e=updated&g=h&i=+j+'); |
| + assert_equals(searchParams.get('e'), 'updated'); |
| + |
| + var url2 = new URL('http://example.org/file?a=b&c=d'); |
| + assert_equals(url2.search, '?a=b&c=d'); |
| + assert_equals(url2.searchParams.toString(), 'a=b&c=d'); |
| +}, 'URL.searchParams and URL.search setters, update propagation'); |
| +</script> |