blob: 27bd517c5ded5c455c138225809a622076472708 [file] [log] [blame]
Patrick Venture21be45a2018-11-06 12:08:52 -08001#include "firmware_handler.hpp"
Patrick Venturea78e39f2018-11-06 18:37:06 -08002#include "image_mock.hpp"
Patrick Venture1d66fe62019-06-03 14:57:27 -07003#include "triggerable_mock.hpp"
Patrick Venture7dad86f2019-05-17 08:52:20 -07004#include "util.hpp"
Patrick Venture21be45a2018-11-06 12:08:52 -08005
Patrick Venture52854622018-11-06 12:30:00 -08006#include <algorithm>
Patrick Venturea78e39f2018-11-06 18:37:06 -08007#include <vector>
Patrick Venture21be45a2018-11-06 12:08:52 -08008
9#include <gtest/gtest.h>
10
Patrick Venture1d5a31c2019-05-20 11:38:22 -070011namespace ipmi_flash
Patrick Venture21be45a2018-11-06 12:08:52 -080012{
Patrick Venture930c7b72019-05-24 11:11:08 -070013namespace
14{
15
16using ::testing::UnorderedElementsAreArray;
Patrick Venture52854622018-11-06 12:30:00 -080017
18TEST(FirmwareHandlerTest, CreateEmptyListVerifyFails)
Patrick Venture21be45a2018-11-06 12:08:52 -080019{
Patrick Venture1cde5f92018-11-07 08:26:47 -080020 std::vector<DataHandlerPack> data = {
Patrick Venture05abf7e2018-11-09 11:02:56 -080021 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
Patrick Venture1cde5f92018-11-07 08:26:47 -080022 };
23
Patrick Venture4eb55952018-11-16 15:36:24 -080024 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture6d7735d2019-06-21 10:03:19 -070025 {}, data, CreateTriggerMock(), CreateTriggerMock(),
26 CreateTriggerMock());
Patrick Venture1cde5f92018-11-07 08:26:47 -080027 EXPECT_EQ(handler, nullptr);
28}
29TEST(FirmwareHandlerTest, CreateEmptyDataHandlerListFails)
30{
31 ImageHandlerMock imageMock;
32
33 std::vector<HandlerPack> blobs = {
Patrick Venture7dad86f2019-05-17 08:52:20 -070034 {hashBlobId, &imageMock},
Patrick Venture1cde5f92018-11-07 08:26:47 -080035 {"asdf", &imageMock},
36 };
37
Patrick Venture4eb55952018-11-16 15:36:24 -080038 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture6d7735d2019-06-21 10:03:19 -070039 blobs, {}, CreateTriggerMock(), CreateTriggerMock(),
40 CreateTriggerMock());
Patrick Venture52854622018-11-06 12:30:00 -080041 EXPECT_EQ(handler, nullptr);
42}
Patrick Venture18235e62018-11-08 10:21:09 -080043TEST(FirmwareHandlerTest, VerifyHashRequiredForHappiness)
Patrick Venture52854622018-11-06 12:30:00 -080044{
Patrick Venture18235e62018-11-08 10:21:09 -080045 /* This works fine only if you also pass in the hash handler. */
Patrick Venturea78e39f2018-11-06 18:37:06 -080046 ImageHandlerMock imageMock;
47
48 std::vector<HandlerPack> blobs = {
49 {"asdf", &imageMock},
50 };
Patrick Venture1cde5f92018-11-07 08:26:47 -080051 std::vector<DataHandlerPack> data = {
Patrick Venture05abf7e2018-11-09 11:02:56 -080052 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
Patrick Venture1cde5f92018-11-07 08:26:47 -080053 };
Patrick Venturea78e39f2018-11-06 18:37:06 -080054
Patrick Venture4eb55952018-11-16 15:36:24 -080055 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture6d7735d2019-06-21 10:03:19 -070056 blobs, data, CreateTriggerMock(), CreateTriggerMock(),
57 CreateTriggerMock());
Patrick Venture18235e62018-11-08 10:21:09 -080058 EXPECT_EQ(handler, nullptr);
59
Patrick Venture7dad86f2019-05-17 08:52:20 -070060 blobs.push_back({hashBlobId, &imageMock});
Patrick Venture18235e62018-11-08 10:21:09 -080061
Patrick Venture4eb55952018-11-16 15:36:24 -080062 handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture6d7735d2019-06-21 10:03:19 -070063 blobs, data, CreateTriggerMock(), CreateTriggerMock(),
64 CreateTriggerMock());
Patrick Venture21be45a2018-11-06 12:08:52 -080065 auto result = handler->getBlobIds();
Patrick Venture930c7b72019-05-24 11:11:08 -070066 std::vector<std::string> expectedBlobs = {"asdf", hashBlobId};
67 EXPECT_THAT(result, UnorderedElementsAreArray(expectedBlobs));
Patrick Venture21be45a2018-11-06 12:08:52 -080068}
Patrick Venture930c7b72019-05-24 11:11:08 -070069
70} // namespace
Patrick Venture1d5a31c2019-05-20 11:38:22 -070071} // namespace ipmi_flash