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

Unified Diff: components/policy/core/common/fake_async_policy_loader.h

Issue 858303003: Removing FakePolicyWatcher and introducing FakeAsyncPolicyLoader. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 11 months 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: components/policy/core/common/fake_async_policy_loader.h
diff --git a/components/policy/core/common/fake_async_policy_loader.h b/components/policy/core/common/fake_async_policy_loader.h
new file mode 100644
index 0000000000000000000000000000000000000000..886c0461b117011b37bb763061dcf3dba0b762a4
--- /dev/null
+++ b/components/policy/core/common/fake_async_policy_loader.h
@@ -0,0 +1,55 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef COMPONENTS_POLICY_CORE_COMMON_FAKE_ASYNC_POLICY_LOADER_H_
+#define COMPONENTS_POLICY_CORE_COMMON_FAKE_ASYNC_POLICY_LOADER_H_
+
+#include "base/values.h"
Mattias Nissler (ping if slow) 2015/01/22 16:05:07 nit: you can forward-declare DictionaryValue inste
Łukasz Anforowicz 2015/01/22 18:28:05 Done.
+#include "components/policy/core/common/async_policy_loader.h"
+#include "components/policy/core/common/policy_bundle.h"
+#include "components/policy/core/common/policy_namespace.h"
+#include "components/policy/core/common/policy_types.h"
+
+namespace policy {
+
+// Fake AsyncPolicyLoader for testing with test-controlled policies.
+//
+// Typical test code would populate the policy contents via calls to
+// ClearPolicies and AddPolicies and then notify the rest of the policy
+// subsystem of the changes by calling PostReloadOnBackgroundThread.
+class FakeAsyncPolicyLoader : public AsyncPolicyLoader {
+ public:
+ explicit FakeAsyncPolicyLoader(
+ scoped_refptr<base::SequencedTaskRunner> task_runner);
+
+ // Implementation of virtual methods from AsyncPolicyLoader base class.
+ scoped_ptr<PolicyBundle> Load() override;
+ void InitOnBackgroundThread() override;
+
+ // Clears the simulated / faked policy contents.
+ void ClearPolicies();
Mattias Nissler (ping if slow) 2015/01/22 16:05:07 I'd prefer if you just made an UpdatePolicies(cons
Łukasz Anforowicz 2015/01/22 18:28:05 I removed ClearPolicies and AddPolicies(Dict) and
+
+ // Adds content to the simulated / faked policy contents.
+ void AddPolicies(const PolicyNamespace& ns,
+ const base::DictionaryValue& policies,
+ PolicyLevel level,
+ PolicyScope scope);
+
+ // Notifies the rest of the policy subsystem that policy contents have
+ // changed. This simulates / fakes a notification that normally would be
+ // triggered by a FilePathWatcher or (registry)ObjectWatcher in a real loader.
+ //
+ // See AsyncPolicyLoader::Reload method for description of the |force|
+ // parameter.
+ void PostReloadOnBackgroundThread(bool force);
+
+ private:
+ PolicyBundle policy_bundle_;
+
+ DISALLOW_COPY_AND_ASSIGN(FakeAsyncPolicyLoader);
+};
+
+} // namespace policy
+
+#endif // COMPONENTS_POLICY_CORE_COMMON_FAKE_ASYNC_POLICY_LOADER_H_

Powered by Google App Engine
This is Rietveld 408576698