Index: third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-preflight.js |
diff --git a/third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-preflight.js b/third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-preflight.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..55b524050e255927e0b9cd9c8c8eab52d6223c31 |
--- /dev/null |
+++ b/third_party/WebKit/LayoutTests/external/wpt/fetch/api/cors/cors-preflight.js |
@@ -0,0 +1,104 @@ |
+if (this.document === undefined) { |
+ importScripts("/resources/testharness.js"); |
+ importScripts("/common/utils.js"); |
+ importScripts("../resources/utils.js"); |
+ importScripts("/common/get-host-info.sub.js"); |
+} |
+ |
+function headerNames(headers) |
+{ |
+ let names = []; |
+ for (let header of headers) |
+ names.push(header[0].toLowerCase()); |
+ return names |
+} |
+ |
+/* |
+ Check preflight is done |
+ Control if server allows method and headers and check accordingly |
+ Check control access headers added by UA (for method and headers) |
+*/ |
+function corsPreflight(desc, corsUrl, method, allowed, headers, safeHeaders) { |
+ return promise_test(function(test) { |
+ var uuid_token = token(); |
+ return fetch(RESOURCES_DIR + "clean-stash.py?token=" + uuid_token).then(function(response) { |
+ var url = corsUrl; |
+ var urlParameters = "?token=" + uuid_token + "&max_age=0"; |
+ var requestInit = {"mode": "cors", "method": method}; |
+ var requestHeaders = []; |
+ if (headers) |
+ requestHeaders.push.apply(requestHeaders, headers); |
+ if (safeHeaders) |
+ requestHeaders.push.apply(requestHeaders, safeHeaders); |
+ requestInit["headers"] = requestHeaders; |
+ |
+ if (allowed) { |
+ urlParameters += "&allow_methods=" + method + "&control_request_headers"; |
+ if (headers) { |
+ //Make the server allow the headers |
+ urlParameters += "&allow_headers=" + headerNames(headers).join("%20%2C"); |
+ } |
+ return fetch(url + urlParameters, requestInit).then(function(resp) { |
+ assert_equals(resp.status, 200, "Response's status is 200"); |
+ assert_equals(resp.headers.get("x-did-preflight"), "1", "Preflight request has been made"); |
+ if (headers) { |
+ var actualHeaders = resp.headers.get("x-control-request-headers").toLowerCase().split(","); |
+ for (var i in actualHeaders) |
+ actualHeaders[i] = actualHeaders[i].trim(); |
+ for (var header of headers) |
+ assert_in_array(header[0].toLowerCase(), actualHeaders, "Preflight asked permission for header: " + header); |
+ |
+ let accessControlAllowHeaders = headerNames(headers).sort().join(","); |
+ assert_equals(resp.headers.get("x-control-request-headers"), accessControlAllowHeaders, "Access-Control-Allow-Headers value"); |
+ return fetch(RESOURCES_DIR + "clean-stash.py?token=" + uuid_token); |
+ } else { |
+ assert_equals(resp.headers.get("x-control-request-headers"), null, "Access-Control-Request-Headers should be omitted") |
+ } |
+ }); |
+ } else { |
+ return promise_rejects(test, new TypeError(), fetch(url + urlParameters, requestInit)).then(function(){ |
+ return fetch(RESOURCES_DIR + "clean-stash.py?token=" + uuid_token); |
+ }); |
+ } |
+ }); |
+ }, desc); |
+} |
+ |
+var corsUrl = get_host_info().HTTP_REMOTE_ORIGIN + dirname(location.pathname) + RESOURCES_DIR + "preflight.py"; |
+ |
+corsPreflight("CORS [DELETE], server allows", corsUrl, "DELETE", true); |
+corsPreflight("CORS [DELETE], server refuses", corsUrl, "DELETE", false); |
+corsPreflight("CORS [PUT], server allows", corsUrl, "PUT", true); |
+corsPreflight("CORS [PUT], server refuses", corsUrl, "PUT", false); |
+corsPreflight("CORS [PATCH], server allows", corsUrl, "PATCH", true); |
+corsPreflight("CORS [PATCH], server refuses", corsUrl, "PATCH", false); |
+corsPreflight("CORS [NEW], server allows", corsUrl, "NEW", true); |
+corsPreflight("CORS [NEW], server refuses", corsUrl, "NEW", false); |
+ |
+corsPreflight("CORS [GET] [x-test-header: allowed], server allows", corsUrl, "GET", true, [["x-test-header1", "allowed"]]); |
+corsPreflight("CORS [GET] [x-test-header: refused], server refuses", corsUrl, "GET", false, [["x-test-header1", "refused"]]); |
+ |
+var headers = [ |
+ ["x-test-header1", "allowedOrRefused"], |
+ ["x-test-header2", "allowedOrRefused"], |
+ ["X-test-header3", "allowedOrRefused"], |
+ ["x-test-header-b", "allowedOrRefused"], |
+ ["x-test-header-D", "allowedOrRefused"], |
+ ["x-test-header-C", "allowedOrRefused"], |
+ ["x-test-header-a", "allowedOrRefused"], |
+ ["Content-Type", "allowedOrRefused"], |
+]; |
+var safeHeaders= [ |
+ ["Accept", "*"], |
+ ["Accept-Language", "bzh"], |
+ ["Content-Language", "eu"], |
+]; |
+ |
+corsPreflight("CORS [GET] [several headers], server allows", corsUrl, "GET", true, headers, safeHeaders); |
+corsPreflight("CORS [GET] [several headers], server refuses", corsUrl, "GET", false, headers, safeHeaders); |
+corsPreflight("CORS [PUT] [several headers], server allows", corsUrl, "PUT", true, headers, safeHeaders); |
+corsPreflight("CORS [PUT] [several headers], server refuses", corsUrl, "PUT", false, headers, safeHeaders); |
+ |
+corsPreflight("CORS [PUT] [only safe headers], server allows", corsUrl, "PUT", true, null, safeHeaders); |
+ |
+done(); |