// // 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_