blob: 75eab406148693eb646ed5e4d7c0da47b8312734 [file] [log] [blame]
Patrick Venture18235e62018-11-08 10:21:09 -08001#include "data_mock.hpp"
2#include "firmware_handler.hpp"
3#include "image_mock.hpp"
Patrick Venture7dad86f2019-05-17 08:52:20 -07004#include "util.hpp"
Patrick Venture18235e62018-11-08 10:21:09 -08005
6#include <cstdint>
7#include <cstring>
Patrick Venture4eb55952018-11-16 15:36:24 -08008#include <sdbusplus/test/sdbus_mock.hpp>
Patrick Venture18235e62018-11-08 10:21:09 -08009#include <vector>
10
11#include <gtest/gtest.h>
12
13namespace blobs
14{
Patrick Venture18235e62018-11-08 10:21:09 -080015using ::testing::Eq;
16using ::testing::Return;
17
18TEST(FirmwareHandlerWriteTest, DataTypeIpmiWriteSuccess)
19{
20 /* Verify if data type ipmi, it calls write with the bytes. */
21
22 ImageHandlerMock imageMock1, imageMock2;
23 std::vector<HandlerPack> blobs = {
Patrick Venture7dad86f2019-05-17 08:52:20 -070024 {hashBlobId, &imageMock1},
Patrick Venture18235e62018-11-08 10:21:09 -080025 {"asdf", &imageMock2},
26 };
27
28 std::vector<DataHandlerPack> data = {
Patrick Venture05abf7e2018-11-09 11:02:56 -080029 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
Patrick Venture18235e62018-11-08 10:21:09 -080030 };
31
Patrick Venture4eb55952018-11-16 15:36:24 -080032 sdbusplus::SdBusMock sdbus_mock;
33 auto bus_mock = sdbusplus::get_mocked_new(&sdbus_mock);
34
35 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture74059d62019-05-17 10:40:26 -070036 std::move(bus_mock), blobs, data, "");
Patrick Venture18235e62018-11-08 10:21:09 -080037
38 EXPECT_CALL(imageMock2, open("asdf")).WillOnce(Return(true));
39
40 EXPECT_TRUE(handler->open(
Patrick Venture05abf7e2018-11-09 11:02:56 -080041 0, OpenFlags::write | FirmwareBlobHandler::UpdateFlags::ipmi, "asdf"));
Patrick Venture18235e62018-11-08 10:21:09 -080042
43 std::vector<std::uint8_t> bytes = {0xaa, 0x55};
44
45 EXPECT_CALL(imageMock2, write(0, Eq(bytes))).WillOnce(Return(true));
46 EXPECT_TRUE(handler->write(0, 0, bytes));
47}
48
49TEST(FirmwareHandlerWriteTest, DataTypeNonIpmiWriteSuccess)
50{
51 /* Verify if data type non-ipmi, it calls write with the length. */
52
53 ImageHandlerMock imageMock1, imageMock2;
54 std::vector<HandlerPack> blobs = {
Patrick Venture7dad86f2019-05-17 08:52:20 -070055 {hashBlobId, &imageMock1},
Patrick Venture18235e62018-11-08 10:21:09 -080056 {"asdf", &imageMock2},
57 };
58
59 DataHandlerMock dataMock;
60
61 std::vector<DataHandlerPack> data = {
Patrick Venture05abf7e2018-11-09 11:02:56 -080062 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
63 {FirmwareBlobHandler::UpdateFlags::lpc, &dataMock},
Patrick Venture18235e62018-11-08 10:21:09 -080064 };
65
Patrick Venture4eb55952018-11-16 15:36:24 -080066 sdbusplus::SdBusMock sdbus_mock;
67 auto bus_mock = sdbusplus::get_mocked_new(&sdbus_mock);
68
69 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture74059d62019-05-17 10:40:26 -070070 std::move(bus_mock), blobs, data, "");
Patrick Venture18235e62018-11-08 10:21:09 -080071
Patrick Venture6e307a72018-11-09 18:21:17 -080072 EXPECT_CALL(dataMock, open()).WillOnce(Return(true));
Patrick Venture18235e62018-11-08 10:21:09 -080073 EXPECT_CALL(imageMock2, open("asdf")).WillOnce(Return(true));
74
75 EXPECT_TRUE(handler->open(
Patrick Venture05abf7e2018-11-09 11:02:56 -080076 0, OpenFlags::write | FirmwareBlobHandler::UpdateFlags::lpc, "asdf"));
Patrick Venture18235e62018-11-08 10:21:09 -080077
78 struct ExtChunkHdr request;
79 request.length = 4; /* number of bytes to read. */
80 std::vector<std::uint8_t> ipmiRequest;
81 ipmiRequest.resize(sizeof(request));
82 std::memcpy(ipmiRequest.data(), &request, sizeof(request));
83
84 std::vector<std::uint8_t> bytes = {0x01, 0x02, 0x03, 0x04};
85
86 EXPECT_CALL(dataMock, copyFrom(request.length)).WillOnce(Return(bytes));
87 EXPECT_CALL(imageMock2, write(0, Eq(bytes))).WillOnce(Return(true));
88 EXPECT_TRUE(handler->write(0, 0, ipmiRequest));
89}
90
91TEST(FirmwareHandlerWriteTest, DataTypeNonIpmiWriteFailsBadRequest)
92{
93 /* Verify the data type non-ipmi, if the request's structure doesn't match,
94 * return failure. */
95
96 ImageHandlerMock imageMock1, imageMock2;
97 std::vector<HandlerPack> blobs = {
Patrick Venture7dad86f2019-05-17 08:52:20 -070098 {hashBlobId, &imageMock1},
Patrick Venture18235e62018-11-08 10:21:09 -080099 {"asdf", &imageMock2},
100 };
101
102 DataHandlerMock dataMock;
103
104 std::vector<DataHandlerPack> data = {
Patrick Venture05abf7e2018-11-09 11:02:56 -0800105 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
106 {FirmwareBlobHandler::UpdateFlags::lpc, &dataMock},
Patrick Venture18235e62018-11-08 10:21:09 -0800107 };
108
Patrick Venture4eb55952018-11-16 15:36:24 -0800109 sdbusplus::SdBusMock sdbus_mock;
110 auto bus_mock = sdbusplus::get_mocked_new(&sdbus_mock);
111
112 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture74059d62019-05-17 10:40:26 -0700113 std::move(bus_mock), blobs, data, "");
Patrick Venture18235e62018-11-08 10:21:09 -0800114
Patrick Venture6e307a72018-11-09 18:21:17 -0800115 EXPECT_CALL(dataMock, open()).WillOnce(Return(true));
Patrick Venture18235e62018-11-08 10:21:09 -0800116 EXPECT_CALL(imageMock2, open("asdf")).WillOnce(Return(true));
117
118 EXPECT_TRUE(handler->open(
Patrick Venture05abf7e2018-11-09 11:02:56 -0800119 0, OpenFlags::write | FirmwareBlobHandler::UpdateFlags::lpc, "asdf"));
Patrick Venture18235e62018-11-08 10:21:09 -0800120
121 struct ExtChunkHdr request;
122 request.length = 4; /* number of bytes to read. */
123
124 std::vector<std::uint8_t> ipmiRequest;
125 ipmiRequest.resize(sizeof(request));
126 std::memcpy(ipmiRequest.data(), &request, sizeof(request));
127 ipmiRequest.push_back(1);
128
129 /* ipmiRequest is too large by one byte. */
130 EXPECT_FALSE(handler->write(0, 0, ipmiRequest));
131}
132
133} // namespace blobs