Update web-platform-tests to revision 7ec633bbfbc01de4972e65f81f593983d9cdc17d

This commit is contained in:
WPT Sync Bot 2020-01-23 08:22:35 +00:00
parent 24674687ac
commit 36e52003a7
107 changed files with 1452 additions and 646 deletions

View file

@ -7,25 +7,85 @@
<script src="/common/get-host-info.sub.js"></script>
<body>
<script>
function getUrl(origin1, origin2, withHeaders) {
const frameOrigin = host_info.HTTP_NOTSAMESITE_ORIGIN;
return `${frameOrigin}/fetch/api/resources/keepalive-iframe.html?` +
`origin1=${origin1}&` +
`origin2=${origin2}&` +
(withHeaders ? `with-headers` : ``);
}
async function getToken() {
return new Promise((resolve) => {
window.addEventListener('message', (event) => {
resolve(event.data);
}, {once: true});
});
}
async function queryToken(token) {
const response = await fetch(`../resources/stash-take.py?key=${token}`);
const json = await response.json();
return json;
}
// In order to parallelize the work, we are going to have an async_test
// for the rest of the work. Note that we want the serialized behavior
// for the steps so far, so we don't want to make the entire test case
// an async_test.
function checkToken(testName, token) {
async_test((test) => {
new Promise((resolve) => test.step_timeout(resolve, 1000)).then(() => {
return queryToken(token);
}).then((result) => {
assert_equals(result, 'on');
}).then(() => {
test.done();
}).catch(test.step_func((e) => {
assert_unreached(e);
}));
}, testName);
}
const host_info = get_host_info();
promise_test(async (test) => {
const iframe = document.createElement('iframe');
iframe.src = host_info.HTTP_REMOTE_ORIGIN +
'/fetch/api/resources/keepalive-iframe.html';
iframe.src = getUrl('', '', false);
document.body.appendChild(iframe);
const uuid_promise = new Promise((resolve) => {
window.addEventListener('message', (event) => {
resolve(event.data);
});
});
const tokenPromise = getToken();
await (new Promise((resolve) => iframe.addEventListener('load', resolve)));
const uuid = await uuid_promise;
const token = await tokenPromise;
iframe.remove();
await (new Promise((resolve) => test.step_timeout(resolve, 1000)));
const response = await fetch(`../resources/stash-take.py?key=${uuid}`);
const json = await response.json();
assert_equals(json, 'on');
});
checkToken('same-origin', token);
}, 'same-origin; setting up');
promise_test(async (test) => {
const iframe = document.createElement('iframe');
iframe.src = getUrl(host_info.HTTP_REMOTE_ORIGIN,
host_info.HTTP_REMOTE_ORIGIN_WITH_DIFFERENT_PORT, false);
document.body.appendChild(iframe);
const tokenPromise = getToken();
await (new Promise((resolve) => iframe.addEventListener('load', resolve)));
const token = await tokenPromise;
iframe.remove();
checkToken('cross-origin redirect', token);
}, 'cross-origin redirect; setting up');
promise_test(async (test) => {
const iframe = document.createElement('iframe');
iframe.src = getUrl(host_info.HTTP_REMOTE_ORIGIN,
host_info.HTTP_REMOTE_ORIGIN_WITH_DIFFERENT_PORT, true);
document.body.appendChild(iframe);
const tokenPromise = getToken();
await (new Promise((resolve) => iframe.addEventListener('load', resolve)));
const token = await tokenPromise;
iframe.remove();
checkToken('cross-origin redirect with preflight', token);
}, 'cross-origin redirect with preflight; setting up');
</script>
</body>
</html>

View file

@ -35,7 +35,7 @@ test(function() {
}, "Passing undefined to Headers constructor");
test(function() {
assert_throws(new TypeError, function() {
assert_throws_js(TypeError, function() {
var h = new Headers(null);
});
}, "Passing null to Headers constructor");
@ -126,7 +126,7 @@ test(function() {
this.add_cleanup(clearLog);
var record = { a: "b", "\uFFFF": "d" };
var proxy = new Proxy(record, loggingHandler);
assert_throws(new TypeError, function() {
assert_throws_js(TypeError, function() {
var h = new Headers(proxy);
});
@ -151,7 +151,7 @@ test(function() {
this.add_cleanup(clearLog);
var record = { a: "\uFFFF", c: "d" }
var proxy = new Proxy(record, loggingHandler);
assert_throws(new TypeError, function() {
assert_throws_js(TypeError, function() {
var h = new Headers(proxy);
});

View file

@ -2,16 +2,24 @@
<html>
<meta charset="utf-8">
<script src="/common/utils.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script>
const uuid = token();
const URL =
`../resources/redirect.py?` +
`delay=100&` +
`location=../resources/stash-put.py?key=${uuid}%26value=on`;
const SEARCH_PARAMS = new URL(location.href).searchParams;
const ORIGIN1 = SEARCH_PARAMS.get('origin1') || '';
const ORIGIN2 = SEARCH_PARAMS.get('origin2') || '';
const WITH_HEADERS = !!SEARCH_PARAMS.has('with-headers');
const TOKEN = token();
const url =
`${ORIGIN1}/fetch/api/resources/redirect.py?` +
`delay=500&` +
`allow_headers=foo&` +
`location=${ORIGIN2}/fetch/api/resources/stash-put.py?key=${TOKEN}%26value=on`;
addEventListener('load', () => {
let p = fetch(URL, {keepalive: true});
window.parent.postMessage(uuid, '*');
const headers = WITH_HEADERS ? {'foo': 'bar'} : undefined;
let p = fetch(url, {keepalive: true, headers});
window.parent.postMessage(TOKEN, '*');
});
</script>
</html>

View file

@ -1,4 +1,11 @@
def main(request, response):
if request.method == 'OPTIONS':
# CORS preflight
response.headers.set('Access-Control-Allow-Origin', '*')
response.headers.set('Access-Control-Allow-Methods', '*')
response.headers.set('Access-Control-Allow-Headers', '*')
return 'done'
url_dir = '/'.join(request.url_parts.path.split('/')[:-1]) + '/'
key = request.GET.first("key")
value = request.GET.first("value")