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 |