blob: 448287b00c626ccfa5c82fb88da1b727ac3522af [file] [log] [blame]
#include "flash-ipmi.hpp"
#include "ipmi.hpp"
#include "updater_mock.hpp"
#include <cstring>
#include <gtest/gtest.h>
using ::testing::NotNull;
using ::testing::Return;
using ::testing::StrictMock;
// ipmid.hpp isn't installed where we can grab it and this value is per BMC
// SoC.
#define MAX_IPMI_BUFFER 64
#define THIRTYTWO_MIB 33554432
TEST(IpmiStartTransferTest, InvalidRequestLengthReturnsFailure)
{
// Verify that the request is sanity checked w.r.t length.
StrictMock<UpdaterMock> updater;
size_t dataLen;
uint8_t request[MAX_IPMI_BUFFER] = {0};
uint8_t reply[MAX_IPMI_BUFFER] = {0};
struct StartTx tx;
tx.cmd = FlashSubCmds::flashStartTransfer;
tx.length = THIRTYTWO_MIB;
std::memcpy(request, &tx, sizeof(tx));
dataLen = sizeof(tx) - 1; // It's too small to be a valid packet.
EXPECT_EQ(IPMI_CC_INVALID,
startTransfer(&updater, request, reply, &dataLen));
}
TEST(IpmiStartTransferTest, ValidRequestBoringCase)
{
// Verify that if the request is valid it calls into the flash updater.
StrictMock<UpdaterMock> updater;
size_t dataLen;
uint8_t request[MAX_IPMI_BUFFER] = {0};
uint8_t reply[MAX_IPMI_BUFFER] = {0};
struct StartTx tx;
tx.cmd = FlashSubCmds::flashStartTransfer;
tx.length = THIRTYTWO_MIB;
std::memcpy(request, &tx, sizeof(tx));
dataLen = sizeof(tx);
EXPECT_CALL(updater, start(THIRTYTWO_MIB)).WillOnce(Return(true));
EXPECT_EQ(IPMI_CC_OK, startTransfer(&updater, request, reply, &dataLen));
EXPECT_EQ(sizeof(uint8_t), dataLen);
EXPECT_EQ(0, reply[0]);
}