1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "core/fetch/CrossOriginAccessControl.h"
#include "platform/network/ResourceRequest.h"
#include "platform/weborigin/SecurityOrigin.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "wtf/RefPtr.h"
#include "wtf/text/WTFString.h"
namespace blink {
namespace {
TEST(CreateAccessControlPreflightRequestTest, LexicographicalOrder) {
ResourceRequest request;
request.addHTTPHeaderField("Orange", "Orange");
request.addHTTPHeaderField("Apple", "Red");
request.addHTTPHeaderField("Kiwifruit", "Green");
request.addHTTPHeaderField("Content-Type", "application/octet-stream");
request.addHTTPHeaderField("Strawberry", "Red");
ResourceRequest preflight = createAccessControlPreflightRequest(request);
EXPECT_EQ("apple,content-type,kiwifruit,orange,strawberry",
preflight.httpHeaderField("Access-Control-Request-Headers"));
}
TEST(CreateAccessControlPreflightRequestTest, ExcludeSimpleHeaders) {
ResourceRequest request;
request.addHTTPHeaderField("Accept", "everything");
request.addHTTPHeaderField("Accept-Language", "everything");
request.addHTTPHeaderField("Content-Language", "everything");
request.addHTTPHeaderField("Save-Data", "on");
ResourceRequest preflight = createAccessControlPreflightRequest(request);
// Do not emit empty-valued headers; an empty list of non-"CORS safelisted"
// request headers should cause "Access-Control-Request-Headers:" to be
// left out in the preflight request.
EXPECT_EQ(nullAtom,
preflight.httpHeaderField("Access-Control-Request-Headers"));
}
TEST(CreateAccessControlPreflightRequestTest, ExcludeSimpleContentTypeHeader) {
ResourceRequest request;
request.addHTTPHeaderField("Content-Type", "text/plain");
ResourceRequest preflight = createAccessControlPreflightRequest(request);
// Empty list also; see comment in test above.
EXPECT_EQ(nullAtom,
preflight.httpHeaderField("Access-Control-Request-Headers"));
}
TEST(CreateAccessControlPreflightRequestTest, IncludeNonSimpleHeader) {
ResourceRequest request;
request.addHTTPHeaderField("X-Custom-Header", "foobar");
ResourceRequest preflight = createAccessControlPreflightRequest(request);
EXPECT_EQ("x-custom-header",
preflight.httpHeaderField("Access-Control-Request-Headers"));
}
TEST(CreateAccessControlPreflightRequestTest,
IncludeNonSimpleContentTypeHeader) {
ResourceRequest request;
request.addHTTPHeaderField("Content-Type", "application/octet-stream");
ResourceRequest preflight = createAccessControlPreflightRequest(request);
EXPECT_EQ("content-type",
preflight.httpHeaderField("Access-Control-Request-Headers"));
}
} // namespace
} // namespace blink
|