Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
2017
pastarmovj
2017/06/01 11:05:06
Done.
| |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include <string> | |
| 6 | |
| 7 #include "base/memory/ptr_util.h" | |
| 8 #include "base/values.h" | |
| 9 #include "chrome/browser/policy/local_sync_policy_handler.h" | |
| 10 #include "components/policy/core/common/policy_map.h" | |
| 11 #include "components/policy/core/common/policy_types.h" | |
| 12 #include "components/policy/policy_constants.h" | |
| 13 #include "components/prefs/pref_value_map.h" | |
| 14 #include "components/sync/base/pref_names.h" | |
| 15 #include "testing/gtest/include/gtest/gtest.h" | |
| 16 | |
| 17 namespace policy { | |
| 18 | |
| 19 class LocalSyncPolicyTest : public testing::Test { | |
| 20 protected: | |
| 21 PolicyMap policy_; | |
| 22 LocalSyncPolicyHandler handler_; | |
| 23 PrefValueMap prefs_; | |
| 24 }; | |
| 25 | |
| 26 TEST_F(LocalSyncPolicyTest, Default) { | |
| 27 handler_.ApplyPolicySettings(policy_, &prefs_); | |
| 28 EXPECT_FALSE(prefs_.GetValue(syncer::prefs::kLocalSyncBackendDir, NULL)); | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Nit: nullptr
pastarmovj
2017/06/01 11:05:06
Done.
| |
| 29 } | |
| 30 | |
| 31 TEST_F(LocalSyncPolicyTest, SetPolicyInvalid) { | |
| 32 // RoamingProfileLocation policy expects a string; give it a boolean. | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Nit: I'd suggest to move this comment above TEST_F
pastarmovj
2017/06/01 11:05:06
Done.
| |
| 33 policy_.Set(key::kRoamingProfileLocation, POLICY_LEVEL_MANDATORY, | |
| 34 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, | |
| 35 base::MakeUnique<base::Value>(false), nullptr); | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Nit: nullptr /* external_data_fetcher */
pastarmovj
2017/06/01 11:05:06
I don't think this is particularly useful comment.
| |
| 36 handler_.ApplyPolicySettings(policy_, &prefs_); | |
| 37 EXPECT_FALSE(prefs_.GetValue(syncer::prefs::kLocalSyncBackendDir, NULL)); | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Nit: nullptr
pastarmovj
2017/06/01 11:05:07
Done.
| |
| 38 } | |
| 39 | |
| 40 TEST_F(LocalSyncPolicyTest, SetPolicyValid) { | |
| 41 // Use a variable in the value. It should be expanded by the handler. | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Same here.
pastarmovj
2017/06/01 11:05:06
Done.
| |
| 42 const std::string in = "${user_name}/foo"; | |
| 43 policy_.Set(key::kRoamingProfileLocation, POLICY_LEVEL_MANDATORY, | |
| 44 POLICY_SCOPE_USER, POLICY_SOURCE_CLOUD, | |
| 45 base::MakeUnique<base::Value>(in), nullptr); | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Nit: nullptr /* external_data_fetcher */
pastarmovj
2017/06/01 11:05:06
ditto.
| |
| 46 handler_.ApplyPolicySettings(policy_, &prefs_); | |
| 47 | |
| 48 const base::Value* value; | |
| 49 ASSERT_TRUE(prefs_.GetValue(syncer::prefs::kLocalSyncBackendDir, &value)); | |
| 50 std::string out; | |
| 51 ASSERT_TRUE(value->GetAsString(&out)); | |
| 52 EXPECT_NE(std::string::npos, out.find("foo")); | |
| 53 EXPECT_EQ(std::string::npos, out.find("${user_name}")); | |
|
ljusten (tachyonic)
2017/06/01 10:05:53
Is it possible to check whether ${user_name} was r
pastarmovj
2017/06/01 11:05:06
Not really in a platform independent way. It is im
| |
| 54 } | |
| 55 | |
| 56 } // namespace policy | |
| OLD | NEW |