| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/memory/scoped_ptr.h" |
| 5 #include "base/strings/string_util.h" | 6 #include "base/strings/string_util.h" |
| 7 #include "chrome/browser/browser_process.h" |
| 6 #include "chrome/browser/chromeos/policy/device_policy_builder.h" | 8 #include "chrome/browser/chromeos/policy/device_policy_builder.h" |
| 7 #include "chrome/browser/chromeos/policy/device_policy_cros_browser_test.h" | 9 #include "chrome/browser/chromeos/policy/device_policy_cros_browser_test.h" |
| 8 #include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h" | 10 #include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h" |
| 11 #include "chrome/browser/metrics/variations/chrome_variations_service_client.h" |
| 9 #include "chrome/browser/metrics/variations/variations_service.h" | 12 #include "chrome/browser/metrics/variations/variations_service.h" |
| 10 #include "chrome/test/base/testing_browser_process.h" | 13 #include "chrome/test/base/testing_browser_process.h" |
| 11 #include "net/base/url_util.h" | 14 #include "net/base/url_util.h" |
| 12 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
| 13 | 16 |
| 14 namespace policy { | 17 namespace policy { |
| 15 | 18 |
| 16 class VariationsServiceDevicePolicyTest : public DevicePolicyCrosBrowserTest { | 19 class VariationsServiceDevicePolicyTest : public DevicePolicyCrosBrowserTest { |
| 17 protected: | 20 protected: |
| 18 VariationsServiceDevicePolicyTest() {} | 21 VariationsServiceDevicePolicyTest() {} |
| (...skipping 15 matching lines...) Expand all Loading... |
| 34 | 37 |
| 35 private: | 38 private: |
| 36 DISALLOW_COPY_AND_ASSIGN(VariationsServiceDevicePolicyTest); | 39 DISALLOW_COPY_AND_ASSIGN(VariationsServiceDevicePolicyTest); |
| 37 }; | 40 }; |
| 38 | 41 |
| 39 IN_PROC_BROWSER_TEST_F(VariationsServiceDevicePolicyTest, VariationsURLValid) { | 42 IN_PROC_BROWSER_TEST_F(VariationsServiceDevicePolicyTest, VariationsURLValid) { |
| 40 const std::string default_variations_url = | 43 const std::string default_variations_url = |
| 41 chrome_variations::VariationsService:: | 44 chrome_variations::VariationsService:: |
| 42 GetDefaultVariationsServerURLForTesting(); | 45 GetDefaultVariationsServerURLForTesting(); |
| 43 | 46 |
| 47 // g_browser_process->variations_service() is null by default in Chromium |
| 48 // builds, so construct a VariationsService locally instead. |
| 49 scoped_ptr<chrome_variations::VariationsService> service = |
| 50 chrome_variations::VariationsService::CreateForTesting( |
| 51 make_scoped_ptr(new ChromeVariationsServiceClient()), |
| 52 g_browser_process->local_state()); |
| 53 |
| 44 // Device policy has updated the cros settings. | 54 // Device policy has updated the cros settings. |
| 45 const GURL url = chrome_variations::VariationsService::GetVariationsServerURL( | 55 const GURL url = service->GetVariationsServerURL( |
| 46 g_browser_process->local_state(), std::string()); | 56 g_browser_process->local_state(), std::string()); |
| 47 EXPECT_TRUE(base::StartsWith(url.spec(), default_variations_url, | 57 EXPECT_TRUE(base::StartsWith(url.spec(), default_variations_url, |
| 48 base::CompareCase::SENSITIVE)); | 58 base::CompareCase::SENSITIVE)); |
| 49 std::string value; | 59 std::string value; |
| 50 EXPECT_TRUE(net::GetValueForKeyInQuery(url, "restrict", &value)); | 60 EXPECT_TRUE(net::GetValueForKeyInQuery(url, "restrict", &value)); |
| 51 EXPECT_EQ("restricted", value); | 61 EXPECT_EQ("restricted", value); |
| 52 } | 62 } |
| 53 | 63 |
| 54 } // namespace policy | 64 } // namespace policy |
| OLD | NEW |