| // |
| // Copyright (C) 2012 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // |
| |
| #ifndef UPDATE_ENGINE_COMMON_FAKE_PREFS_H_ |
| #define UPDATE_ENGINE_COMMON_FAKE_PREFS_H_ |
| |
| #include <map> |
| #include <string> |
| #include <vector> |
| |
| #include <base/macros.h> |
| |
| #include "update_engine/common/prefs_interface.h" |
| |
| namespace chromeos_update_engine { |
| |
| // Implements a fake preference store by storing the value associated with |
| // a key in a std::map, suitable for testing. It doesn't allow to set a value on |
| // a key with a different type than the previously set type. This enforces the |
| // type of a given key to be fixed. Also the class checks that the Get*() |
| // methods aren't called on a key set with a different type. |
| |
| class FakePrefs : public PrefsInterface { |
| public: |
| FakePrefs() = default; |
| ~FakePrefs(); |
| |
| // PrefsInterface methods. |
| bool GetString(const std::string& key, std::string* value) const override; |
| bool SetString(const std::string& key, const std::string& value) override; |
| bool GetInt64(const std::string& key, int64_t* value) const override; |
| bool SetInt64(const std::string& key, const int64_t value) override; |
| bool GetBoolean(const std::string& key, bool* value) const override; |
| bool SetBoolean(const std::string& key, const bool value) override; |
| |
| bool Exists(const std::string& key) const override; |
| bool Delete(const std::string& key) override; |
| |
| void AddObserver(const std::string& key, |
| ObserverInterface* observer) override; |
| void RemoveObserver(const std::string& key, |
| ObserverInterface* observer) override; |
| |
| private: |
| enum class PrefType { |
| kString, |
| kInt64, |
| kBool, |
| }; |
| struct PrefValue { |
| std::string as_str; |
| int64_t as_int64; |
| bool as_bool; |
| }; |
| |
| struct PrefTypeValue { |
| PrefType type; |
| PrefValue value; |
| }; |
| |
| // Class to store compile-time type-dependent constants. |
| template <typename T> |
| class PrefConsts { |
| public: |
| // The PrefType associated with T. |
| static FakePrefs::PrefType const type; |
| |
| // The data member pointer to PrefValue associated with T. |
| static T FakePrefs::PrefValue::*const member; |
| }; |
| |
| // Returns a string representation of the PrefType useful for logging. |
| static std::string GetTypeName(PrefType type); |
| |
| // Checks that the |key| is either not present or has the given |type|. |
| void CheckKeyType(const std::string& key, PrefType type) const; |
| |
| // Helper function to set a value of the passed |key|. It sets the type based |
| // on the template parameter T. |
| template <typename T> |
| void SetValue(const std::string& key, const T& value); |
| |
| // Helper function to get a value from the map checking for invalid calls. |
| // The function fails the test if you attempt to read a value defined as a |
| // different type. Returns whether the get succeeded. |
| template <typename T> |
| bool GetValue(const std::string& key, T* value) const; |
| |
| // Container for all the key/value pairs. |
| std::map<std::string, PrefTypeValue> values_; |
| |
| // The registered observers watching for changes. |
| std::map<std::string, std::vector<ObserverInterface*>> observers_; |
| |
| DISALLOW_COPY_AND_ASSIGN(FakePrefs); |
| }; |
| |
| } // namespace chromeos_update_engine |
| |
| #endif // UPDATE_ENGINE_COMMON_FAKE_PREFS_H_ |