blob: e04dd6d32a8ab403c1ebaa5b0a1acc5f9b0161f0 [file] [log] [blame]
/**
* Copyright © 2020 IBM Corporation
*
* 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.
*/
#include "action.hpp"
#include "chassis.hpp"
#include "configuration.hpp"
#include "device.hpp"
#include "i2c_interface.hpp"
#include "mock_action.hpp"
#include "phase_fault_detection.hpp"
#include "presence_detection.hpp"
#include "rail.hpp"
#include "rule.hpp"
#include <filesystem>
#include <fstream>
#include <memory>
#include <string>
#include <utility>
#include <vector>
namespace phosphor::power::regulators::test_utils
{
namespace fs = std::filesystem;
/**
* Create an I2CInterface object with hard-coded bus and address values.
*
* @return I2CInterface object wrapped in a unique_ptr
*/
inline std::unique_ptr<i2c::I2CInterface> createI2CInterface()
{
return i2c::create(1, 0x70, i2c::I2CInterface::InitialState::CLOSED);
}
/**
* Creates a Device object with the specified ID.
*
* Creates Rail objects within the Device if railIDs is specified.
*
* @param id device ID
* @param railIDs rail IDs (optional)
* @return Device object
*/
inline std::unique_ptr<Device>
createDevice(const std::string& id,
const std::vector<std::string>& railIDs = {})
{
// Create Rails (if any)
std::vector<std::unique_ptr<Rail>> rails{};
for (const std::string& railID : railIDs)
{
rails.emplace_back(std::make_unique<Rail>(railID));
}
// Create Device
bool isRegulator = true;
std::string fru =
"/xyz/openbmc_project/inventory/system/chassis/motherboard/reg1";
std::unique_ptr<i2c::I2CInterface> i2cInterface = createI2CInterface();
std::unique_ptr<PresenceDetection> presenceDetection{};
std::unique_ptr<Configuration> configuration{};
std::unique_ptr<PhaseFaultDetection> phaseFaultDetection{};
return std::make_unique<Device>(
id, isRegulator, fru, std::move(i2cInterface),
std::move(presenceDetection), std::move(configuration),
std::move(phaseFaultDetection), std::move(rails));
}
/**
* Creates a Rule object with the specified ID.
*
* @param id rule ID
* @return Rule object
*/
inline std::unique_ptr<Rule> createRule(const std::string& id)
{
// Create actions
std::vector<std::unique_ptr<Action>> actions{};
actions.emplace_back(std::make_unique<MockAction>());
// Create Rule
return std::make_unique<Rule>(id, std::move(actions));
}
/**
* Modify the specified file so that fs::remove() fails with an exception.
*
* The file will be renamed and can be restored by calling makeFileRemovable().
*
* @param path path to the file
*/
inline void makeFileUnRemovable(const fs::path& path)
{
// Rename the file to save its contents
fs::path savePath{path.native() + ".save"};
fs::rename(path, savePath);
// Create a directory at the original file path
fs::create_directory(path);
// Create a file within the directory. fs::remove() will throw an exception
// if the path is a non-empty directory.
std::ofstream childFile{path / "childFile"};
}
/**
* Modify the specified file so that fs::remove() can successfully delete it.
*
* Undo the modifications from an earlier call to makeFileUnRemovable().
*
* @param path path to the file
*/
inline void makeFileRemovable(const fs::path& path)
{
// makeFileUnRemovable() creates a directory at the file path. Remove the
// directory and all of its contents.
fs::remove_all(path);
// Rename the file back to the original path to restore its contents
fs::path savePath{path.native() + ".save"};
fs::rename(savePath, path);
}
} // namespace phosphor::power::regulators::test_utils