blob: b886a01db07f04abc2f5f73b5de9e0f2cd832488 [file] [log] [blame]
Patrick Venture21be45a2018-11-06 12:08:52 -08001#include "firmware_handler.hpp"
Patrick Venture84778b82019-06-26 20:11:09 -07002#include "flags.hpp"
Patrick Venturea78e39f2018-11-06 18:37:06 -08003#include "image_mock.hpp"
Patrick Venture1d66fe62019-06-03 14:57:27 -07004#include "triggerable_mock.hpp"
Patrick Venture7dad86f2019-05-17 08:52:20 -07005#include "util.hpp"
Patrick Venture21be45a2018-11-06 12:08:52 -08006
Patrick Venture52854622018-11-06 12:30:00 -08007#include <algorithm>
Patrick Ventured4e20de2019-07-18 12:48:05 -07008#include <memory>
Patrick Venturea78e39f2018-11-06 18:37:06 -08009#include <vector>
Patrick Venture21be45a2018-11-06 12:08:52 -080010
11#include <gtest/gtest.h>
12
Patrick Venture1d5a31c2019-05-20 11:38:22 -070013namespace ipmi_flash
Patrick Venture21be45a2018-11-06 12:08:52 -080014{
Patrick Venture930c7b72019-05-24 11:11:08 -070015namespace
16{
17
18using ::testing::UnorderedElementsAreArray;
Patrick Venture52854622018-11-06 12:30:00 -080019
Patrick Venture16265382019-11-06 19:31:36 -080020TEST(FirmwareHandlerTest, CreateEmptyHandlerListVerifyFails)
Patrick Venture21be45a2018-11-06 12:08:52 -080021{
Patrick Venture4934daa2020-09-22 16:37:44 -070022 std::vector<DataHandlerPack> data;
23 data.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
Patrick Venture1cde5f92018-11-07 08:26:47 -080024
Patrick Venture4eb55952018-11-16 15:36:24 -080025 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture7b783432020-09-22 15:55:08 -070026 {}, std::move(data), std::move(CreateActionMap("abcd")));
Patrick Venture1cde5f92018-11-07 08:26:47 -080027 EXPECT_EQ(handler, nullptr);
28}
29TEST(FirmwareHandlerTest, CreateEmptyDataHandlerListFails)
30{
31 ImageHandlerMock imageMock;
32
Patrick Ventured4e20de2019-07-18 12:48:05 -070033 std::vector<HandlerPack> blobs;
34 blobs.push_back(std::move(
35 HandlerPack(hashBlobId, std::make_unique<ImageHandlerMock>())));
36 blobs.push_back(
37 std::move(HandlerPack("asdf", std::make_unique<ImageHandlerMock>())));
Patrick Venture1cde5f92018-11-07 08:26:47 -080038
Patrick Venture4eb55952018-11-16 15:36:24 -080039 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture7b783432020-09-22 15:55:08 -070040 std::move(blobs), std::move(std::vector<DataHandlerPack>()),
41 std::move(CreateActionMap("asdf")));
Patrick Venture52854622018-11-06 12:30:00 -080042 EXPECT_EQ(handler, nullptr);
43}
Patrick Venture16265382019-11-06 19:31:36 -080044TEST(FirmwareHandlerTest, CreateEmptyActionPackVerifyFails)
45{
46 /* The ActionPack map corresponds to the firmware list passed in, but
47 * they're not checked against each other yet.
48 */
Patrick Venture4934daa2020-09-22 16:37:44 -070049 std::vector<DataHandlerPack> data;
50 data.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
Patrick Venture16265382019-11-06 19:31:36 -080051
52 std::vector<HandlerPack> blobs;
53 blobs.push_back(
54 std::move(HandlerPack("asdf", std::make_unique<ImageHandlerMock>())));
55 blobs.push_back(std::move(
56 HandlerPack(hashBlobId, std::make_unique<ImageHandlerMock>())));
57
58 ActionMap emptyMap;
59
60 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture7b783432020-09-22 15:55:08 -070061 std::move(blobs), std::move(data), std::move(emptyMap));
Patrick Venture16265382019-11-06 19:31:36 -080062 EXPECT_EQ(handler, nullptr);
63}
64TEST(FirmwareHandlerTest, FirmwareHandlerListRequiresAtLeastTwoEntries)
65{
66 /* The hashblob handler must be one of the entries, but it cannot be the
67 * only entry.
68 */
Patrick Venture4934daa2020-09-22 16:37:44 -070069 std::vector<DataHandlerPack> data;
70 data.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
Patrick Venture16265382019-11-06 19:31:36 -080071
72 /* Provide a firmware list that has the hash blob, which is the required one
73 * -- tested in a different test.
74 */
75 std::vector<HandlerPack> blobs;
76 blobs.push_back(std::move(
77 HandlerPack(hashBlobId, std::make_unique<ImageHandlerMock>())));
78
79 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture7b783432020-09-22 15:55:08 -070080 std::move(blobs), std::move(data), std::move(CreateActionMap("asdf")));
Patrick Venture16265382019-11-06 19:31:36 -080081 EXPECT_EQ(handler, nullptr);
82
83 /* Add second firmware and it'll now work. */
84 std::vector<HandlerPack> blobs2;
85 blobs2.push_back(std::move(
86 HandlerPack(hashBlobId, std::make_unique<ImageHandlerMock>())));
87 blobs2.push_back(
88 std::move(HandlerPack("asdf", std::make_unique<ImageHandlerMock>())));
89
Patrick Venture4934daa2020-09-22 16:37:44 -070090 std::vector<DataHandlerPack> data2;
91 data2.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
92
Patrick Venture16265382019-11-06 19:31:36 -080093 handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture4934daa2020-09-22 16:37:44 -070094 std::move(blobs2), std::move(data2),
95 std::move(CreateActionMap("asdf")));
Patrick Venture16265382019-11-06 19:31:36 -080096
97 auto result = handler->getBlobIds();
98 std::vector<std::string> expectedBlobs = {"asdf", hashBlobId};
99 EXPECT_THAT(result, UnorderedElementsAreArray(expectedBlobs));
100}
Patrick Venture18235e62018-11-08 10:21:09 -0800101TEST(FirmwareHandlerTest, VerifyHashRequiredForHappiness)
Patrick Venture52854622018-11-06 12:30:00 -0800102{
Patrick Venture4934daa2020-09-22 16:37:44 -0700103 std::vector<DataHandlerPack> data;
104 data.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
Patrick Venturea78e39f2018-11-06 18:37:06 -0800105
Patrick Ventured4e20de2019-07-18 12:48:05 -0700106 /* This works fine only if you also pass in the hash handler. */
107 std::vector<HandlerPack> blobs;
108 blobs.push_back(
109 std::move(HandlerPack("asdf", std::make_unique<ImageHandlerMock>())));
110
Patrick Venture4eb55952018-11-16 15:36:24 -0800111 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture7b783432020-09-22 15:55:08 -0700112 std::move(blobs), std::move(data), std::move(CreateActionMap("asdf")));
Patrick Venture18235e62018-11-08 10:21:09 -0800113 EXPECT_EQ(handler, nullptr);
114
Patrick Ventured4e20de2019-07-18 12:48:05 -0700115 std::vector<HandlerPack> blobs2;
116 blobs2.push_back(
117 std::move(HandlerPack("asdf", std::make_unique<ImageHandlerMock>())));
118 blobs2.push_back(std::move(
119 HandlerPack(hashBlobId, std::make_unique<ImageHandlerMock>())));
Patrick Venture18235e62018-11-08 10:21:09 -0800120
Patrick Venture4934daa2020-09-22 16:37:44 -0700121 std::vector<DataHandlerPack> data2;
122 data2.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
123
Patrick Venture4eb55952018-11-16 15:36:24 -0800124 handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture4934daa2020-09-22 16:37:44 -0700125 std::move(blobs2), std::move(data2),
126 std::move(CreateActionMap("asdf")));
Patrick Venturefa06a5f2019-07-01 09:22:38 -0700127
Patrick Venture21be45a2018-11-06 12:08:52 -0800128 auto result = handler->getBlobIds();
Patrick Venture930c7b72019-05-24 11:11:08 -0700129 std::vector<std::string> expectedBlobs = {"asdf", hashBlobId};
130 EXPECT_THAT(result, UnorderedElementsAreArray(expectedBlobs));
Patrick Venture21be45a2018-11-06 12:08:52 -0800131}
Patrick Venture930c7b72019-05-24 11:11:08 -0700132
133} // namespace
Patrick Venture1d5a31c2019-05-20 11:38:22 -0700134} // namespace ipmi_flash