Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4087)

Unified Diff: chrome/browser/policy/cloud/component_cloud_policy_updater_unittest.cc

Issue 13792003: Switch ComponentCloudPolicyUpdater to ExternalPolicyDataUpdater backend (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fixed copy&paste mistake that tripped up clang. Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/policy/cloud/component_cloud_policy_updater.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/policy/cloud/component_cloud_policy_updater_unittest.cc
diff --git a/chrome/browser/policy/cloud/component_cloud_policy_updater_unittest.cc b/chrome/browser/policy/cloud/component_cloud_policy_updater_unittest.cc
index 5154e9cb389e35f1941e4b3d007fa43a0a6ae0b5..e50f66965d812bc953b2075346d85e563bc30896 100644
--- a/chrome/browser/policy/cloud/component_cloud_policy_updater_unittest.cc
+++ b/chrome/browser/policy/cloud/component_cloud_policy_updater_unittest.cc
@@ -6,21 +6,22 @@
#include <string>
-#include "base/basictypes.h"
+#include "base/compiler_specific.h"
#include "base/files/scoped_temp_dir.h"
-#include "base/memory/ref_counted.h"
-#include "base/memory/scoped_ptr.h"
+#include "base/sequenced_task_runner.h"
#include "base/sha1.h"
-#include "base/test/test_pending_task.h"
#include "base/test/test_simple_task_runner.h"
-#include "base/time.h"
+#include "base/values.h"
#include "chrome/browser/policy/cloud/cloud_policy_constants.h"
#include "chrome/browser/policy/cloud/component_cloud_policy_store.h"
#include "chrome/browser/policy/cloud/policy_builder.h"
#include "chrome/browser/policy/cloud/proto/chrome_extension_policy.pb.h"
#include "chrome/browser/policy/cloud/proto/device_management_backend.pb.h"
#include "chrome/browser/policy/cloud/resource_cache.h"
-#include "net/base/net_errors.h"
+#include "chrome/browser/policy/policy_bundle.h"
+#include "chrome/browser/policy/policy_map.h"
+#include "chrome/browser/policy/policy_types.h"
+#include "googleurl/src/gurl.h"
#include "net/url_request/test_url_fetcher_factory.h"
#include "net/url_request/url_fetcher_delegate.h"
#include "net/url_request/url_request_context_getter.h"
@@ -37,6 +38,7 @@ namespace {
const char kTestExtension[] = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
const char kTestExtension2[] = "bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb";
+const char kTestExtension3[] = "cccccccccccccccccccccccccccccccc";
const char kTestDownload[] = "http://example.com/getpolicy?id=123";
const char kTestDownload2[] = "http://example.com/getpolicy?id=456";
const char kTestDownload3[] = "http://example.com/getpolicy?id=789";
@@ -63,58 +65,9 @@ class MockComponentCloudPolicyStoreDelegate
class ComponentCloudPolicyUpdaterTest : public testing::Test {
protected:
- virtual void SetUp() OVERRIDE {
- ASSERT_TRUE(temp_dir_.CreateUniqueTempDir());
- cache_.reset(new ResourceCache(temp_dir_.path()));
- store_.reset(new ComponentCloudPolicyStore(&store_delegate_, cache_.get()));
- store_->SetCredentials(ComponentPolicyBuilder::kFakeUsername,
- ComponentPolicyBuilder::kFakeToken);
- fetcher_factory_.set_remove_fetcher_on_delete(true);
- scoped_refptr<net::URLRequestContextGetter> request_context;
- task_runner_ = new base::TestSimpleTaskRunner();
- updater_.reset(new ComponentCloudPolicyUpdater(
- task_runner_, request_context, store_.get()));
- ASSERT_FALSE(GetCurrentFetcher());
- ASSERT_TRUE(store_->policy().begin() == store_->policy().end());
-
- builder_.policy_data().set_policy_type(
- dm_protocol::kChromeExtensionPolicyType);
- builder_.policy_data().set_settings_entity_id(kTestExtension);
- builder_.payload().set_download_url(kTestDownload);
- builder_.payload().set_secure_hash(base::SHA1HashString(kTestPolicy));
-
- PolicyNamespace ns(POLICY_DOMAIN_EXTENSIONS, kTestExtension);
- PolicyMap& policy = expected_bundle_.Get(ns);
- policy.Set("Name", POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
- base::Value::CreateStringValue("disabled"));
- policy.Set("Second", POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER,
- base::Value::CreateStringValue("maybe"));
- }
-
- net::TestURLFetcher* GetCurrentFetcher() {
- return fetcher_factory_.GetFetcherByID(0);
- }
-
- // Many tests also verify that a second fetcher is scheduled once the first
- // completes, either successfully or with a failure. This helper starts two
- // fetches immediately, so that the second is queued.
- void StartTwoFetches() {
- updater_->UpdateExternalPolicy(CreateResponse());
-
- builder_.payload().set_download_url(kTestDownload2);
- builder_.policy_data().set_settings_entity_id(kTestExtension2);
- updater_->UpdateExternalPolicy(CreateResponse());
- }
-
- scoped_ptr<em::PolicyFetchResponse> CreateResponse() {
- builder_.Build();
- return make_scoped_ptr(new em::PolicyFetchResponse(builder_.policy()));
- }
-
- std::string CreateSerializedResponse() {
- builder_.Build();
- return builder_.GetBlob();
- }
+ virtual void SetUp() OVERRIDE;
+
+ scoped_ptr<em::PolicyFetchResponse> CreateResponse();
base::ScopedTempDir temp_dir_;
scoped_ptr<ResourceCache> cache_;
@@ -127,321 +80,230 @@ class ComponentCloudPolicyUpdaterTest : public testing::Test {
PolicyBundle expected_bundle_;
};
+void ComponentCloudPolicyUpdaterTest::SetUp() {
+ ASSERT_TRUE(temp_dir_.CreateUniqueTempDir());
+ cache_.reset(new ResourceCache(temp_dir_.path()));
+ store_.reset(new ComponentCloudPolicyStore(&store_delegate_, cache_.get()));
+ store_->SetCredentials(ComponentPolicyBuilder::kFakeUsername,
+ ComponentPolicyBuilder::kFakeToken);
+ fetcher_factory_.set_remove_fetcher_on_delete(true);
+ task_runner_ = new base::TestSimpleTaskRunner();
+ updater_.reset(new ComponentCloudPolicyUpdater(
+ task_runner_,
+ scoped_refptr<net::URLRequestContextGetter>(),
+ store_.get()));
+ ASSERT_EQ(store_->policy().end(), store_->policy().begin());
+
+ builder_.policy_data().set_policy_type(
+ dm_protocol::kChromeExtensionPolicyType);
+ builder_.policy_data().set_settings_entity_id(kTestExtension);
+ builder_.payload().set_download_url(kTestDownload);
+ builder_.payload().set_secure_hash(base::SHA1HashString(kTestPolicy));
+
+ PolicyNamespace ns(POLICY_DOMAIN_EXTENSIONS, kTestExtension);
+ PolicyMap& policy = expected_bundle_.Get(ns);
+ policy.Set("Name", POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
+ base::Value::CreateStringValue("disabled"));
+ policy.Set("Second", POLICY_LEVEL_RECOMMENDED, POLICY_SCOPE_USER,
+ base::Value::CreateStringValue("maybe"));
+}
+
+scoped_ptr<em::PolicyFetchResponse>
+ ComponentCloudPolicyUpdaterTest::CreateResponse() {
+ builder_.Build();
+ return make_scoped_ptr(new em::PolicyFetchResponse(builder_.policy()));
+}
+
TEST_F(ComponentCloudPolicyUpdaterTest, FetchAndCache) {
- StartTwoFetches();
+ // Submit a policy fetch response.
+ updater_->UpdateExternalPolicy(CreateResponse());
- // The first fetch was scheduled; complete it.
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that a download has been started.
+ net::TestURLFetcher* fetcher = fetcher_factory_.GetFetcherByID(0);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
+
+ // Complete the download.
fetcher->set_response_code(200);
fetcher->SetResponseString(kTestPolicy);
EXPECT_CALL(store_delegate_, OnComponentCloudPolicyStoreUpdated());
fetcher->delegate()->OnURLFetchComplete(fetcher);
Mock::VerifyAndClearExpectations(&store_delegate_);
- // The second fetch was scheduled.
- fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
+ // Verify that the download is no longer running.
+ ASSERT_FALSE(fetcher_factory_.GetFetcherByID(0));
- // The policy is being served.
+ // Verify that the downloaded policy is being served.
EXPECT_TRUE(store_->policy().Equals(expected_bundle_));
-
- // No retries have been scheduled.
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
}
-TEST_F(ComponentCloudPolicyUpdaterTest, LargeResponse) {
+TEST_F(ComponentCloudPolicyUpdaterTest, PolicyFetchResponseTooLarge) {
+ // Submit a policy fetch response that exceeds the allowed maximum size.
std::string long_download("http://example.com/get?id=");
long_download.append(20 * 1024, '1');
builder_.payload().set_download_url(long_download);
updater_->UpdateExternalPolicy(CreateResponse());
+ // Submit two valid policy fetch responses.
builder_.policy_data().set_settings_entity_id(kTestExtension2);
builder_.payload().set_download_url(kTestDownload2);
updater_->UpdateExternalPolicy(CreateResponse());
+ builder_.policy_data().set_settings_entity_id(kTestExtension3);
+ builder_.payload().set_download_url(kTestDownload3);
+ updater_->UpdateExternalPolicy(CreateResponse());
- // The first request was dropped, and the second was started.
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that the first policy fetch response has been ignored and downloads
+ // have been started for the next two fetch responses instead.
+ net::TestURLFetcher* fetcher = fetcher_factory_.GetFetcherByID(0);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // No retry is scheduled for the first request, because the policy was
- // rejected (too large).
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
+ fetcher = fetcher_factory_.GetFetcherByID(1);
+ ASSERT_TRUE(fetcher);
+ EXPECT_EQ(GURL(kTestDownload3), fetcher->GetOriginalURL());
}
-TEST_F(ComponentCloudPolicyUpdaterTest, InvalidPolicy) {
+TEST_F(ComponentCloudPolicyUpdaterTest, PolicyFetchResponseInvalid) {
+ // Submit an invalid policy fetch response.
builder_.policy_data().set_username("wronguser@example.com");
updater_->UpdateExternalPolicy(CreateResponse());
+ // Submit two valid policy fetch responses.
builder_.policy_data().set_username(ComponentPolicyBuilder::kFakeUsername);
builder_.policy_data().set_settings_entity_id(kTestExtension2);
builder_.payload().set_download_url(kTestDownload2);
updater_->UpdateExternalPolicy(CreateResponse());
+ builder_.policy_data().set_settings_entity_id(kTestExtension3);
+ builder_.payload().set_download_url(kTestDownload3);
+ updater_->UpdateExternalPolicy(CreateResponse());
- // The first request was dropped, and the second was started.
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that the first policy fetch response has been ignored and downloads
+ // have been started for the next two fetch responses instead.
+ net::TestURLFetcher* fetcher = fetcher_factory_.GetFetcherByID(0);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // No retry is scheduled for the first request, because the policy was
- // rejected (invalid).
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
+ fetcher = fetcher_factory_.GetFetcherByID(1);
+ ASSERT_TRUE(fetcher);
+ EXPECT_EQ(GURL(kTestDownload3), fetcher->GetOriginalURL());
}
TEST_F(ComponentCloudPolicyUpdaterTest, AlreadyCached) {
+ // Cache policy for an extension.
+ builder_.Build();
PolicyNamespace ns(POLICY_DOMAIN_EXTENSIONS, kTestExtension);
EXPECT_CALL(store_delegate_, OnComponentCloudPolicyStoreUpdated());
EXPECT_TRUE(store_->Store(ns,
- CreateSerializedResponse(),
+ builder_.GetBlob(),
base::SHA1HashString(kTestPolicy),
kTestPolicy));
Mock::VerifyAndClearExpectations(&store_delegate_);
- // Seeing the same policy data again won't trigger a new fetch.
+ // Submit a policy fetch response whose extension ID and hash match the
+ // already cached policy.
updater_->UpdateExternalPolicy(CreateResponse());
- EXPECT_FALSE(GetCurrentFetcher());
- // And no retry is scheduled either.
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
+ // Verify that no download has been started.
+ EXPECT_FALSE(fetcher_factory_.GetFetcherByID(0));
}
-TEST_F(ComponentCloudPolicyUpdaterTest, LargeFetch) {
- StartTwoFetches();
-
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
- fetcher->delegate()->OnURLFetchDownloadProgress(fetcher, 6 * 1024 * 1024, -1);
-
- // The second fetch was scheduled next.
- fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // A retry is scheduled for the first fetcher.
- EXPECT_EQ(1u, task_runner_->GetPendingTasks().size());
-}
-
-TEST_F(ComponentCloudPolicyUpdaterTest, FetchFailed) {
- StartTwoFetches();
+TEST_F(ComponentCloudPolicyUpdaterTest, PolicyDataInvalid) {
+ // Submit two policy fetch responses.
+ updater_->UpdateExternalPolicy(CreateResponse());
+ builder_.payload().set_download_url(kTestDownload2);
+ builder_.policy_data().set_settings_entity_id(kTestExtension2);
+ updater_->UpdateExternalPolicy(CreateResponse());
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that the first download has been started.
+ net::TestURLFetcher* fetcher = fetcher_factory_.GetFetcherByID(0);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
- fetcher->set_status(net::URLRequestStatus(net::URLRequestStatus::FAILED,
- net::ERR_NETWORK_CHANGED));
- fetcher->delegate()->OnURLFetchComplete(fetcher);
-
- // The second fetch was scheduled next.
- fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // A retry is scheduled for the first fetcher.
- EXPECT_EQ(1u, task_runner_->GetPendingTasks().size());
-}
-TEST_F(ComponentCloudPolicyUpdaterTest, ServerFailed) {
- StartTwoFetches();
+ // Indicate that the policy data size will exceed allowed maximum.
+ fetcher->delegate()->OnURLFetchDownloadProgress(fetcher, 6 * 1024 * 1024, -1);
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
- fetcher->set_response_code(500);
- fetcher->delegate()->OnURLFetchComplete(fetcher);
+ // Verify that the first download is no longer running.
+ ASSERT_FALSE(fetcher_factory_.GetFetcherByID(0));
- // The second fetch was scheduled next.
- fetcher = GetCurrentFetcher();
+ // Verify that the second download has been started.
+ fetcher = fetcher_factory_.GetFetcherByID(1);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // A retry is scheduled for the first fetcher.
- EXPECT_EQ(1u, task_runner_->GetPendingTasks().size());
}
-TEST_F(ComponentCloudPolicyUpdaterTest, RetryLimit) {
+TEST_F(ComponentCloudPolicyUpdaterTest, FetchUpdatedData) {
+ // Submit a policy fetch response.
updater_->UpdateExternalPolicy(CreateResponse());
- // Failing due to client errors retries up to 3 times.
- for (int i = 0; i < 3; ++i) {
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
-
- // Make it fail with a 400 (bad request) client error.
- fetcher->set_response_code(400);
- fetcher->delegate()->OnURLFetchComplete(fetcher);
-
- // A retry is scheduled.
- EXPECT_EQ(1u, task_runner_->GetPendingTasks().size());
- // Make it retry immediately.
- task_runner_->RunPendingTasks();
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
- }
-
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that the first download has been started.
+ net::TestURLFetcher* fetcher = fetcher_factory_.GetFetcherByID(0);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
- // Make the last retry fail too; it won't retry anymore.
- fetcher->set_response_code(400);
- fetcher->delegate()->OnURLFetchComplete(fetcher);
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
-}
-
-TEST_F(ComponentCloudPolicyUpdaterTest, RetryWithBackoff) {
- updater_->UpdateExternalPolicy(CreateResponse());
-
- base::TimeDelta expected_delay = base::TimeDelta::FromSeconds(60);
- const base::TimeDelta delay_cap = base::TimeDelta::FromHours(12);
-
- // The backoff delay is capped at 12 hours, which is reached after 10 retries:
- // 60 * 2^10 == 61440 > 43200 == 12 * 60 * 60
- for (int i = 0; i < 20; ++i) {
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
-
- // Make it fail with a 500 server error.
- fetcher->set_response_code(500);
- fetcher->delegate()->OnURLFetchComplete(fetcher);
-
- // A retry is scheduled. The delay is twice the last delay, with random
- // jitter from 80% to 100%.
- ASSERT_EQ(1u, task_runner_->GetPendingTasks().size());
- const base::TestPendingTask& task = task_runner_->GetPendingTasks().front();
- EXPECT_GT(task.delay,
- base::TimeDelta::FromMilliseconds(
- 0.799 * expected_delay.InMilliseconds()));
- EXPECT_LE(task.delay, expected_delay);
-
- if (i < 10) {
- // The delay cap hasn't been reached yet.
- EXPECT_LT(expected_delay, delay_cap);
- expected_delay *= 2;
-
- if (i == 9) {
- // The last doubling reached the cap.
- EXPECT_GT(expected_delay, delay_cap);
- expected_delay = delay_cap;
- }
- }
-
- // Make it retry immediately.
- task_runner_->RunPendingTasks();
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
- }
-}
-
-TEST_F(ComponentCloudPolicyUpdaterTest, DataValidationFails) {
- StartTwoFetches();
-
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
- fetcher->set_response_code(200);
- fetcher->SetResponseString("{ won't hash }");
- fetcher->delegate()->OnURLFetchComplete(fetcher);
-
- // The second fetch was scheduled next.
- fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // A retry is scheduled for the first fetcher.
- EXPECT_EQ(1u, task_runner_->GetPendingTasks().size());
-}
-
-TEST_F(ComponentCloudPolicyUpdaterTest, FetchUpdatedData) {
- updater_->UpdateExternalPolicy(CreateResponse());
-
- // Same extension, but the download location has changed.
+ // Submit a second policy fetch response for the same extension with an
+ // updated download URL.
builder_.payload().set_download_url(kTestDownload2);
updater_->UpdateExternalPolicy(CreateResponse());
- // The first was cancelled and overridden by the second.
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that the first download is no longer running.
+ ASSERT_FALSE(fetcher_factory_.GetFetcherByID(0));
+
+ // Verify that the second download has been started.
+ fetcher = fetcher_factory_.GetFetcherByID(1);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload2), fetcher->GetOriginalURL());
-
- // No retries are scheduled.
- EXPECT_TRUE(task_runner_->GetPendingTasks().empty());
}
TEST_F(ComponentCloudPolicyUpdaterTest, FetchUpdatedDataWithoutPolicy) {
- // Fetch the initial policy data.
+ // Submit a policy fetch response.
updater_->UpdateExternalPolicy(CreateResponse());
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
+ // Verify that the download has been started.
+ net::TestURLFetcher* fetcher = fetcher_factory_.GetFetcherByID(0);
ASSERT_TRUE(fetcher);
EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
+
+ // Complete the download.
fetcher->set_response_code(200);
fetcher->SetResponseString(kTestPolicy);
EXPECT_CALL(store_delegate_, OnComponentCloudPolicyStoreUpdated());
fetcher->delegate()->OnURLFetchComplete(fetcher);
Mock::VerifyAndClearExpectations(&store_delegate_);
- EXPECT_FALSE(GetCurrentFetcher());
- // The policy is being served.
+ // Verify that the download is no longer running.
+ EXPECT_FALSE(fetcher_factory_.GetFetcherByID(0));
+
+ // Verify that the downloaded policy is being served.
EXPECT_TRUE(store_->policy().Equals(expected_bundle_));
- // Same extension, but the download location has changed and is empty, meaning
- // that no policy should be served anymore.
- EXPECT_CALL(store_delegate_, OnComponentCloudPolicyStoreUpdated());
+ // Submit a second policy fetch response for the same extension with no
+ // download URL, meaning that no policy should be provided for this extension.
builder_.payload().clear_download_url();
builder_.payload().clear_secure_hash();
+ EXPECT_CALL(store_delegate_, OnComponentCloudPolicyStoreUpdated());
updater_->UpdateExternalPolicy(CreateResponse());
Mock::VerifyAndClearExpectations(&store_delegate_);
- // No fetcher was started for that.
- EXPECT_FALSE(GetCurrentFetcher());
+ // Verify that no download has been started.
+ EXPECT_FALSE(fetcher_factory_.GetFetcherByID(1));
- // And the policy has been removed.
+ // Verify that the policy is no longer being served.
const PolicyBundle empty_bundle;
EXPECT_TRUE(store_->policy().Equals(empty_bundle));
}
-TEST_F(ComponentCloudPolicyUpdaterTest, InvalidatedJob) {
- StartTwoFetches();
-
- // Start a new fetch for the second extension with a new download URL; the
- // queued job is invalidated.
- builder_.payload().set_download_url(kTestDownload3);
- updater_->UpdateExternalPolicy(CreateResponse());
-
- // The first request is still pending.
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload), fetcher->GetOriginalURL());
-
- // Make it fail.
- fetcher->set_response_code(500);
- fetcher->delegate()->OnURLFetchComplete(fetcher);
-
- // Now the second job was invalidated, and the third job (for the same
- // extension) is the next one.
- fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- EXPECT_EQ(GURL(kTestDownload3), fetcher->GetOriginalURL());
-}
-
TEST_F(ComponentCloudPolicyUpdaterTest, NoPolicy) {
- // Start a fetch with a valid download url.
+ // Submit a policy fetch response with a valid download URL.
updater_->UpdateExternalPolicy(CreateResponse());
- net::TestURLFetcher* fetcher = GetCurrentFetcher();
- ASSERT_TRUE(fetcher);
- // Now update the policy fetch response before the fetch completes. The new
- // data does not have a download url.
+ // Verify that the download has been started.
+ ASSERT_TRUE(fetcher_factory_.GetFetcherByID(0));
+
+ // Update the policy fetch response before the download has finished. The new
+ // policy fetch response has no download URL.
builder_.payload().Clear();
updater_->UpdateExternalPolicy(CreateResponse());
- // The download has been cancelled.
- fetcher = GetCurrentFetcher();
- ASSERT_FALSE(fetcher);
+ // Verify that the download is no longer running.
+ ASSERT_FALSE(fetcher_factory_.GetFetcherByID(0));
}
} // namespace policy
« no previous file with comments | « chrome/browser/policy/cloud/component_cloud_policy_updater.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698