| Index: third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-basic.js
|
| diff --git a/third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-basic.js b/third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-basic.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..354d8aaa97c59c30a74864eb420a9b311ef0a0c3
|
| --- /dev/null
|
| +++ b/third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-basic.js
|
| @@ -0,0 +1,42 @@
|
| +if (this.document === undefined) {
|
| + importScripts("/resources/testharness.js");
|
| + importScripts("../resources/utils.js");
|
| + importScripts("/common/get-host-info.sub.js");
|
| +}
|
| +
|
| +function cors(desc, origin) {
|
| + var url = origin + dirname(location.pathname);
|
| + var urlParameters = "?pipe=header(Access-Control-Allow-Origin,*)";
|
| +
|
| + promise_test(function(test) {
|
| + return fetch(url + RESOURCES_DIR + "top.txt" + urlParameters, {"mode": "no-cors"} ).then(function(resp) {
|
| + assert_equals(resp.status, 0, "Opaque filter: status is 0");
|
| + assert_equals(resp.statusText, "", "Opaque filter: statusText is \"\"");
|
| + assert_equals(resp.type , "opaque", "Opaque filter: response's type is opaque");
|
| + return resp.text().then(function(value) {
|
| + assert_equals(value, "", "Opaque response should have an empty body");
|
| + });
|
| + });
|
| + }, desc + " [no-cors mode]");
|
| +
|
| + promise_test(function(test) {
|
| + return promise_rejects(test, new TypeError(), fetch(url + RESOURCES_DIR + "top.txt", {"mode": "cors"}));
|
| + }, desc + " [server forbid CORS]");
|
| +
|
| + promise_test(function(test) {
|
| + return fetch(url + RESOURCES_DIR + "top.txt" + urlParameters, {"mode": "cors"} ).then(function(resp) {
|
| + assert_equals(resp.status, 200, "Fetch's response's status is 200");
|
| + assert_equals(resp.type , "cors", "CORS response's type is cors");
|
| + });
|
| + }, desc + " [cors mode]");
|
| +}
|
| +
|
| +var host_info = get_host_info();
|
| +
|
| +cors("Same domain different port", host_info.HTTP_ORIGIN_WITH_DIFFERENT_PORT);
|
| +cors("Same domain different protocol different port", host_info.HTTPS_ORIGIN);
|
| +cors("Cross domain basic usage", host_info.HTTP_REMOTE_ORIGIN);
|
| +cors("Cross domain different port", host_info.HTTP_REMOTE_ORIGIN_WITH_DIFFERENT_PORT);
|
| +cors("Cross domain different protocol", host_info.HTTPS_REMOTE_ORIGIN);
|
| +
|
| +done();
|
|
|