blob: 87dba979dc427930675a052c4221975d94b5a13b [file] [log] [blame]
#include "bmc_update_mock.hpp"
#include "data_mock.hpp"
#include "firmware_handler.hpp"
#include "image_mock.hpp"
#include "util.hpp"
#include "verification_mock.hpp"
#include <memory>
#include <vector>
#include <gtest/gtest.h>
namespace ipmi_flash
{
using ::testing::_;
using ::testing::IsNull;
using ::testing::NotNull;
using ::testing::Return;
using ::testing::StrEq;
using ::testing::StrictMock;
class FirmwareHandlerCommitTest : public ::testing::Test
{
protected:
ImageHandlerMock imageMock1, imageMock2;
std::vector<HandlerPack> blobs;
std::vector<DataHandlerPack> data;
void SetUp() override
{
blobs = {
{hashBlobId, &imageMock1},
{"asdf", &imageMock2},
};
data = {
{FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
};
}
};
TEST_F(FirmwareHandlerCommitTest, VerifyCannotCommitOnFlashImage)
{
/* Verify the flash image returns failure on this command. It's a fairly
* artificial test.
*/
/* Verify it doesn't get called by using StrictMock. */
std::unique_ptr<VerificationInterface> verifyMock =
std::make_unique<StrictMock<VerificationMock>>();
auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
blobs, data, std::move(verifyMock), CreateUpdateMock());
EXPECT_CALL(imageMock2, open("asdf")).WillOnce(Return(true));
EXPECT_TRUE(handler->open(
0, blobs::OpenFlags::write | FirmwareBlobHandler::UpdateFlags::ipmi,
"asdf"));
EXPECT_FALSE(handler->commit(0, {}));
}
TEST_F(FirmwareHandlerCommitTest, VerifyCannotCommitOnHashFile)
{
/* Verify the hash file returns failure on this command. It's a fairly
* artificial test.
*/
/* Verify it doesn't get called by using StrictMock. */
std::unique_ptr<VerificationInterface> verifyMock =
std::make_unique<StrictMock<VerificationMock>>();
auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
blobs, data, std::move(verifyMock), CreateUpdateMock());
EXPECT_CALL(imageMock1, open(StrEq(hashBlobId))).WillOnce(Return(true));
EXPECT_TRUE(handler->open(
0, blobs::OpenFlags::write | FirmwareBlobHandler::UpdateFlags::ipmi,
hashBlobId));
EXPECT_FALSE(handler->commit(0, {}));
}
TEST_F(FirmwareHandlerCommitTest, VerifyCommitAcceptedOnVerifyBlob)
{
/* Verify the verify blob lets you call this command, and it returns
* success.
*/
auto verifyMock = CreateVerifyMock();
auto verifyMockPtr = reinterpret_cast<VerificationMock*>(verifyMock.get());
auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
blobs, data, std::move(verifyMock), CreateUpdateMock());
EXPECT_TRUE(handler->open(0, blobs::OpenFlags::write, verifyBlobId));
EXPECT_CALL(*verifyMockPtr, triggerVerification())
.WillRepeatedly(Return(true));
EXPECT_TRUE(handler->commit(0, {}));
}
TEST_F(FirmwareHandlerCommitTest, VerifyCommitCanOnlyBeCalledOnceForEffect)
{
/* Verify you cannot call the commit() command once verification is
* started, after which it will just return true.
*/
auto verifyMock = CreateVerifyMock();
auto verifyMockPtr = reinterpret_cast<VerificationMock*>(verifyMock.get());
auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
blobs, data, std::move(verifyMock), CreateUpdateMock());
EXPECT_TRUE(handler->open(0, blobs::OpenFlags::write, verifyBlobId));
EXPECT_CALL(*verifyMockPtr, triggerVerification())
.WillRepeatedly(Return(true));
EXPECT_TRUE(handler->commit(0, {}));
EXPECT_TRUE(handler->commit(0, {}));
}
} // namespace ipmi_flash