Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 #ifndef CHROME_TEST_TESTING_PREF_SERVICE_H_ | 5 #ifndef CHROME_TEST_TESTING_PREF_SERVICE_H_ |
| 6 #define CHROME_TEST_TESTING_PREF_SERVICE_H_ | 6 #define CHROME_TEST_TESTING_PREF_SERVICE_H_ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include "base/ref_counted.h" | |
| 9 #include "chrome/browser/prefs/pref_service.h" | 10 #include "chrome/browser/prefs/pref_service.h" |
| 10 | 11 |
| 12 class ExtensionPrefStore; | |
| 11 class TestingPrefStore; | 13 class TestingPrefStore; |
| 12 | 14 |
| 15 // Helper base class to allow simple construction of TestPrefService objects. | |
| 16 class TestingPrefServiceBase : public PrefService { | |
| 17 public: | |
| 18 virtual ~TestingPrefServiceBase(); | |
| 19 | |
| 20 protected: | |
| 21 TestingPrefServiceBase( | |
| 22 TestingPrefStore* managed_platform_prefs, | |
| 23 TestingPrefStore* device_management_prefs, | |
| 24 ExtensionPrefStore* extension_prefs, | |
| 25 TestingPrefStore* user_prefs); | |
| 26 | |
| 27 // Pointers to the pref stores our value store uses. | |
| 28 scoped_refptr<TestingPrefStore> managed_platform_prefs_; | |
| 29 scoped_refptr<TestingPrefStore> device_management_prefs_; | |
| 30 scoped_refptr<ExtensionPrefStore> extension_prefs_; | |
| 31 scoped_refptr<TestingPrefStore> user_prefs_; | |
|
Mattias Nissler (ping if slow)
2010/12/22 12:09:03
Didn't we agree to just move all the interface int
battre
2010/12/22 18:34:53
Done.
| |
| 32 | |
| 33 DISALLOW_COPY_AND_ASSIGN(TestingPrefServiceBase); | |
| 34 }; | |
| 35 | |
| 13 // A PrefService subclass for testing. It operates totally in memory and | 36 // A PrefService subclass for testing. It operates totally in memory and |
| 14 // provides additional API for manipulating preferences at the different levels | 37 // provides additional API for manipulating preferences at the different levels |
| 15 // (managed, extension, user) conveniently. | 38 // (managed, extension, user) conveniently. |
| 16 class TestingPrefService : public PrefService { | 39 class TestingPrefService : public TestingPrefServiceBase { |
| 17 public: | 40 public: |
| 18 // Create an empty instance. | |
| 19 TestingPrefService(); | 41 TestingPrefService(); |
| 20 virtual ~TestingPrefService() {} | 42 virtual ~TestingPrefService(); |
| 21 | 43 |
| 22 // Read the value of a preference from the managed layer. Returns NULL if the | 44 // Read the value of a preference from the managed layer. Returns NULL if the |
| 23 // preference is not defined at the managed layer. | 45 // preference is not defined at the managed layer. |
| 24 const Value* GetManagedPref(const char* path) const; | 46 const Value* GetManagedPref(const char* path) const; |
| 25 | 47 |
| 26 // Set a preference on the managed layer and fire observers if the preference | 48 // Set a preference on the managed layer and fire observers if the preference |
| 27 // changed. Assumes ownership of |value|. | 49 // changed. Assumes ownership of |value|. |
| 28 void SetManagedPref(const char* path, Value* value); | 50 void SetManagedPref(const char* path, Value* value); |
| 29 | 51 |
| 30 // Clear the preference on the managed layer and fire observers if the | 52 // Clear the preference on the managed layer and fire observers if the |
| 31 // preference has been defined previously. | 53 // preference has been defined previously. |
| 32 void RemoveManagedPref(const char* path); | 54 void RemoveManagedPref(const char* path); |
| 33 | 55 |
| 34 // Similar to the above, but for user preferences. | 56 // Similar to the above, but for user preferences. |
| 35 const Value* GetUserPref(const char* path) const; | 57 const Value* GetUserPref(const char* path) const; |
| 36 void SetUserPref(const char* path, Value* value); | 58 void SetUserPref(const char* path, Value* value); |
| 37 void RemoveUserPref(const char* path); | 59 void RemoveUserPref(const char* path); |
| 38 | 60 |
| 61 ExtensionPrefStore* GetExtensionPrefs(); | |
|
Mattias Nissler (ping if slow)
2010/12/22 12:09:03
No! This class is meant for the case when you need
battre
2010/12/22 18:34:53
This method was introduced because the ExtensionPr
| |
| 62 | |
| 39 private: | 63 private: |
| 40 // Reads the value of the preference indicated by |path| from |pref_store|. | 64 // Reads the value of the preference indicated by |path| from |pref_store|. |
| 41 // Returns NULL if the preference was not found. | 65 // Returns NULL if the preference was not found. |
| 42 const Value* GetPref(TestingPrefStore* pref_store, const char* path) const; | 66 const Value* GetPref(TestingPrefStore* pref_store, const char* path) const; |
| 43 | 67 |
| 44 // Sets the value for |path| in |pref_store|. | 68 // Sets the value for |path| in |pref_store|. |
| 45 void SetPref(TestingPrefStore* pref_store, const char* path, Value* value); | 69 void SetPref(TestingPrefStore* pref_store, const char* path, Value* value); |
| 46 | 70 |
| 47 // Removes the preference identified by |path| from |pref_store|. | 71 // Removes the preference identified by |path| from |pref_store|. |
| 48 void RemovePref(TestingPrefStore* pref_store, const char* path); | 72 void RemovePref(TestingPrefStore* pref_store, const char* path); |
| 49 | 73 |
| 50 // Pointers to the pref stores our value store uses. | |
| 51 TestingPrefStore* managed_platform_prefs_; // weak | |
| 52 TestingPrefStore* device_management_prefs_; // weak | |
| 53 TestingPrefStore* user_prefs_; // weak | |
| 54 | |
| 55 DISALLOW_COPY_AND_ASSIGN(TestingPrefService); | 74 DISALLOW_COPY_AND_ASSIGN(TestingPrefService); |
| 56 }; | 75 }; |
| 57 | 76 |
| 58 #endif // CHROME_TEST_TESTING_PREF_SERVICE_H_ | 77 #endif // CHROME_TEST_TESTING_PREF_SERVICE_H_ |
| OLD | NEW |