mirror of
https://github.com/servo/servo.git
synced 2025-08-10 16:05:43 +01:00
Update web-platform-tests to revision d011702f368b88b3bae86e7a8fd2ddd22e18b33c
This commit is contained in:
parent
f9608022ca
commit
299ad0f9d0
573 changed files with 38776 additions and 14942 deletions
|
@ -5,20 +5,22 @@
|
|||
<script src=urltestparser.js></script>
|
||||
<div id=log></div>
|
||||
<script>
|
||||
var setup = async_test("Loading data…")
|
||||
setup.step(function() {
|
||||
var request = new XMLHttpRequest()
|
||||
request.open("GET", "urltestdata.json")
|
||||
request.send()
|
||||
request.responseType = "json"
|
||||
request.onload = setup.step_func(function() {
|
||||
runURLTests(request.response)
|
||||
setup.done()
|
||||
function runURLConstructorTests() {
|
||||
var setup = async_test("Loading data…")
|
||||
setup.step(function() {
|
||||
var request = new XMLHttpRequest()
|
||||
request.open("GET", "urltestdata.json")
|
||||
request.send()
|
||||
request.responseType = "json"
|
||||
request.onload = setup.step_func(function() {
|
||||
runURLTests(request.response)
|
||||
setup.done()
|
||||
})
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
function bURL(url, base) {
|
||||
return new URL(url, base || "about:blank");
|
||||
return new URL(url, base || "about:blank")
|
||||
}
|
||||
|
||||
function runURLTests(urltests) {
|
||||
|
@ -30,8 +32,8 @@ function runURLTests(urltests) {
|
|||
if (expected.failure) {
|
||||
assert_throws(new TypeError(), function() {
|
||||
bURL(expected.input, expected.base)
|
||||
});
|
||||
return;
|
||||
})
|
||||
return
|
||||
}
|
||||
|
||||
var url = bURL(expected.input, expected.base)
|
||||
|
@ -45,8 +47,82 @@ function runURLTests(urltests) {
|
|||
assert_equals(url.port, expected.port, "port")
|
||||
assert_equals(url.pathname, expected.pathname, "pathname")
|
||||
assert_equals(url.search, expected.search, "search")
|
||||
if ("searchParams" in expected) {
|
||||
assert_true("searchParams" in url)
|
||||
assert_equals(url.searchParams.toString(), expected.searchParams, "searchParams")
|
||||
}
|
||||
assert_equals(url.hash, expected.hash, "hash")
|
||||
}, "Parsing: <" + expected.input + "> against <" + expected.base + ">")
|
||||
}
|
||||
}
|
||||
|
||||
function runURLSearchParamTests() {
|
||||
test(function() {
|
||||
var url = bURL('http://example.org/?a=b')
|
||||
assert_true("searchParams" in url)
|
||||
var searchParams = url.searchParams
|
||||
assert_true(url.searchParams === searchParams, 'Object identity should hold.')
|
||||
}, 'URL.searchParams getter')
|
||||
|
||||
test(function() {
|
||||
var url = bURL('http://example.org/?a=b')
|
||||
assert_true("searchParams" in url)
|
||||
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'
|
||||
var urlString = 'http://example.org'
|
||||
var url = bURL(urlString)
|
||||
assert_throws(TypeError(), function() { url.searchParams = new URLSearchParams(urlString) })
|
||||
}, 'URL.searchParams setter, invalid values')
|
||||
|
||||
test(function() {
|
||||
var url = bURL('http://example.org/file?a=b&c=d')
|
||||
assert_true("searchParams" in url)
|
||||
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'
|
||||
assert_equals(url.search, '?e=f&g=h')
|
||||
assert_equals(searchParams.toString(), 'e=f&g=h')
|
||||
|
||||
// ..and same but with a leading '?'.
|
||||
url.search = '?e=f&g=h'
|
||||
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 = bURL('http://example.org/file??a=b&c=d')
|
||||
assert_equals(url2.search, '??a=b&c=d')
|
||||
assert_equals(url2.searchParams.toString(), '%3Fa=b&c=d')
|
||||
|
||||
url2.href = 'http://example.org/file??a=b'
|
||||
assert_equals(url2.search, '??a=b')
|
||||
assert_equals(url2.searchParams.toString(), '%3Fa=b')
|
||||
}, 'URL.searchParams and URL.search setters, update propagation')
|
||||
}
|
||||
runURLSearchParamTests()
|
||||
runURLConstructorTests()
|
||||
</script>
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue