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 |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..0d5223beefb0d27188106e0c691c0357da49642d |
| --- /dev/null |
| +++ b/net/url_request/url_request_http_job_unittest.cc |
| @@ -0,0 +1,78 @@ |
| +// Copyright (c) 2013 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 "net/url_request/url_request_http_job.h" |
| + |
| +#include "base/memory/ref_counted.h" |
| +#include "net/http/http_transaction_unittest.h" |
| +#include "net/url_request/url_request_test_util.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace net { |
| + |
| +class URLRequestHttpJobTest : public ::testing::Test { |
| + protected: |
| + URLRequestHttpJob* MakeHttpJob( |
| + URLRequest* request, |
| + NetworkDelegate* network_delegate, |
| + const std::string& scheme) const { |
| + return static_cast<URLRequestHttpJob*>( |
| + URLRequestHttpJob::Factory(request, network_delegate, scheme)); |
| + } |
| + |
| + bool HttpJobHasTransaction(const URLRequestHttpJob& job) const { |
| + return job.transaction_ != NULL; |
| + } |
| + |
| + RequestPriority GetJobPriority(const URLRequestHttpJob& job) const { |
| + return job.request_info_.priority; |
| + } |
| + |
| + RequestPriority GetJobTransactionPriority( |
| + const URLRequestHttpJob& job) const { |
| + const MockNetworkTransaction* transaction = |
| + static_cast<MockNetworkTransaction*>(job.transaction_.get()); |
|
mmenke
2013/03/13 15:24:38
I'd still really like to get rid of this friend re
akalin
2013/03/13 16:57:14
Done. Ended up inheriting from URLRequestHttpJob a
|
| + return transaction->priority(); |
| + } |
| + |
| + void StartJob(const scoped_refptr<URLRequestHttpJob>& job) const { |
| + job->Start(); |
| + } |
| + |
| + void SetJobPriority(const scoped_refptr<URLRequestHttpJob>& job, |
| + RequestPriority priority) const { |
| + job->SetPriority(priority); |
| + } |
| +}; |
| + |
| +// Make sure that URLRequestHttpJob passes on its priority updates to |
| +// its transaction. |
| +TEST_F(URLRequestHttpJobTest, Priority) { |
| + MockNetworkLayer network_layer; |
| + net::TestURLRequestContext context; |
| + context.set_http_transaction_factory(&network_layer); |
| + |
| + net::TestDelegate d; |
| + net::TestURLRequest req(GURL("http://www.example.com"), &d, &context, NULL); |
| + |
| + scoped_refptr<URLRequestHttpJob> job = MakeHttpJob(&req, NULL, "http"); |
| + EXPECT_FALSE(HttpJobHasTransaction(*job)); |
| + EXPECT_EQ(LOWEST, GetJobPriority(*job)); |
| + |
| + req.SetPriority(MEDIUM); |
| + // The priority doesn't propagate to the job until Start() is |
| + // called. |
|
mmenke
2013/03/13 15:24:38
nit: Think this fits on one line.
akalin
2013/03/13 16:57:14
Done.
|
| + EXPECT_EQ(LOWEST, GetJobPriority(*job)); |
| + |
| + StartJob(job); |
| + EXPECT_TRUE(HttpJobHasTransaction(*job)); |
| + EXPECT_EQ(MEDIUM, GetJobPriority(*job)); |
| + EXPECT_EQ(MEDIUM, GetJobTransactionPriority(*job)); |
| + |
| + SetJobPriority(job, HIGHEST); |
| + EXPECT_EQ(HIGHEST, GetJobPriority(*job)); |
| + EXPECT_EQ(HIGHEST, GetJobTransactionPriority(*job)); |
| +} |
| + |
| +} // namespace net |