|  | /* | 
|  | * Copyright (C) 2016 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 BOOT_EVENT_RECORD_STORE_H_ | 
|  | #define BOOT_EVENT_RECORD_STORE_H_ | 
|  |  | 
|  | #include <cstdint> | 
|  | #include <string> | 
|  | #include <utility> | 
|  | #include <vector> | 
|  | #include <android-base/macros.h> | 
|  | #include <gtest/gtest_prod.h> | 
|  |  | 
|  | // BootEventRecordStore manages the persistence of boot events to the record | 
|  | // store and the retrieval of all boot event records from the store. | 
|  | class BootEventRecordStore { | 
|  | public: | 
|  | // A BootEventRecord consists of the event name and the timestamp the event | 
|  | // occurred. | 
|  | typedef std::pair<std::string, int32_t> BootEventRecord; | 
|  |  | 
|  | BootEventRecordStore(); | 
|  |  | 
|  | // Persists the boot |event| in the record store. | 
|  | void AddBootEvent(const std::string& event); | 
|  |  | 
|  | // Persists the boot |event| with the associated |value| in the record store. | 
|  | void AddBootEventWithValue(const std::string& event, int32_t value); | 
|  |  | 
|  | // Queries the named boot |event|. |record| must be non-null. |record| | 
|  | // contains the boot event data on success. Returns true iff the query is | 
|  | // successful. | 
|  | bool GetBootEvent(const std::string& event, BootEventRecord* record) const; | 
|  |  | 
|  | // Returns a list of all of the boot events persisted in the record store. | 
|  | std::vector<BootEventRecord> GetAllBootEvents() const; | 
|  |  | 
|  | private: | 
|  | // The tests call SetStorePath to override the default store location with a | 
|  | // more test-friendly path. | 
|  | FRIEND_TEST(BootEventRecordStoreTest, AddSingleBootEvent); | 
|  | FRIEND_TEST(BootEventRecordStoreTest, AddMultipleBootEvents); | 
|  | FRIEND_TEST(BootEventRecordStoreTest, AddBootEventWithValue); | 
|  | FRIEND_TEST(BootEventRecordStoreTest, GetBootEvent); | 
|  |  | 
|  | // Sets the filesystem path of the record store. | 
|  | void SetStorePath(const std::string& path); | 
|  |  | 
|  | // Constructs the full path of the given boot |event|. | 
|  | std::string GetBootEventPath(const std::string& event) const; | 
|  |  | 
|  | // The filesystem path of the record store. | 
|  | std::string store_path_; | 
|  |  | 
|  | DISALLOW_COPY_AND_ASSIGN(BootEventRecordStore); | 
|  | }; | 
|  |  | 
|  | #endif  // BOOT_EVENT_RECORD_STORE_H_ |