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

Unified Diff: trunk/src/chrome/browser/chromeos/policy/user_cloud_external_data_manager_browsertest.cc

Issue 60683002: Revert 233048 "Support policies referencing external data for de..." (Closed) Base URL: svn://svn.chromium.org/chrome/
Patch Set: Created 7 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: trunk/src/chrome/browser/chromeos/policy/user_cloud_external_data_manager_browsertest.cc
===================================================================
--- trunk/src/chrome/browser/chromeos/policy/user_cloud_external_data_manager_browsertest.cc (revision 233050)
+++ trunk/src/chrome/browser/chromeos/policy/user_cloud_external_data_manager_browsertest.cc (working copy)
@@ -4,22 +4,28 @@
#include <string>
+#include "base/basictypes.h"
#include "base/bind.h"
#include "base/callback.h"
#include "base/file_util.h"
#include "base/files/file_path.h"
#include "base/memory/scoped_ptr.h"
+#include "base/memory/weak_ptr.h"
#include "base/path_service.h"
#include "base/run_loop.h"
+#include "base/sha1.h"
+#include "base/strings/string_number_conversions.h"
#include "base/values.h"
#include "chrome/browser/chromeos/policy/cloud_external_data_manager_base.h"
-#include "chrome/browser/chromeos/policy/cloud_external_data_manager_base_test_util.h"
#include "chrome/browser/chromeos/policy/user_cloud_policy_manager_chromeos.h"
#include "chrome/browser/chromeos/policy/user_cloud_policy_manager_factory_chromeos.h"
+#include "chrome/browser/policy/cloud/cloud_external_data_manager.h"
#include "chrome/browser/policy/cloud/cloud_policy_core.h"
+#include "chrome/browser/policy/cloud/cloud_policy_store.h"
#include "chrome/browser/policy/external_data_fetcher.h"
#include "chrome/browser/policy/policy_map.h"
#include "chrome/browser/policy/policy_service.h"
+#include "chrome/browser/policy/policy_types.h"
#include "chrome/browser/policy/profile_policy_connector.h"
#include "chrome/browser/policy/profile_policy_connector_factory.h"
#include "chrome/browser/profiles/profile.h"
@@ -38,10 +44,68 @@
const char kExternalDataPath[] = "policy/blank.html";
+void ExternalDataFetchCallback(scoped_ptr<std::string>* destination,
+ const base::Closure& done_callback,
+ scoped_ptr<std::string> data) {
+ destination->reset(data.release());
+ done_callback.Run();
+}
+
} // namespace
-typedef InProcessBrowserTest UserCloudExternalDataManagerTest;
+class UserCloudExternalDataManagerTest : public InProcessBrowserTest {
+ protected:
+ UserCloudExternalDataManagerTest();
+ virtual ~UserCloudExternalDataManagerTest();
+ scoped_ptr<base::DictionaryValue> ConstructMetadata(const std::string& url,
+ const std::string& hash);
+ void SetExternalDataReference(const std::string& policy,
+ scoped_ptr<base::DictionaryValue> metadata);
+
+ DISALLOW_COPY_AND_ASSIGN(UserCloudExternalDataManagerTest);
+};
+
+UserCloudExternalDataManagerTest::UserCloudExternalDataManagerTest() {
+}
+
+UserCloudExternalDataManagerTest::~UserCloudExternalDataManagerTest() {
+}
+
+scoped_ptr<base::DictionaryValue>
+ UserCloudExternalDataManagerTest::ConstructMetadata(
+ const std::string& url,
+ const std::string& hash) {
+ scoped_ptr<base::DictionaryValue> metadata(new base::DictionaryValue);
+ metadata->SetStringWithoutPathExpansion("url", url);
+ metadata->SetStringWithoutPathExpansion("hash", base::HexEncode(hash.c_str(),
+ hash.size()));
+ return metadata.Pass();
+}
+
+void UserCloudExternalDataManagerTest::SetExternalDataReference(
+ const std::string& policy,
+ scoped_ptr<base::DictionaryValue> metadata) {
+#if defined(OS_CHROMEOS)
+ UserCloudPolicyManagerChromeOS* policy_manager =
+ UserCloudPolicyManagerFactoryChromeOS::GetForProfile(
+ browser()->profile());
+#else
+ UserCloudPolicyManager* policy_manager =
+ UserCloudPolicyManagerFactory::GetForProfile(browser()->profile());
+#endif
+ ASSERT_TRUE(policy_manager);
+ CloudPolicyStore* store = policy_manager->core()->store();
+ ASSERT_TRUE(store);
+ PolicyMap policy_map;
+ policy_map.Set(policy,
+ POLICY_LEVEL_MANDATORY, POLICY_SCOPE_USER,
+ metadata.release(),
+ new ExternalDataFetcher(store->external_data_manager(),
+ policy));
+ store->SetPolicyMapForTesting(policy_map);
+}
+
IN_PROC_BROWSER_TEST_F(UserCloudExternalDataManagerTest, FetchExternalData) {
CloudExternalDataManagerBase::SetMaxExternalDataSizeForTesting(1000);
@@ -57,23 +121,13 @@
ASSERT_FALSE(external_data.empty());
scoped_ptr<base::DictionaryValue> metadata =
- test::ConstructExternalDataReference(url.spec(), external_data);
-#if defined(OS_CHROMEOS)
- UserCloudPolicyManagerChromeOS* policy_manager =
- UserCloudPolicyManagerFactoryChromeOS::GetForProfile(
- browser()->profile());
-#else
- UserCloudPolicyManager* policy_manager =
- UserCloudPolicyManagerFactory::GetForProfile(browser()->profile());
-#endif
- ASSERT_TRUE(policy_manager);
+ ConstructMetadata(url.spec(), base::SHA1HashString(external_data));
// TODO(bartfab): The test injects an ExternalDataFetcher for an arbitrary
// policy. This is only done because there are no policies that reference
// external data yet. Once the first such policy is added, switch the test to
// that policy and stop injecting a manually instantiated ExternalDataFetcher.
- test::SetExternalDataReference(policy_manager->core(),
- key::kHomepageLocation,
- make_scoped_ptr(metadata->DeepCopy()));
+ SetExternalDataReference(key::kHomepageLocation,
+ make_scoped_ptr(metadata->DeepCopy()));
content::RunAllPendingInMessageLoop();
ProfilePolicyConnector* policy_connector =
@@ -89,7 +143,7 @@
base::RunLoop run_loop;
scoped_ptr<std::string> fetched_external_data;
policy_entry->external_data_fetcher->Fetch(base::Bind(
- &test::ExternalDataFetchCallback,
+ &ExternalDataFetchCallback,
&fetched_external_data,
run_loop.QuitClosure()));
run_loop.Run();

Powered by Google App Engine
This is Rietveld 408576698