Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "net/http/http_cache.h" | 5 #include "net/http/http_cache.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 6425 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 6436 base::MessageLoop::current()->RunUntilIdle(); | 6436 base::MessageLoop::current()->RunUntilIdle(); |
| 6437 | 6437 |
| 6438 // Read bytes 20-29 and 50-59 from the network, bytes 30-49 from the cache. | 6438 // Read bytes 20-29 and 50-59 from the network, bytes 30-49 from the cache. |
| 6439 transaction.request_headers = "Range: bytes = 20-59\r\n" EXTRA_HEADER; | 6439 transaction.request_headers = "Range: bytes = 20-59\r\n" EXTRA_HEADER; |
| 6440 transaction.data = "rg: 20-29 rg: 30-39 rg: 40-49 rg: 50-59 "; | 6440 transaction.data = "rg: 20-29 rg: 30-39 rg: 40-49 rg: 50-59 "; |
| 6441 received_bytes = RunTransactionAndGetReceivedBytes(cache, transaction); | 6441 received_bytes = RunTransactionAndGetReceivedBytes(cache, transaction); |
| 6442 EXPECT_EQ(range_response_size * 2, received_bytes); | 6442 EXPECT_EQ(range_response_size * 2, received_bytes); |
| 6443 | 6443 |
| 6444 RemoveMockTransaction(&kRangeGET_TransactionOK); | 6444 RemoveMockTransaction(&kRangeGET_TransactionOK); |
| 6445 } | 6445 } |
| 6446 | |
| 6447 static void CheckChromeFreshnessHeader(const net::HttpRequestInfo* request, | |
| 6448 std::string* response_status, | |
| 6449 std::string* response_headers, | |
| 6450 std::string* response_data) { | |
| 6451 std::string value; | |
| 6452 EXPECT_TRUE(request->extra_headers.GetHeader("Chrome-Freshness", &value)); | |
| 6453 // 228658821 seconds is around 7.25 years. | |
| 6454 // TODO(ricea): Find out why we get this number, and why it is always the | |
| 6455 // same. | |
|
tyoshino (SeeGerritForStatus)
2014/07/23 00:08:56
Hmm... FYI, 18 Apr 2007 01:10:43 + 228658821sec =
| |
| 6456 EXPECT_EQ("max-age=3600,stale-while-revalidate=7200,age=228658821", value); | |
| 6457 } | |
| 6458 | |
| 6459 // Verify that the Chrome-Freshness header is sent on a revalidation if the | |
| 6460 // stale-while-revalidate directive was on the response. | |
| 6461 // TODO(ricea): Rename this test when a final name for the header is decided. | |
| 6462 TEST(HttpCache, ChromeFreshnessHeaderSent) { | |
| 6463 MockHttpCache cache; | |
| 6464 | |
| 6465 const MockTransaction kStaleWhileRevalidateTransaction = { | |
| 6466 "http://www.example.com/stale-while-revalidate", | |
| 6467 "GET", | |
| 6468 base::Time(), | |
| 6469 "", | |
| 6470 net::LOAD_NORMAL, | |
| 6471 "HTTP/1.1 200 OK", | |
| 6472 "Last-Modified: Sat, 18 Apr 2007 01:10:43 GMT\n" | |
| 6473 "Cache-Control: max-age=3600,stale-while-revalidate=7200\n", | |
| 6474 base::Time(), | |
| 6475 "<title>Testing stale-while-revalidate</title>", | |
| 6476 TEST_MODE_SYNC_NET_START, | |
| 6477 NULL, | |
| 6478 0, | |
| 6479 net::OK}; | |
| 6480 | |
| 6481 ScopedMockTransaction stale_while_revalidate_transaction( | |
| 6482 kStaleWhileRevalidateTransaction); | |
| 6483 | |
| 6484 // Write to the cache. | |
| 6485 RunTransactionTest(cache.http_cache(), stale_while_revalidate_transaction); | |
| 6486 | |
| 6487 // Send the request again and check that Chrome-Freshness header is added. | |
| 6488 stale_while_revalidate_transaction.handler = CheckChromeFreshnessHeader; | |
| 6489 | |
| 6490 RunTransactionTest(cache.http_cache(), stale_while_revalidate_transaction); | |
| 6491 } | |
| 6492 | |
| 6493 static void CheckChromeFreshnessAbsent(const net::HttpRequestInfo* request, | |
| 6494 std::string* response_status, | |
| 6495 std::string* response_headers, | |
| 6496 std::string* response_data) { | |
| 6497 EXPECT_FALSE(request->extra_headers.HasHeader("Chrome-Freshness")); | |
| 6498 } | |
| 6499 | |
| 6500 // Verify that the Chrome-Freshness header is not sent when cookies are | |
| 6501 // disabled. | |
| 6502 TEST(HttpCache, ChromeFreshnessHeaderNotSent) { | |
| 6503 MockHttpCache cache; | |
| 6504 | |
| 6505 const MockTransaction kStaleWhileRevalidateTransaction = { | |
| 6506 "http://www.example.com/stale-while-revalidate", | |
| 6507 "GET", | |
| 6508 base::Time(), | |
| 6509 "", | |
| 6510 net::LOAD_DO_NOT_SEND_COOKIES, | |
| 6511 "HTTP/1.1 200 OK", | |
| 6512 "Last-Modified: Sat, 18 Apr 2007 01:10:43 GMT\n" | |
| 6513 "Cache-Control: max-age=3600,stale-while-revalidate=7200\n", | |
| 6514 base::Time(), | |
| 6515 "<title>Testing stale-while-revalidate</title>", | |
| 6516 TEST_MODE_SYNC_NET_START, | |
| 6517 NULL, | |
| 6518 0, | |
| 6519 net::OK}; | |
| 6520 | |
| 6521 ScopedMockTransaction stale_while_revalidate_transaction( | |
| 6522 kStaleWhileRevalidateTransaction); | |
| 6523 | |
| 6524 // Write to the cache. | |
| 6525 RunTransactionTest(cache.http_cache(), stale_while_revalidate_transaction); | |
| 6526 | |
| 6527 // Send the request again and check that Chrome-Freshness header is absent. | |
| 6528 stale_while_revalidate_transaction.handler = CheckChromeFreshnessAbsent; | |
| 6529 | |
| 6530 RunTransactionTest(cache.http_cache(), stale_while_revalidate_transaction); | |
| 6531 } | |
| OLD | NEW |