| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/browser/chromeos/login/signed_settings_helper.h" | 5 #include "chrome/browser/chromeos/login/signed_settings_helper.h" |
| 6 | 6 |
| 7 #include "chrome/browser/chromeos/cros/cros_library.h" | 7 #include "chrome/browser/chromeos/cros/cros_library.h" |
| 8 #include "chrome/browser/chromeos/cros_settings_names.h" | 8 #include "chrome/browser/chromeos/cros_settings_names.h" |
| 9 #include "chrome/browser/chromeos/dbus/dbus_thread_manager.h" | 9 #include "chrome/browser/chromeos/dbus/dbus_thread_manager.h" |
| 10 #include "chrome/browser/chromeos/login/mock_ownership_service.h" | 10 #include "chrome/browser/chromeos/login/mock_ownership_service.h" |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 using ::testing::Return; | 25 using ::testing::Return; |
| 26 using ::testing::ReturnRef; | 26 using ::testing::ReturnRef; |
| 27 using ::testing::SaveArg; | 27 using ::testing::SaveArg; |
| 28 using ::testing::WithArg; | 28 using ::testing::WithArg; |
| 29 | 29 |
| 30 namespace em = enterprise_management; | 30 namespace em = enterprise_management; |
| 31 namespace chromeos { | 31 namespace chromeos { |
| 32 | 32 |
| 33 class MockSignedSettingsHelperCallback : public SignedSettingsHelper::Callback { | 33 class MockSignedSettingsHelperCallback : public SignedSettingsHelper::Callback { |
| 34 public: | 34 public: |
| 35 MOCK_METHOD2(OnCheckWhitelistCompleted, void( | 35 virtual ~MockSignedSettingsHelperCallback() {} |
| 36 SignedSettings::ReturnCode code, const std::string& email)); | 36 |
| 37 MOCK_METHOD2(OnWhitelistCompleted, void( | |
| 38 SignedSettings::ReturnCode code, const std::string& email)); | |
| 39 MOCK_METHOD2(OnUnwhitelistCompleted, void( | |
| 40 SignedSettings::ReturnCode code, const std::string& email)); | |
| 41 MOCK_METHOD3(OnStorePropertyCompleted, void( | 37 MOCK_METHOD3(OnStorePropertyCompleted, void( |
| 42 SignedSettings::ReturnCode code, | 38 SignedSettings::ReturnCode code, |
| 43 const std::string& name, | 39 const std::string& name, |
| 44 const base::Value& value)); | 40 const base::Value& value)); |
| 45 MOCK_METHOD3(OnRetrievePropertyCompleted, void( | 41 MOCK_METHOD3(OnRetrievePropertyCompleted, void( |
| 46 SignedSettings::ReturnCode code, | 42 SignedSettings::ReturnCode code, |
| 47 const std::string& name, | 43 const std::string& name, |
| 48 const base::Value* value)); | 44 const base::Value* value)); |
| 49 }; | 45 }; |
| 50 | 46 |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 112 ScopedStubCrosEnabler stub_cros_enabler_; | 108 ScopedStubCrosEnabler stub_cros_enabler_; |
| 113 }; | 109 }; |
| 114 | 110 |
| 115 TEST_F(SignedSettingsHelperTest, SerializedOps) { | 111 TEST_F(SignedSettingsHelperTest, SerializedOps) { |
| 116 MockSignedSettingsHelperCallback cb; | 112 MockSignedSettingsHelperCallback cb; |
| 117 | 113 |
| 118 EXPECT_CALL(m_, GetStatus(_)) | 114 EXPECT_CALL(m_, GetStatus(_)) |
| 119 .Times(2) | 115 .Times(2) |
| 120 .WillRepeatedly(Return(OwnershipService::OWNERSHIP_TAKEN)); | 116 .WillRepeatedly(Return(OwnershipService::OWNERSHIP_TAKEN)); |
| 121 EXPECT_CALL(m_, has_cached_policy()) | 117 EXPECT_CALL(m_, has_cached_policy()) |
| 122 .Times(5) | 118 .Times(2) |
| 123 .WillRepeatedly(Return(true)); | 119 .WillRepeatedly(Return(true)); |
| 124 em::PolicyData fake_pol = BuildPolicyData(); | 120 em::PolicyData fake_pol = BuildPolicyData(); |
| 125 EXPECT_CALL(m_, cached_policy()) | 121 EXPECT_CALL(m_, cached_policy()) |
| 126 .Times(5) | 122 .Times(2) |
| 127 .WillRepeatedly(ReturnRef(fake_pol)); | 123 .WillRepeatedly(ReturnRef(fake_pol)); |
| 128 EXPECT_CALL(m_, set_cached_policy(A<const em::PolicyData&>())) | 124 EXPECT_CALL(m_, set_cached_policy(A<const em::PolicyData&>())) |
| 129 .Times(3) | 125 .Times(1) |
| 130 .WillRepeatedly(SaveArg<0>(&fake_pol)); | 126 .WillRepeatedly(SaveArg<0>(&fake_pol)); |
| 131 | 127 |
| 132 InSequence s; | 128 InSequence s; |
| 133 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) | 129 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) |
| 134 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); | 130 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); |
| 135 EXPECT_CALL(cb, OnWhitelistCompleted(SignedSettings::SUCCESS, _)) | |
| 136 .Times(1); | |
| 137 | |
| 138 EXPECT_CALL(cb, OnCheckWhitelistCompleted(SignedSettings::SUCCESS, _)) | |
| 139 .Times(1); | |
| 140 | |
| 141 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) | |
| 142 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); | |
| 143 EXPECT_CALL(cb, OnUnwhitelistCompleted(SignedSettings::SUCCESS, _)) | |
| 144 .Times(1); | |
| 145 | |
| 146 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) | |
| 147 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); | |
| 148 EXPECT_CALL(cb, OnStorePropertyCompleted(SignedSettings::SUCCESS, _, _)) | 131 EXPECT_CALL(cb, OnStorePropertyCompleted(SignedSettings::SUCCESS, _, _)) |
| 149 .Times(1); | 132 .Times(1); |
| 150 | 133 |
| 151 EXPECT_CALL(cb, OnRetrievePropertyCompleted(SignedSettings::SUCCESS, _, _)) | 134 EXPECT_CALL(cb, OnRetrievePropertyCompleted(SignedSettings::SUCCESS, _, _)) |
| 152 .Times(1); | 135 .Times(1); |
| 153 | 136 |
| 154 pending_ops_ = 5; | 137 |
| 155 SignedSettingsHelper::Get()->StartWhitelistOp(fake_email_, true, &cb); | 138 pending_ops_ = 2; |
| 156 SignedSettingsHelper::Get()->StartCheckWhitelistOp(fake_email_, &cb); | |
| 157 SignedSettingsHelper::Get()->StartWhitelistOp(fake_email_, false, &cb); | |
| 158 SignedSettingsHelper::Get()->StartStorePropertyOp(fake_prop_, fake_value_, | 139 SignedSettingsHelper::Get()->StartStorePropertyOp(fake_prop_, fake_value_, |
| 159 &cb); | 140 &cb); |
| 160 SignedSettingsHelper::Get()->StartRetrieveProperty(fake_prop_, &cb); | 141 SignedSettingsHelper::Get()->StartRetrieveProperty(fake_prop_, &cb); |
| 161 | 142 |
| 162 message_loop_.Run(); | 143 message_loop_.Run(); |
| 163 } | 144 } |
| 164 | 145 |
| 165 TEST_F(SignedSettingsHelperTest, CanceledOps) { | 146 TEST_F(SignedSettingsHelperTest, CanceledOps) { |
| 166 MockSignedSettingsHelperCallback cb; | 147 MockSignedSettingsHelperCallback cb; |
| 167 | 148 |
| 168 EXPECT_CALL(m_, GetStatus(_)) | 149 EXPECT_CALL(m_, GetStatus(_)) |
| 169 .Times(2) | 150 .Times(3) |
| 170 .WillRepeatedly(Return(OwnershipService::OWNERSHIP_TAKEN)); | 151 .WillRepeatedly(Return(OwnershipService::OWNERSHIP_TAKEN)); |
| 171 EXPECT_CALL(m_, has_cached_policy()) | 152 EXPECT_CALL(m_, has_cached_policy()) |
| 172 .Times(6) | 153 .Times(3) |
| 173 .WillRepeatedly(Return(true)); | 154 .WillRepeatedly(Return(true)); |
| 174 em::PolicyData fake_pol = BuildPolicyData(); | 155 em::PolicyData fake_pol = BuildPolicyData(); |
| 175 EXPECT_CALL(m_, cached_policy()) | 156 EXPECT_CALL(m_, cached_policy()) |
| 176 .Times(7) | 157 .Times(3) |
| 177 .WillRepeatedly(ReturnRef(fake_pol)); | 158 .WillRepeatedly(ReturnRef(fake_pol)); |
| 178 EXPECT_CALL(m_, set_cached_policy(A<const em::PolicyData&>())) | 159 EXPECT_CALL(m_, set_cached_policy(A<const em::PolicyData&>())) |
| 179 .Times(3) | 160 .Times(1) |
| 180 .WillRepeatedly(SaveArg<0>(&fake_pol)); | 161 .WillRepeatedly(SaveArg<0>(&fake_pol)); |
| 181 | 162 |
| 182 InSequence s; | 163 InSequence s; |
| 183 | 164 |
| 184 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) | 165 // RetrievePropertyOp for cb_to_be_canceled still gets executed but callback |
| 185 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); | |
| 186 EXPECT_CALL(cb, OnWhitelistCompleted(SignedSettings::SUCCESS, _)) | |
| 187 .Times(1); | |
| 188 | |
| 189 EXPECT_CALL(cb, OnCheckWhitelistCompleted(SignedSettings::SUCCESS, _)) | |
| 190 .Times(1); | |
| 191 | |
| 192 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) | |
| 193 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); | |
| 194 EXPECT_CALL(cb, OnUnwhitelistCompleted(SignedSettings::SUCCESS, _)) | |
| 195 .Times(1); | |
| 196 | |
| 197 // CheckWhitelistOp for cb_to_be_canceled still gets executed but callback | |
| 198 // does not happen. | 166 // does not happen. |
| 199 | |
| 200 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) | 167 EXPECT_CALL(m_, StartSigningAttempt(_, A<OwnerManager::Delegate*>())) |
| 201 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); | 168 .WillOnce(WithArg<1>(Invoke(&SignedSettingsHelperTest::OnKeyOpComplete))); |
| 202 EXPECT_CALL(cb, OnStorePropertyCompleted(SignedSettings::SUCCESS, _, _)) | 169 EXPECT_CALL(cb, OnStorePropertyCompleted(SignedSettings::SUCCESS, _, _)) |
| 203 .Times(1); | 170 .Times(1); |
| 204 | |
| 205 EXPECT_CALL(cb, OnRetrievePropertyCompleted(SignedSettings::SUCCESS, _, _)) | 171 EXPECT_CALL(cb, OnRetrievePropertyCompleted(SignedSettings::SUCCESS, _, _)) |
| 206 .Times(1); | 172 .Times(1); |
| 207 | 173 |
| 208 pending_ops_ = 6; | 174 pending_ops_ = 3; |
| 209 SignedSettingsHelper::Get()->StartWhitelistOp(fake_email_, true, &cb); | |
| 210 SignedSettingsHelper::Get()->StartCheckWhitelistOp(fake_email_, &cb); | |
| 211 SignedSettingsHelper::Get()->StartWhitelistOp(fake_email_, false, &cb); | |
| 212 | |
| 213 MockSignedSettingsHelperCallback cb_to_be_canceled; | 175 MockSignedSettingsHelperCallback cb_to_be_canceled; |
| 214 SignedSettingsHelper::Get()->StartCheckWhitelistOp(fake_email_, | 176 SignedSettingsHelper::Get()->StartRetrieveProperty(fake_prop_, |
| 215 &cb_to_be_canceled); | 177 &cb_to_be_canceled); |
| 216 SignedSettingsHelper::Get()->CancelCallback(&cb_to_be_canceled); | 178 SignedSettingsHelper::Get()->CancelCallback(&cb_to_be_canceled); |
| 217 | 179 |
| 218 SignedSettingsHelper::Get()->StartStorePropertyOp(fake_prop_, fake_value_, | 180 SignedSettingsHelper::Get()->StartStorePropertyOp(fake_prop_, fake_value_, |
| 219 &cb); | 181 &cb); |
| 220 SignedSettingsHelper::Get()->StartRetrieveProperty(fake_prop_, &cb); | 182 SignedSettingsHelper::Get()->StartRetrieveProperty(fake_prop_, &cb); |
| 221 | 183 |
| 222 message_loop_.Run(); | 184 message_loop_.Run(); |
| 223 } | 185 } |
| 224 | 186 |
| 225 } // namespace chromeos | 187 } // namespace chromeos |
| OLD | NEW |