OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2013, Google Inc. All rights reserved. | 2 * Copyright (c) 2013, Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 16 matching lines...) Expand all Loading... |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 */ | 29 */ |
30 | 30 |
31 #include "config.h" | 31 #include "config.h" |
32 #include "core/fetch/ResourceFetcher.h" | 32 #include "core/fetch/ResourceFetcher.h" |
33 | 33 |
34 #include "core/fetch/FetchInitiatorInfo.h" | 34 #include "core/fetch/FetchInitiatorInfo.h" |
35 #include "core/fetch/FetchRequest.h" | 35 #include "core/fetch/FetchRequest.h" |
36 #include "core/fetch/MemoryCache.h" | 36 #include "core/fetch/MemoryCache.h" |
| 37 #include "core/fetch/ResourceLoader.h" |
37 #include "core/fetch/ResourcePtr.h" | 38 #include "core/fetch/ResourcePtr.h" |
38 #include "platform/exported/WrappedResourceResponse.h" | 39 #include "platform/exported/WrappedResourceResponse.h" |
39 #include "platform/heap/Handle.h" | 40 #include "platform/heap/Handle.h" |
40 #include "platform/network/ResourceRequest.h" | 41 #include "platform/network/ResourceRequest.h" |
41 #include "platform/testing/URLTestHelpers.h" | 42 #include "platform/testing/URLTestHelpers.h" |
42 #include "platform/weborigin/KURL.h" | 43 #include "platform/weborigin/KURL.h" |
43 #include "public/platform/Platform.h" | 44 #include "public/platform/Platform.h" |
44 #include "public/platform/WebURLResponse.h" | 45 #include "public/platform/WebURLResponse.h" |
45 #include "public/platform/WebUnitTestSupport.h" | 46 #include "public/platform/WebUnitTestSupport.h" |
46 #include <gtest/gtest.h> | 47 #include <gtest/gtest.h> |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
110 response.setHTTPHeaderField("Cache-Control", "max-age=3600"); | 111 response.setHTTPHeaderField("Cache-Control", "max-age=3600"); |
111 resource->responseReceived(response, nullptr); | 112 resource->responseReceived(response, nullptr); |
112 resource->finish(); | 113 resource->finish(); |
113 | 114 |
114 FetchRequest fetchRequest = FetchRequest(url, FetchInitiatorInfo()); | 115 FetchRequest fetchRequest = FetchRequest(url, FetchInitiatorInfo()); |
115 ResourcePtr<Resource> newResource = fetcher->requestResource(fetchRequest, T
estResourceFactory(Resource::Image)); | 116 ResourcePtr<Resource> newResource = fetcher->requestResource(fetchRequest, T
estResourceFactory(Resource::Image)); |
116 EXPECT_EQ(resource, newResource); | 117 EXPECT_EQ(resource, newResource); |
117 memoryCache()->remove(resource.get()); | 118 memoryCache()->remove(resource.get()); |
118 } | 119 } |
119 | 120 |
120 | |
121 TEST_F(ResourceFetcherTest, Vary) | 121 TEST_F(ResourceFetcherTest, Vary) |
122 { | 122 { |
123 ResourceFetcher* fetcher = ResourceFetcher::create(ResourceFetcherTestMockFe
tchContext::create()); | |
124 | |
125 KURL url(ParsedURLString, "http://127.0.0.1:8000/foo.html"); | 123 KURL url(ParsedURLString, "http://127.0.0.1:8000/foo.html"); |
126 ResourcePtr<Resource> resource = new Resource(url, Resource::Raw); | 124 ResourcePtr<Resource> resource = new Resource(url, Resource::Raw); |
127 memoryCache()->add(resource.get()); | 125 memoryCache()->add(resource.get()); |
128 ResourceResponse response; | 126 ResourceResponse response; |
129 response.setURL(url); | 127 response.setURL(url); |
130 response.setHTTPStatusCode(200); | 128 response.setHTTPStatusCode(200); |
131 response.setHTTPHeaderField("Cache-Control", "max-age=3600"); | 129 response.setHTTPHeaderField("Cache-Control", "max-age=3600"); |
132 response.setHTTPHeaderField("Vary", "*"); | 130 response.setHTTPHeaderField("Vary", "*"); |
133 resource->responseReceived(response, nullptr); | 131 resource->responseReceived(response, nullptr); |
134 resource->finish(); | 132 resource->finish(); |
135 ASSERT_TRUE(resource->hasVaryHeader()); | 133 ASSERT_TRUE(resource->hasVaryHeader()); |
136 | 134 |
| 135 ResourceFetcher* fetcher = ResourceFetcher::create(ResourceFetcherTestMockFe
tchContext::create()); |
137 FetchRequest fetchRequest = FetchRequest(url, FetchInitiatorInfo()); | 136 FetchRequest fetchRequest = FetchRequest(url, FetchInitiatorInfo()); |
138 Platform::current()->unitTestSupport()->registerMockedURL(url, WebURLRespons
e(), ""); | 137 Platform::current()->unitTestSupport()->registerMockedURL(url, WebURLRespons
e(), ""); |
139 ResourcePtr<Resource> newResource = fetcher->requestResource(fetchRequest, T
estResourceFactory()); | 138 ResourcePtr<Resource> newResource = fetcher->requestResource(fetchRequest, T
estResourceFactory()); |
140 EXPECT_NE(resource, newResource); | 139 EXPECT_NE(resource, newResource); |
141 | 140 newResource->loader()->cancel(); |
142 memoryCache()->remove(newResource.get()); | 141 memoryCache()->remove(newResource.get()); |
143 Platform::current()->unitTestSupport()->unregisterMockedURL(url); | 142 Platform::current()->unitTestSupport()->unregisterMockedURL(url); |
| 143 |
| 144 memoryCache()->remove(resource.get()); |
144 } | 145 } |
145 | 146 |
146 TEST_F(ResourceFetcherTest, VaryOnBack) | 147 TEST_F(ResourceFetcherTest, VaryOnBack) |
147 { | 148 { |
148 ResourceFetcherTestMockFetchContext* context = ResourceFetcherTestMockFetchC
ontext::create(); | 149 ResourceFetcherTestMockFetchContext* context = ResourceFetcherTestMockFetchC
ontext::create(); |
149 context->setCachePolicy(CachePolicyHistoryBuffer); | 150 context->setCachePolicy(CachePolicyHistoryBuffer); |
150 ResourceFetcher* fetcher = ResourceFetcher::create(context); | 151 ResourceFetcher* fetcher = ResourceFetcher::create(context); |
151 | 152 |
152 KURL url(ParsedURLString, "http://127.0.0.1:8000/foo.html"); | 153 KURL url(ParsedURLString, "http://127.0.0.1:8000/foo.html"); |
153 ResourcePtr<Resource> resource = new Resource(url, Resource::Raw); | 154 ResourcePtr<Resource> resource = new Resource(url, Resource::Raw); |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
211 response.setHTTPHeaderField("etag", "1234567890"); | 212 response.setHTTPHeaderField("etag", "1234567890"); |
212 resource1->responseReceived(response, nullptr); | 213 resource1->responseReceived(response, nullptr); |
213 resource1->finish(); | 214 resource1->finish(); |
214 | 215 |
215 ResourceFetcherTestMockFetchContext* context = ResourceFetcherTestMockFetchC
ontext::create(); | 216 ResourceFetcherTestMockFetchContext* context = ResourceFetcherTestMockFetchC
ontext::create(); |
216 context->setCachePolicy(CachePolicyRevalidate); | 217 context->setCachePolicy(CachePolicyRevalidate); |
217 ResourceFetcher* fetcher2 = ResourceFetcher::create(context); | 218 ResourceFetcher* fetcher2 = ResourceFetcher::create(context); |
218 FetchRequest fetchRequest2(url, FetchInitiatorInfo()); | 219 FetchRequest fetchRequest2(url, FetchInitiatorInfo()); |
219 ResourcePtr<Resource> resource2 = fetcher2->requestResource(fetchRequest2, T
estResourceFactory(Resource::Image)); | 220 ResourcePtr<Resource> resource2 = fetcher2->requestResource(fetchRequest2, T
estResourceFactory(Resource::Image)); |
220 EXPECT_EQ(resource1, resource2); | 221 EXPECT_EQ(resource1, resource2); |
| 222 |
| 223 // Tidily(?) shut down the ResourceLoader. |
| 224 resource1->loader()->cancel(); |
| 225 Platform::current()->unitTestSupport()->unregisterMockedURL(url); |
221 } | 226 } |
222 | 227 |
223 } // namespace blink | 228 } // namespace blink |
OLD | NEW |