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

Side by Side Diff: chrome/browser/policy/asynchronous_policy_loader_unittest.cc

Issue 10386097: Refactored ConfigurationPolicyProvider to provide PolicyBundles instead of PolicyMaps. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments Created 8 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 "base/bind.h" 5 #include "base/bind.h"
6 #include "base/callback.h" 6 #include "base/memory/scoped_ptr.h"
7 #include "base/values.h" 7 #include "base/values.h"
8 #include "chrome/browser/policy/asynchronous_policy_loader.h" 8 #include "chrome/browser/policy/asynchronous_policy_loader.h"
9 #include "chrome/browser/policy/asynchronous_policy_provider.h" 9 #include "chrome/browser/policy/asynchronous_policy_provider.h"
10 #include "chrome/browser/policy/asynchronous_policy_test_base.h" 10 #include "chrome/browser/policy/asynchronous_policy_test_base.h"
11 #include "chrome/browser/policy/mock_configuration_policy_provider.h" 11 #include "chrome/browser/policy/mock_configuration_policy_provider.h"
12 #include "chrome/browser/policy/policy_bundle.h"
12 #include "chrome/browser/policy/policy_map.h" 13 #include "chrome/browser/policy/policy_map.h"
13 #include "testing/gmock/include/gmock/gmock.h" 14 #include "testing/gmock/include/gmock/gmock.h"
14 15
15 using ::testing::InSequence; 16 using ::testing::InSequence;
16 using ::testing::Mock; 17 using ::testing::Mock;
17 using ::testing::Return; 18 using ::testing::Return;
18 using ::testing::_; 19 using ::testing::_;
19 20
20 namespace policy { 21 namespace policy {
21 22
22 namespace {
23
24 void IgnoreCallback() {
25 }
26
27 } // namespace
28
29 class AsynchronousPolicyLoaderTest : public AsynchronousPolicyTestBase { 23 class AsynchronousPolicyLoaderTest : public AsynchronousPolicyTestBase {
30 public: 24 public:
31 AsynchronousPolicyLoaderTest() {} 25 AsynchronousPolicyLoaderTest() {}
32 virtual ~AsynchronousPolicyLoaderTest() {} 26 virtual ~AsynchronousPolicyLoaderTest() {}
33 27
34 virtual void SetUp() { 28 virtual void SetUp() {
35 AsynchronousPolicyTestBase::SetUp(); 29 AsynchronousPolicyTestBase::SetUp();
36 ignore_callback_ = base::Bind(&IgnoreCallback); 30 update_callback_ = base::Bind(&AsynchronousPolicyLoaderTest::UpdateCallback,
31 base::Unretained(this));
37 } 32 }
38 33
39 protected: 34 protected:
40 base::Closure ignore_callback_; 35 AsynchronousPolicyLoader::UpdateCallback update_callback_;
36 scoped_ptr<PolicyBundle> bundle_;
41 37
42 private: 38 private:
39 void UpdateCallback(scoped_ptr<PolicyBundle> bundle) {
40 bundle_.swap(bundle);
41 }
42
43 DISALLOW_COPY_AND_ASSIGN(AsynchronousPolicyLoaderTest); 43 DISALLOW_COPY_AND_ASSIGN(AsynchronousPolicyLoaderTest);
44 }; 44 };
45 45
46 ACTION(CreateTestPolicyMap) { 46 ACTION(CreateTestPolicyMap) {
47 return new PolicyMap(); 47 return new PolicyMap();
48 } 48 }
49 49
50 ACTION_P(CreateSequencedTestPolicyMap, number) { 50 ACTION_P(CreateSequencedTestPolicyMap, number) {
51 PolicyMap* test_policy_map = new PolicyMap(); 51 PolicyMap* test_policy_map = new PolicyMap();
52 test_policy_map->Set("id", POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 52 test_policy_map->Set("id", POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
53 Value::CreateIntegerValue(++(*number))); 53 Value::CreateIntegerValue(++(*number)));
54 return test_policy_map; 54 return test_policy_map;
55 } 55 }
56 56
57 ACTION(RescheduleImmediatePolicyReload) {
58 *arg1 = base::TimeDelta();
59 return false;
60 }
61
62 TEST_F(AsynchronousPolicyLoaderTest, InitialLoad) { 57 TEST_F(AsynchronousPolicyLoaderTest, InitialLoad) {
63 PolicyMap template_policy; 58 PolicyMap template_policy;
64 template_policy.Set("test", POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER, 59 template_policy.Set("test", POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
65 Value::CreateIntegerValue(123)); 60 Value::CreateIntegerValue(123));
66 PolicyMap* result = new PolicyMap(); 61 PolicyMap* result = new PolicyMap();
67 result->CopyFrom(template_policy); 62 result->CopyFrom(template_policy);
68 ProviderDelegateMock* delegate = new ProviderDelegateMock(); 63 ProviderDelegateMock* delegate = new ProviderDelegateMock();
69 EXPECT_CALL(*delegate, Load()).WillOnce(Return(result)); 64 EXPECT_CALL(*delegate, Load()).WillOnce(Return(result));
70 scoped_refptr<AsynchronousPolicyLoader> loader = 65 scoped_refptr<AsynchronousPolicyLoader> loader =
71 new AsynchronousPolicyLoader(delegate, 10); 66 new AsynchronousPolicyLoader(delegate, 10);
72 loader->Init(ignore_callback_); 67 EXPECT_FALSE(bundle_.get());
73 const PolicyMap& loaded_policy(loader->policy()); 68 loader->Init(update_callback_);
74 EXPECT_TRUE(loaded_policy.Equals(template_policy)); 69 ASSERT_TRUE(bundle_.get());
70 const PolicyMap& chrome_policy =
71 bundle_->Get(POLICY_DOMAIN_CHROME, std::string());
72 EXPECT_TRUE(chrome_policy.Equals(template_policy));
75 } 73 }
76 74
77 // Verify that the fallback policy requests are made. 75 // Verify that the fallback policy requests are made.
78 TEST_F(AsynchronousPolicyLoaderTest, InitialLoadWithFallback) { 76 TEST_F(AsynchronousPolicyLoaderTest, InitialLoadWithFallback) {
79 int policy_number = 0; 77 int policy_number = 0;
80 InSequence s; 78 InSequence s;
81 ProviderDelegateMock* delegate = new ProviderDelegateMock(); 79 ProviderDelegateMock* delegate = new ProviderDelegateMock();
82 EXPECT_CALL(*delegate, Load()).WillOnce( 80 EXPECT_CALL(*delegate, Load()).WillOnce(
83 CreateSequencedTestPolicyMap(&policy_number)); 81 CreateSequencedTestPolicyMap(&policy_number));
84 EXPECT_CALL(*delegate, Load()).WillOnce( 82 EXPECT_CALL(*delegate, Load()).WillOnce(
85 CreateSequencedTestPolicyMap(&policy_number)); 83 CreateSequencedTestPolicyMap(&policy_number));
86 scoped_refptr<AsynchronousPolicyLoader> loader = 84 scoped_refptr<AsynchronousPolicyLoader> loader =
87 new AsynchronousPolicyLoader(delegate, 10); 85 new AsynchronousPolicyLoader(delegate, 10);
88 loader->Init(ignore_callback_); 86 loader->Init(update_callback_);
89 loop_.RunAllPending(); 87 loop_.RunAllPending();
90 loader->Reload(true); 88 loader->Reload(true);
91 loop_.RunAllPending(); 89 loop_.RunAllPending();
92 90
93 const PolicyMap& loaded_policy(loader->policy()); 91 const PolicyMap& chrome_policy =
92 bundle_->Get(POLICY_DOMAIN_CHROME, std::string());
94 base::FundamentalValue expected(policy_number); 93 base::FundamentalValue expected(policy_number);
95 EXPECT_TRUE(Value::Equals(&expected, loaded_policy.GetValue("id"))); 94 EXPECT_TRUE(Value::Equals(&expected, chrome_policy.GetValue("id")));
96 EXPECT_EQ(1U, loaded_policy.size()); 95 EXPECT_EQ(1U, chrome_policy.size());
97 } 96 }
98 97
99 // Ensure that calling stop on the loader stops subsequent reloads from 98 // Ensure that calling stop on the loader stops subsequent reloads from
100 // happening. 99 // happening.
101 TEST_F(AsynchronousPolicyLoaderTest, Stop) { 100 TEST_F(AsynchronousPolicyLoaderTest, Stop) {
102 ProviderDelegateMock* delegate = new ProviderDelegateMock(); 101 ProviderDelegateMock* delegate = new ProviderDelegateMock();
103 ON_CALL(*delegate, Load()).WillByDefault(CreateTestPolicyMap()); 102 ON_CALL(*delegate, Load()).WillByDefault(CreateTestPolicyMap());
104 EXPECT_CALL(*delegate, Load()).Times(1); 103 EXPECT_CALL(*delegate, Load()).Times(1);
105 scoped_refptr<AsynchronousPolicyLoader> loader = 104 scoped_refptr<AsynchronousPolicyLoader> loader =
106 new AsynchronousPolicyLoader(delegate, 10); 105 new AsynchronousPolicyLoader(delegate, 10);
107 loader->Init(ignore_callback_); 106 loader->Init(update_callback_);
108 loop_.RunAllPending(); 107 loop_.RunAllPending();
109 loader->Stop(); 108 loader->Stop();
110 loop_.RunAllPending(); 109 loop_.RunAllPending();
111 loader->Reload(true); 110 loader->Reload(true);
112 loop_.RunAllPending(); 111 loop_.RunAllPending();
113 } 112 }
114 113
115 // Verifies that the provider is notified upon policy reload. 114 // Verifies that the provider is notified upon policy reload.
116 TEST_F(AsynchronousPolicyLoaderTest, ProviderNotificationOnPolicyChange) { 115 TEST_F(AsynchronousPolicyLoaderTest, ProviderNotificationOnPolicyChange) {
117 InSequence s; 116 InSequence s;
(...skipping 24 matching lines...) Expand all
142 EXPECT_CALL(*delegate, Load()).WillOnce( 141 EXPECT_CALL(*delegate, Load()).WillOnce(
143 CreateSequencedTestPolicyMap(&policy_number_1)); 142 CreateSequencedTestPolicyMap(&policy_number_1));
144 EXPECT_CALL(observer, OnUpdatePolicy(_)).Times(1); 143 EXPECT_CALL(observer, OnUpdatePolicy(_)).Times(1);
145 provider.RefreshPolicies(); 144 provider.RefreshPolicies();
146 loop_.RunAllPending(); 145 loop_.RunAllPending();
147 Mock::VerifyAndClearExpectations(delegate); 146 Mock::VerifyAndClearExpectations(delegate);
148 Mock::VerifyAndClearExpectations(&observer); 147 Mock::VerifyAndClearExpectations(&observer);
149 } 148 }
150 149
151 } // namespace policy 150 } // namespace policy
OLDNEW
« no previous file with comments | « chrome/browser/policy/asynchronous_policy_loader.cc ('k') | chrome/browser/policy/asynchronous_policy_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698