Chromium Code Reviews| Index: net/url_request/url_request_http_job_unittest.cc |
| diff --git a/net/url_request/url_request_http_job_unittest.cc b/net/url_request/url_request_http_job_unittest.cc |
| index dbaea28f76e0115df4041995cea3b3a60e93bfeb..9c457935e084f35a1f87975503cdab23c73871b3 100644 |
| --- a/net/url_request/url_request_http_job_unittest.cc |
| +++ b/net/url_request/url_request_http_job_unittest.cc |
| @@ -15,6 +15,7 @@ |
| #include "base/memory/ref_counted.h" |
| #include "base/run_loop.h" |
| #include "base/strings/string_split.h" |
| +#include "base/test/histogram_tester.h" |
| #include "net/base/auth.h" |
| #include "net/base/request_priority.h" |
| #include "net/base/sdch_observer.h" |
| @@ -616,6 +617,56 @@ TEST_F(URLRequestHttpJobWithMockSocketsTest, |
| EXPECT_EQ(0, network_delegate_.total_network_bytes_received()); |
| } |
| +TEST_F(URLRequestHttpJobWithMockSocketsTest, TestHttpTimeToFirstByte) { |
| + base::HistogramTester histograms; |
| + MockWrite writes[] = {MockWrite(kSimpleGetMockWrite)}; |
| + MockRead reads[] = {MockRead("HTTP/1.1 200 OK\r\n" |
| + "Content-Length: 12\r\n\r\n"), |
| + MockRead("Test Content")}; |
| + |
| + StaticSocketDataProvider socket_data(reads, arraysize(reads), writes, |
| + arraysize(writes)); |
| + socket_factory_.AddSocketDataProvider(&socket_data); |
| + |
| + TestDelegate delegate; |
| + std::unique_ptr<URLRequest> request = context_->CreateRequest( |
| + GURL("http://www.example.com"), DEFAULT_PRIORITY, &delegate); |
| + histograms.ExpectTotalCount("Net.HttpTimeToFirstByte", 0); |
| + |
| + request->Start(); |
| + base::RunLoop().Run(); |
| + |
| + EXPECT_THAT(delegate.request_status(), IsOk()); |
| + EXPECT_EQ(CountReadBytes(reads, arraysize(reads)), |
|
asanka
2017/02/28 20:32:39
This check is unnecessary.
Amey J
2017/02/28 21:22:16
Acknowledged.
|
| + request->GetTotalReceivedBytes()); |
| + histograms.ExpectTotalCount("Net.HttpTimeToFirstByte", 1); |
| +} |
| + |
| +TEST_F(URLRequestHttpJobWithMockSocketsTest, |
| + TestHttpTimeToFirstByteForCancelledTask) { |
| + base::HistogramTester histograms; |
| + MockWrite writes[] = {MockWrite(kSimpleGetMockWrite)}; |
| + MockRead reads[] = {MockRead("HTTP/1.1 200 OK\r\n" |
| + "Content-Length: 12\r\n\r\n"), |
| + MockRead("Test Content")}; |
| + |
| + StaticSocketDataProvider socket_data(reads, arraysize(reads), writes, |
| + arraysize(writes)); |
| + socket_factory_.AddSocketDataProvider(&socket_data); |
| + |
| + TestDelegate delegate; |
| + std::unique_ptr<URLRequest> request = context_->CreateRequest( |
| + GURL("http://www.example.com"), DEFAULT_PRIORITY, &delegate); |
| + |
| + request->Start(); |
| + request->Cancel(); |
| + base::RunLoop().Run(); |
| + |
| + EXPECT_THAT(delegate.request_status(), IsError(ERR_ABORTED)); |
| + EXPECT_EQ(0, request->GetTotalReceivedBytes()); |
|
asanka
2017/02/28 20:32:39
This check is unnecessary.
Amey J
2017/02/28 21:22:16
Acknowledged.
|
| + histograms.ExpectTotalCount("Net.HttpTimeToFirstByte", 0); |
| +} |
| + |
| TEST_F(URLRequestHttpJobTest, TestCancelWhileReadingCookies) { |
| DelayedCookieMonster cookie_monster; |
| TestURLRequestContext context(true); |