Changeset 182152 in webkit
- Timestamp:
- Mar 30, 2015, 2:09:14 PM (10 years ago)
- Location:
- trunk
- Files:
-
- 17 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LayoutTests/ChangeLog
r182149 r182152 1 2015-03-30 Antti Koivisto <antti@apple.com> 2 3 Don't cache resources that are very unlikely to be reused 4 https://bugs.webkit.org/show_bug.cgi?id=143226 5 <rdar://problem/20347160> 6 7 Reviewed by Geoff Garen. 8 9 * http/tests/cache/disk-cache/disk-cache-request-max-stale-expected.txt: 10 * http/tests/cache/disk-cache/disk-cache-request-max-stale-expected.html: 11 12 Keep max-age: 0 cacheable in this test by adding a validation header. 13 14 * http/tests/cache/disk-cache/disk-cache-validation-back-navigation-policy-expected.txt: 15 * http/tests/cache/disk-cache/disk-cache-validation-back-navigation-policy.html: 16 17 Rebase and expand to cover the high priority resource case. 18 1 19 2015-03-30 Marcos Chavarría Teijeiro <chavarria1991@gmail.com> 2 20 -
trunk/LayoutTests/http/tests/cache/disk-cache/disk-cache-request-max-stale-expected.txt
r182145 r182152 6 6 running 36 tests 7 7 8 response headers: {"Cache-control":"max-age=0" }8 response headers: {"Cache-control":"max-age=0","ETag":"match"} 9 9 request headers: {"Cache-control":"max-stale=0"} 10 response source: Network10 response source: Disk cache after validation 11 11 12 12 response headers: {"Cache-control":"max-age=100"} … … 14 14 response source: Disk cache 15 15 16 response headers: {"Cache-control":"max-age=0"," Age":"200"}16 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 17 17 request headers: {"Cache-control":"max-stale=0"} 18 response source: Network18 response source: Disk cache after validation 19 19 20 20 response headers: {"Cache-control":"max-age=100","Age":"200"} … … 22 22 response source: Network 23 23 24 response headers: {"Cache-control":"max-age=0" }24 response headers: {"Cache-control":"max-age=0","ETag":"match"} 25 25 request headers: {"Cache-control":"max-stale"} 26 26 response source: Disk cache … … 30 30 response source: Disk cache 31 31 32 response headers: {"Cache-control":"max-age=0"," Age":"200"}32 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 33 33 request headers: {"Cache-control":"max-stale"} 34 34 response source: Disk cache … … 38 38 response source: Disk cache 39 39 40 response headers: {"Cache-control":"max-age=0" }40 response headers: {"Cache-control":"max-age=0","ETag":"match"} 41 41 request headers: {"Cache-control":"max-stale=100"} 42 42 response source: Disk cache … … 46 46 response source: Disk cache 47 47 48 response headers: {"Cache-control":"max-age=0"," Age":"200"}48 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 49 49 request headers: {"Cache-control":"max-stale=100"} 50 response source: Network50 response source: Disk cache after validation 51 51 52 52 response headers: {"Cache-control":"max-age=100","Age":"200"} … … 54 54 response source: Network 55 55 56 response headers: {"Cache-control":"max-age=0" }56 response headers: {"Cache-control":"max-age=0","ETag":"match"} 57 57 request headers: {"Cache-control":"max-stale=0, max-age=0"} 58 response source: Network58 response source: Disk cache after validation 59 59 60 60 response headers: {"Cache-control":"max-age=100"} … … 62 62 response source: Network 63 63 64 response headers: {"Cache-control":"max-age=0"," Age":"200"}64 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 65 65 request headers: {"Cache-control":"max-stale=0, max-age=0"} 66 response source: Network66 response source: Disk cache after validation 67 67 68 68 response headers: {"Cache-control":"max-age=100","Age":"200"} … … 70 70 response source: Network 71 71 72 response headers: {"Cache-control":"max-age=0" }72 response headers: {"Cache-control":"max-age=0","ETag":"match"} 73 73 request headers: {"Cache-control":"max-stale, max-age=0"} 74 response source: Network74 response source: Disk cache after validation 75 75 76 76 response headers: {"Cache-control":"max-age=100"} … … 78 78 response source: Network 79 79 80 response headers: {"Cache-control":"max-age=0"," Age":"200"}80 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 81 81 request headers: {"Cache-control":"max-stale, max-age=0"} 82 response source: Network82 response source: Disk cache after validation 83 83 84 84 response headers: {"Cache-control":"max-age=100","Age":"200"} … … 86 86 response source: Network 87 87 88 response headers: {"Cache-control":"max-age=0" }88 response headers: {"Cache-control":"max-age=0","ETag":"match"} 89 89 request headers: {"Cache-control":"max-stale=100, max-age=0"} 90 response source: Network90 response source: Disk cache after validation 91 91 92 92 response headers: {"Cache-control":"max-age=100"} … … 94 94 response source: Network 95 95 96 response headers: {"Cache-control":"max-age=0"," Age":"200"}96 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 97 97 request headers: {"Cache-control":"max-stale=100, max-age=0"} 98 response source: Network98 response source: Disk cache after validation 99 99 100 100 response headers: {"Cache-control":"max-age=100","Age":"200"} … … 102 102 response source: Network 103 103 104 response headers: {"Cache-control":"max-age=0" }104 response headers: {"Cache-control":"max-age=0","ETag":"match"} 105 105 request headers: {"Cache-control":"max-stale=0, max-age=100"} 106 response source: Network106 response source: Disk cache after validation 107 107 108 108 response headers: {"Cache-control":"max-age=100"} … … 110 110 response source: Disk cache 111 111 112 response headers: {"Cache-control":"max-age=0"," Age":"200"}112 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 113 113 request headers: {"Cache-control":"max-stale=0, max-age=100"} 114 response source: Network114 response source: Disk cache after validation 115 115 116 116 response headers: {"Cache-control":"max-age=100","Age":"200"} … … 118 118 response source: Network 119 119 120 response headers: {"Cache-control":"max-age=0" }120 response headers: {"Cache-control":"max-age=0","ETag":"match"} 121 121 request headers: {"Cache-control":"max-stale, max-age=100"} 122 122 response source: Disk cache … … 126 126 response source: Disk cache 127 127 128 response headers: {"Cache-control":"max-age=0"," Age":"200"}128 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 129 129 request headers: {"Cache-control":"max-stale, max-age=100"} 130 130 response source: Disk cache … … 134 134 response source: Disk cache 135 135 136 response headers: {"Cache-control":"max-age=0" }136 response headers: {"Cache-control":"max-age=0","ETag":"match"} 137 137 request headers: {"Cache-control":"max-stale=100, max-age=100"} 138 138 response source: Disk cache … … 142 142 response source: Disk cache 143 143 144 response headers: {"Cache-control":"max-age=0"," Age":"200"}144 response headers: {"Cache-control":"max-age=0","ETag":"match","Age":"200"} 145 145 request headers: {"Cache-control":"max-stale=100, max-age=100"} 146 response source: Network146 response source: Disk cache after validation 147 147 148 148 response headers: {"Cache-control":"max-age=100","Age":"200"} -
trunk/LayoutTests/http/tests/cache/disk-cache/disk-cache-request-max-stale.html
r182145 r182152 7 7 [ 8 8 [ 9 { responseHeaders: {'Cache-control': 'max-age=0' } },9 { responseHeaders: {'Cache-control': 'max-age=0', 'ETag': 'match' } }, 10 10 { responseHeaders: {'Cache-control': 'max-age=100' } }, 11 11 ], -
trunk/LayoutTests/http/tests/cache/disk-cache/disk-cache-validation-back-navigation-policy-expected.txt
r181894 r182152 7 7 8 8 response headers: undefined 9 response source: Disk cache9 response source: Network 10 10 11 11 response headers: {"Cache-control":"max-age=0"} 12 response source: Disk cache12 response source: Network 13 13 14 14 response headers: {"Cache-control":"max-age=100"} … … 25 25 26 26 response headers: {"Cache-control":"no-cache"} 27 response source: Disk cache27 response source: Network 28 28 29 29 response headers: {"Cache-control":"max-age=0, no-cache"} 30 response source: Disk cache30 response source: Network 31 31 32 32 response headers: {"Cache-control":"max-age=100, no-cache"} … … 88 88 89 89 response headers: {"Cache-control":"must-revalidate"} 90 response source: Disk cache90 response source: Network 91 91 92 92 response headers: {"Cache-control":"max-age=0, must-revalidate"} 93 response source: Disk cache93 response source: Network 94 94 95 95 response headers: {"Cache-control":"max-age=100, must-revalidate"} … … 106 106 107 107 response headers: {"Cache-control":"no-cache, must-revalidate"} 108 response source: Disk cache108 response source: Network 109 109 110 110 response headers: {"Cache-control":"max-age=0, no-cache, must-revalidate"} 111 response source: Disk cache111 response source: Network 112 112 113 113 response headers: {"Cache-control":"max-age=100, no-cache, must-revalidate"} … … 168 168 response source: Disk cache 169 169 170 Testing high priority resources 171 172 response headers: undefined 173 response source: Disk cache 174 175 response headers: {"Cache-control":"max-age=0"} 176 response source: Disk cache 177 178 response headers: {"Cache-control":"max-age=100"} 179 response source: Disk cache 180 181 response headers: {"Cache-control":"no-store"} 182 response source: Network 183 184 response headers: {"Cache-control":"max-age=0, no-store"} 185 response source: Network 186 187 response headers: {"Cache-control":"max-age=100, no-store"} 188 response source: Network 189 190 response headers: {"Cache-control":"no-cache"} 191 response source: Disk cache 192 193 response headers: {"Cache-control":"max-age=0, no-cache"} 194 response source: Disk cache 195 196 response headers: {"Cache-control":"max-age=100, no-cache"} 197 response source: Disk cache 198 199 response headers: {"ETag":"match"} 200 response source: Disk cache 201 202 response headers: {"Cache-control":"max-age=0","ETag":"match"} 203 response source: Disk cache 204 205 response headers: {"Cache-control":"max-age=100","ETag":"match"} 206 response source: Disk cache 207 208 response headers: {"Cache-control":"no-store","ETag":"match"} 209 response source: Network 210 211 response headers: {"Cache-control":"max-age=0, no-store","ETag":"match"} 212 response source: Network 213 214 response headers: {"Cache-control":"max-age=100, no-store","ETag":"match"} 215 response source: Network 216 217 response headers: {"Cache-control":"no-cache","ETag":"match"} 218 response source: Disk cache 219 220 response headers: {"Cache-control":"max-age=0, no-cache","ETag":"match"} 221 response source: Disk cache 222 223 response headers: {"Cache-control":"max-age=100, no-cache","ETag":"match"} 224 response source: Disk cache 225 226 response headers: {"ETag":"nomatch"} 227 response source: Disk cache 228 229 response headers: {"Cache-control":"max-age=0","ETag":"nomatch"} 230 response source: Disk cache 231 232 response headers: {"Cache-control":"max-age=100","ETag":"nomatch"} 233 response source: Disk cache 234 235 response headers: {"Cache-control":"no-store","ETag":"nomatch"} 236 response source: Network 237 238 response headers: {"Cache-control":"max-age=0, no-store","ETag":"nomatch"} 239 response source: Network 240 241 response headers: {"Cache-control":"max-age=100, no-store","ETag":"nomatch"} 242 response source: Network 243 244 response headers: {"Cache-control":"no-cache","ETag":"nomatch"} 245 response source: Disk cache 246 247 response headers: {"Cache-control":"max-age=0, no-cache","ETag":"nomatch"} 248 response source: Disk cache 249 250 response headers: {"Cache-control":"max-age=100, no-cache","ETag":"nomatch"} 251 response source: Disk cache 252 253 response headers: {"Cache-control":"must-revalidate"} 254 response source: Disk cache 255 256 response headers: {"Cache-control":"max-age=0, must-revalidate"} 257 response source: Disk cache 258 259 response headers: {"Cache-control":"max-age=100, must-revalidate"} 260 response source: Disk cache 261 262 response headers: {"Cache-control":"no-store, must-revalidate"} 263 response source: Network 264 265 response headers: {"Cache-control":"max-age=0, no-store, must-revalidate"} 266 response source: Network 267 268 response headers: {"Cache-control":"max-age=100, no-store, must-revalidate"} 269 response source: Network 270 271 response headers: {"Cache-control":"no-cache, must-revalidate"} 272 response source: Disk cache 273 274 response headers: {"Cache-control":"max-age=0, no-cache, must-revalidate"} 275 response source: Disk cache 276 277 response headers: {"Cache-control":"max-age=100, no-cache, must-revalidate"} 278 response source: Disk cache 279 280 response headers: {"ETag":"match","Cache-control":"must-revalidate"} 281 response source: Disk cache 282 283 response headers: {"Cache-control":"max-age=0, must-revalidate","ETag":"match"} 284 response source: Disk cache 285 286 response headers: {"Cache-control":"max-age=100, must-revalidate","ETag":"match"} 287 response source: Disk cache 288 289 response headers: {"Cache-control":"no-store, must-revalidate","ETag":"match"} 290 response source: Network 291 292 response headers: {"Cache-control":"max-age=0, no-store, must-revalidate","ETag":"match"} 293 response source: Network 294 295 response headers: {"Cache-control":"max-age=100, no-store, must-revalidate","ETag":"match"} 296 response source: Network 297 298 response headers: {"Cache-control":"no-cache, must-revalidate","ETag":"match"} 299 response source: Disk cache 300 301 response headers: {"Cache-control":"max-age=0, no-cache, must-revalidate","ETag":"match"} 302 response source: Disk cache 303 304 response headers: {"Cache-control":"max-age=100, no-cache, must-revalidate","ETag":"match"} 305 response source: Disk cache 306 307 response headers: {"ETag":"nomatch","Cache-control":"must-revalidate"} 308 response source: Disk cache 309 310 response headers: {"Cache-control":"max-age=0, must-revalidate","ETag":"nomatch"} 311 response source: Disk cache 312 313 response headers: {"Cache-control":"max-age=100, must-revalidate","ETag":"nomatch"} 314 response source: Disk cache 315 316 response headers: {"Cache-control":"no-store, must-revalidate","ETag":"nomatch"} 317 response source: Network 318 319 response headers: {"Cache-control":"max-age=0, no-store, must-revalidate","ETag":"nomatch"} 320 response source: Network 321 322 response headers: {"Cache-control":"max-age=100, no-store, must-revalidate","ETag":"nomatch"} 323 response source: Network 324 325 response headers: {"Cache-control":"no-cache, must-revalidate","ETag":"nomatch"} 326 response source: Disk cache 327 328 response headers: {"Cache-control":"max-age=0, no-cache, must-revalidate","ETag":"nomatch"} 329 response source: Disk cache 330 331 response headers: {"Cache-control":"max-age=100, no-cache, must-revalidate","ETag":"nomatch"} 332 response source: Disk cache 333 170 334 PASS successfullyParsed is true 171 335 -
trunk/LayoutTests/http/tests/cache/disk-cache/disk-cache-validation-back-navigation-policy.html
r181894 r182152 37 37 debug(""); 38 38 39 runTests(tests); 39 runTests(tests, function () { 40 debug("Testing high priority resources"); 41 debug(""); 42 internals.setOverrideResourceLoadPriority("ResourceLoadPriorityVeryHigh"); 43 runTests(tests); 44 }); 40 45 41 46 </script> -
trunk/Source/WebCore/ChangeLog
r182147 r182152 1 2015-03-30 Antti Koivisto <antti@apple.com> 2 3 Don't cache resources that are very unlikely to be reused 4 https://bugs.webkit.org/show_bug.cgi?id=143226 5 <rdar://problem/20347160> 6 7 Reviewed by Geoff Garen. 8 9 Allow overriding resource load priorities via Internals for testing. 10 11 * loader/FrameLoader.cpp: 12 (WebCore::FrameLoader::addExtraFieldsToRequest): 13 (WebCore::FrameLoader::clearTestingOverrides): 14 * loader/FrameLoader.h: 15 (WebCore::FrameLoader::setOverrideResourceLoadPriorityForTesting): 16 (WebCore::FrameLoader::clearOverrideCachePolicyForTesting): Deleted. 17 * page/DiagnosticLoggingKeys.cpp: 18 (WebCore::DiagnosticLoggingKeys::unlikelyToReuseKey): 19 * page/DiagnosticLoggingKeys.h: 20 21 Add a key. 22 23 * testing/Internals.cpp: 24 (WebCore::Internals::resetToConsistentState): 25 (WebCore::stringToResourceLoadPriority): 26 (WebCore::Internals::setOverrideResourceLoadPriority): 27 * testing/Internals.h: 28 * testing/Internals.idl: 29 1 30 2015-03-30 Javier Fernandez <jfernandez@igalia.com> 2 31 -
trunk/Source/WebCore/loader/FrameLoader.cpp
r181804 r182152 2562 2562 if (m_overrideCachePolicyForTesting) 2563 2563 request.setCachePolicy(m_overrideCachePolicyForTesting.value()); 2564 if (m_overrideResourceLoadPriorityForTesting) 2565 request.setPriority(m_overrideResourceLoadPriorityForTesting.value()); 2564 2566 2565 2567 if (request.cachePolicy() == ReloadIgnoringCacheData) { … … 3414 3416 } 3415 3417 3418 void FrameLoader::clearTestingOverrides() 3419 { 3420 m_overrideCachePolicyForTesting = Nullopt; 3421 m_overrideResourceLoadPriorityForTesting = Nullopt; 3422 } 3423 3416 3424 bool FrameLoaderClient::hasHTMLView() const 3417 3425 { -
trunk/Source/WebCore/loader/FrameLoader.h
r181728 r182152 291 291 292 292 void setOverrideCachePolicyForTesting(ResourceRequestCachePolicy policy) { m_overrideCachePolicyForTesting = policy; } 293 void clearOverrideCachePolicyForTesting() { m_overrideCachePolicyForTesting = Nullopt; } 293 void setOverrideResourceLoadPriorityForTesting(ResourceLoadPriority priority) { m_overrideResourceLoadPriorityForTesting = priority; } 294 WEBCORE_EXPORT void clearTestingOverrides(); 294 295 295 296 private: … … 443 444 444 445 Optional<ResourceRequestCachePolicy> m_overrideCachePolicyForTesting; 446 Optional<ResourceLoadPriority> m_overrideResourceLoadPriorityForTesting; 445 447 446 448 URL m_previousURL; -
trunk/Source/WebCore/page/DiagnosticLoggingKeys.cpp
r181766 r182152 384 384 } 385 385 386 String DiagnosticLoggingKeys::unlikelyToReuseKey() 387 { 388 return ASCIILiteral("unlikelyToReuse"); 389 } 390 386 391 String DiagnosticLoggingKeys::unsupportedHTTPMethodKey() 387 392 { -
trunk/Source/WebCore/page/DiagnosticLoggingKeys.h
r181766 r182152 109 109 static String svgDocumentKey(); 110 110 WEBCORE_EXPORT static String uncacheableStatusCodeKey(); 111 WEBCORE_EXPORT static String unlikelyToReuseKey(); 111 112 WEBCORE_EXPORT static String unsupportedHTTPMethodKey(); 112 113 static String unsuspendableDOMObjectKey(); -
trunk/Source/WebCore/testing/Internals.cpp
r182141 r182152 309 309 if (page->mainFrame().editor().isOverwriteModeEnabled()) 310 310 page->mainFrame().editor().toggleOverwriteModeEnabled(); 311 page->mainFrame().loader().clear OverrideCachePolicyForTesting();311 page->mainFrame().loader().clearTestingOverrides(); 312 312 ApplicationCacheStorage::singleton().setDefaultOriginQuota(ApplicationCacheStorage::noQuota()); 313 313 #if ENABLE(VIDEO) … … 444 444 { 445 445 frame()->loader().setOverrideCachePolicyForTesting(stringToResourceRequestCachePolicy(policy)); 446 } 447 448 static ResourceLoadPriority stringToResourceLoadPriority(const String& policy) 449 { 450 if (policy == "ResourceLoadPriorityVeryLow") 451 return ResourceLoadPriorityVeryLow; 452 if (policy == "ResourceLoadPriorityLow") 453 return ResourceLoadPriorityLow; 454 if (policy == "ResourceLoadPriorityMedium") 455 return ResourceLoadPriorityMedium; 456 if (policy == "ResourceLoadPriorityHigh") 457 return ResourceLoadPriorityHigh; 458 if (policy == "ResourceLoadPriorityVeryHigh") 459 return ResourceLoadPriorityVeryHigh; 460 ASSERT_NOT_REACHED(); 461 return ResourceLoadPriorityLow; 462 } 463 464 void Internals::setOverrideResourceLoadPriority(const String& priority) 465 { 466 frame()->loader().setOverrideResourceLoadPriorityForTesting(stringToResourceLoadPriority(priority)); 446 467 } 447 468 -
trunk/Source/WebCore/testing/Internals.h
r181728 r182152 91 91 String xhrResponseSource(XMLHttpRequest*); 92 92 void setOverrideCachePolicy(const String&); 93 void setOverrideResourceLoadPriority(const String&); 93 94 94 95 void clearMemoryCache(); -
trunk/Source/WebCore/testing/Internals.idl
r181728 r182152 38 38 }; 39 39 40 enum ResourceLoadPriority { 41 "ResourceLoadPriorityVeryLow", 42 "ResourceLoadPriorityLow", 43 "ResourceLoadPriorityMedium", 44 "ResourceLoadPriorityHigh", 45 "ResourceLoadPriorityVeryHigh" 46 }; 40 47 41 48 [ … … 57 64 long memoryCacheSize(); 58 65 void setOverrideCachePolicy(CachePolicy policy); 66 void setOverrideResourceLoadPriority(ResourceLoadPriority priority); 59 67 60 68 void clearPageCache(); -
trunk/Source/WebKit2/ChangeLog
r182150 r182152 1 2015-03-30 Antti Koivisto <antti@apple.com> 2 3 Don't cache resources that are very unlikely to be reused 4 https://bugs.webkit.org/show_bug.cgi?id=143226 5 <rdar://problem/20347160> 6 7 Reviewed by Geoff Garen. 8 9 We are writing lots of resources to the cache that are never used again. 10 11 In browse-around-randomly test this reduced number of cache entries created by ~20% and bytes written by ~5%. 12 13 * NetworkProcess/cache/NetworkCache.cpp: 14 (WebKit::NetworkCache::makeUseDecision): 15 (WebKit::NetworkCache::makeRetrieveDecision): 16 17 Rename for clarity. 18 19 (WebKit::NetworkCache::makeStoreDecision): 20 21 Store only if the resource has non-zero expiration or has validation headers. 22 23 Very High priority resources (main resources) keep the existing policy to minimize impact 24 on back navigation and tab restore. 25 26 (WebKit::NetworkCache::Cache::retrieve): 27 (WebKit::NetworkCache::Cache::store): 28 (WebKit::NetworkCache::canUse): Deleted. 29 (WebKit::NetworkCache::canRetrieve): Deleted. 30 (WebKit::NetworkCache::canStore): Deleted. 31 * NetworkProcess/cache/NetworkCache.h: 32 * NetworkProcess/cache/NetworkCacheStatistics.cpp: 33 (WebKit::NetworkCache::storeDecisionToDiagnosticKey): 34 1 35 2015-03-30 Tim Horton <timothy_horton@apple.com> 2 36 -
trunk/Source/WebKit2/NetworkProcess/cache/NetworkCache.cpp
r182145 r182152 183 183 } 184 184 185 static UseDecision canUse(const Entry& entry, const WebCore::ResourceRequest& request) 186 { 187 if (!verifyVaryingRequestHeaders(entry.varyingRequestHeaders(), request)) { 188 LOG(NetworkCache, "(NetworkProcess) varying header mismatch\n"); 185 static UseDecision makeUseDecision(const Entry& entry, const WebCore::ResourceRequest& request) 186 { 187 if (!verifyVaryingRequestHeaders(entry.varyingRequestHeaders(), request)) 189 188 return UseDecision::NoDueToVaryingHeaderMismatch; 190 }191 189 192 190 // We never revalidate in the case of a history navigation. … … 197 195 return UseDecision::Use; 198 196 199 bool hasValidatorFields = entry.response().hasCacheValidatorFields(); 200 LOG(NetworkCache, "(NetworkProcess) needsRevalidation hasValidatorFields=%d", hasValidatorFields); 201 if (!hasValidatorFields) 197 if (!entry.response().hasCacheValidatorFields()) 202 198 return UseDecision::NoDueToMissingValidatorFields; 203 199 … … 205 201 } 206 202 207 static RetrieveDecision canRetrieve(const WebCore::ResourceRequest& request)203 static RetrieveDecision makeRetrieveDecision(const WebCore::ResourceRequest& request) 208 204 { 209 205 // FIXME: Support HEAD requests. … … 217 213 218 214 return RetrieveDecision::Yes; 219 }220 221 void Cache::retrieve(const WebCore::ResourceRequest& originalRequest, uint64_t webPageID, std::function<void (std::unique_ptr<Entry>)> completionHandler)222 {223 ASSERT(isEnabled());224 ASSERT(originalRequest.url().protocolIsInHTTPFamily());225 226 LOG(NetworkCache, "(NetworkProcess) retrieving %s priority %u", originalRequest.url().string().ascii().data(), originalRequest.priority());227 228 if (m_statistics)229 m_statistics->recordRetrievalRequest(webPageID);230 231 Key storageKey = makeCacheKey(originalRequest);232 RetrieveDecision retrieveDecision = canRetrieve(originalRequest);233 if (retrieveDecision != RetrieveDecision::Yes) {234 if (m_statistics)235 m_statistics->recordNotUsingCacheForRequest(webPageID, storageKey, originalRequest, retrieveDecision);236 237 completionHandler(nullptr);238 return;239 }240 241 auto startTime = std::chrono::system_clock::now();242 unsigned priority = originalRequest.priority();243 244 m_storage->retrieve(storageKey, priority, [this, originalRequest, completionHandler, startTime, storageKey, webPageID](std::unique_ptr<Storage::Record> record) {245 if (!record) {246 LOG(NetworkCache, "(NetworkProcess) not found in storage");247 248 if (m_statistics)249 m_statistics->recordRetrievalFailure(webPageID, storageKey, originalRequest);250 251 completionHandler(nullptr);252 return false;253 }254 255 ASSERT(record->key == storageKey);256 257 auto entry = Entry::decodeStorageRecord(*record);258 259 auto useDecision = entry ? canUse(*entry, originalRequest) : UseDecision::NoDueToDecodeFailure;260 switch (useDecision) {261 case UseDecision::Use:262 break;263 case UseDecision::Validate:264 entry->setNeedsValidation();265 break;266 default:267 entry = nullptr;268 };269 270 #if !LOG_DISABLED271 auto elapsedMS = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now() - startTime).count();272 LOG(NetworkCache, "(NetworkProcess) retrieve complete useDecision=%d priority=%u time=%lldms", useDecision, originalRequest.priority(), elapsedMS);273 #endif274 completionHandler(WTF::move(entry));275 276 if (m_statistics)277 m_statistics->recordRetrievedCachedEntry(webPageID, storageKey, originalRequest, useDecision);278 return useDecision != UseDecision::NoDueToDecodeFailure;279 });280 215 } 281 216 … … 318 253 } 319 254 320 static StoreDecision canStore(const WebCore::ResourceRequest& originalRequest, const WebCore::ResourceResponse& response)255 static StoreDecision makeStoreDecision(const WebCore::ResourceRequest& originalRequest, const WebCore::ResourceResponse& response) 321 256 { 322 257 if (!originalRequest.url().protocolIsInHTTPFamily() || !response.isHTTP()) … … 333 268 return StoreDecision::NoDueToNoStoreResponse; 334 269 335 if (isStatusCodeCacheableByDefault(response.httpStatusCode())) 336 return StoreDecision::Yes; 337 338 if (isStatusCodePotentiallyCacheable(response.httpStatusCode())) { 339 // Check for expiration headers allowing us to cache. 270 if (!isStatusCodeCacheableByDefault(response.httpStatusCode())) { 340 271 // http://tools.ietf.org/html/rfc7234#section-4.3.2 341 if (std::isfinite(response.expires()) || std::isfinite(response.cacheControlMaxAge())) 342 return StoreDecision::Yes; 343 } 344 345 LOG(NetworkCache, "(NetworkProcess) status code %d not cacheable by default and no explicit expiration headers", response.httpStatusCode()); 346 347 return StoreDecision::NoDueToHTTPStatusCode; 272 bool hasExpirationHeaders = std::isfinite(response.expires()) || std::isfinite(response.cacheControlMaxAge()); 273 bool expirationHeadersAllowCaching = isStatusCodePotentiallyCacheable(response.httpStatusCode()) && hasExpirationHeaders; 274 if (!expirationHeadersAllowCaching) 275 return StoreDecision::NoDueToHTTPStatusCode; 276 } 277 278 // Main resource has ResourceLoadPriorityVeryHigh. 279 bool storeUnconditionallyForHistoryNavigation = originalRequest.priority() == WebCore::ResourceLoadPriorityVeryHigh; 280 if (!storeUnconditionallyForHistoryNavigation) { 281 auto currentTime = std::chrono::duration<double>(std::chrono::system_clock::now().time_since_epoch()); 282 bool hasNonZeroLifetime = WebCore::computeFreshnessLifetimeForHTTPFamily(response, currentTime.count()) > 0; 283 284 bool possiblyReusable = response.hasCacheValidatorFields() || hasNonZeroLifetime; 285 if (!possiblyReusable) 286 return StoreDecision::NoDueToUnlikelyToReuse; 287 } 288 289 return StoreDecision::Yes; 290 } 291 292 void Cache::retrieve(const WebCore::ResourceRequest& originalRequest, uint64_t webPageID, std::function<void (std::unique_ptr<Entry>)> completionHandler) 293 { 294 ASSERT(isEnabled()); 295 ASSERT(originalRequest.url().protocolIsInHTTPFamily()); 296 297 LOG(NetworkCache, "(NetworkProcess) retrieving %s priority %u", originalRequest.url().string().ascii().data(), originalRequest.priority()); 298 299 if (m_statistics) 300 m_statistics->recordRetrievalRequest(webPageID); 301 302 Key storageKey = makeCacheKey(originalRequest); 303 auto retrieveDecision = makeRetrieveDecision(originalRequest); 304 if (retrieveDecision != RetrieveDecision::Yes) { 305 if (m_statistics) 306 m_statistics->recordNotUsingCacheForRequest(webPageID, storageKey, originalRequest, retrieveDecision); 307 308 completionHandler(nullptr); 309 return; 310 } 311 312 auto startTime = std::chrono::system_clock::now(); 313 unsigned priority = originalRequest.priority(); 314 315 m_storage->retrieve(storageKey, priority, [this, originalRequest, completionHandler, startTime, storageKey, webPageID](std::unique_ptr<Storage::Record> record) { 316 if (!record) { 317 LOG(NetworkCache, "(NetworkProcess) not found in storage"); 318 319 if (m_statistics) 320 m_statistics->recordRetrievalFailure(webPageID, storageKey, originalRequest); 321 322 completionHandler(nullptr); 323 return false; 324 } 325 326 ASSERT(record->key == storageKey); 327 328 auto entry = Entry::decodeStorageRecord(*record); 329 330 auto useDecision = entry ? makeUseDecision(*entry, originalRequest) : UseDecision::NoDueToDecodeFailure; 331 switch (useDecision) { 332 case UseDecision::Use: 333 break; 334 case UseDecision::Validate: 335 entry->setNeedsValidation(); 336 break; 337 default: 338 entry = nullptr; 339 }; 340 341 #if !LOG_DISABLED 342 auto elapsedMS = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now() - startTime).count(); 343 LOG(NetworkCache, "(NetworkProcess) retrieve complete useDecision=%d priority=%u time=%lldms", useDecision, originalRequest.priority(), elapsedMS); 344 #endif 345 completionHandler(WTF::move(entry)); 346 347 if (m_statistics) 348 m_statistics->recordRetrievedCachedEntry(webPageID, storageKey, originalRequest, useDecision); 349 return useDecision != UseDecision::NoDueToDecodeFailure; 350 }); 348 351 } 349 352 … … 355 358 LOG(NetworkCache, "(NetworkProcess) storing %s, partition %s", originalRequest.url().string().latin1().data(), originalRequest.cachePartition().latin1().data()); 356 359 357 StoreDecision storeDecision = canStore(originalRequest, response); 360 StoreDecision storeDecision = makeStoreDecision(originalRequest, response); 361 358 362 if (storeDecision != StoreDecision::Yes) { 359 363 LOG(NetworkCache, "(NetworkProcess) didn't store, storeDecision=%d", storeDecision); -
trunk/Source/WebKit2/NetworkProcess/cache/NetworkCache.h
r182059 r182152 63 63 }; 64 64 65 // FIXME: This enum is used in the Statistics code in a way that prevents removing or reordering anything. 65 66 enum class StoreDecision { 66 67 Yes, 67 68 NoDueToProtocol, 68 69 NoDueToHTTPMethod, 69 NoDueToAttachmentResponse, 70 NoDueToAttachmentResponse, // Unused. 70 71 NoDueToNoStoreResponse, 71 72 NoDueToHTTPStatusCode, 72 NoDueToNoStoreRequest 73 NoDueToNoStoreRequest, 74 NoDueToUnlikelyToReuse 73 75 }; 74 76 -
trunk/Source/WebKit2/NetworkProcess/cache/NetworkCacheStatistics.cpp
r182090 r182152 239 239 case StoreDecision::NoDueToHTTPStatusCode: 240 240 return WebCore::DiagnosticLoggingKeys::uncacheableStatusCodeKey(); 241 case StoreDecision::NoDueToUnlikelyToReuse: 242 return WebCore::DiagnosticLoggingKeys::unlikelyToReuseKey(); 241 243 case StoreDecision::Yes: 242 244 // It was stored but could not be retrieved so it must have been pruned from the cache.
Note:
See TracChangeset
for help on using the changeset viewer.