blob: 03ceb9951703c201aaf13e4f495d4bab34c82f02 [file] [log] [blame]
Patrick Venture237e2c62019-05-23 20:35:33 -07001/* The goal of these tests is to verify the behavior of all blob commands given
2 * the current state is verificationStarted. This state is achieved as a out of
3 * verificationPending.
4 */
5#include "firmware_handler.hpp"
6#include "firmware_unittest.hpp"
7#include "status.hpp"
8#include "util.hpp"
9
10#include <cstdint>
11#include <string>
12#include <vector>
13
14#include <gtest/gtest.h>
15
16namespace ipmi_flash
17{
18namespace
19{
20
Patrick Venture8facb382019-05-24 15:27:36 -070021using ::testing::IsEmpty;
Patrick Venture237e2c62019-05-23 20:35:33 -070022using ::testing::Return;
Patrick Venture2c014152019-05-28 18:16:05 -070023using ::testing::UnorderedElementsAreArray;
Patrick Venture237e2c62019-05-23 20:35:33 -070024
25/*
26 * There are the following calls (parameters may vary):
27 * canHandleBlob(blob)
28 * getBlobIds
29 * deleteBlob(blob)
30 * stat(blob)
31 * stat(session)
32 * open(blob)
33 * close(session)
34 * writemeta(session)
35 * write(session)
36 * read(session)
37 * commit(session)
38 *
39 * Testing canHandleBlob is uninteresting in this state. Getting the BlobIDs
40 * will inform what canHandleBlob will return.
41 */
42
43class FirmwareHandlerVerificationStartedTest : public IpmiOnlyFirmwareStaticTest
44{
Patrick Venture237e2c62019-05-23 20:35:33 -070045};
46
47/*
Patrick Venture2c014152019-05-28 18:16:05 -070048 * canHandleBlob(blob)
49 * getBlobIds()
50 */
51TEST_F(FirmwareHandlerVerificationStartedTest, GetBlobIdsReturnsExpectedList)
52{
53 getToVerificationStarted(staticLayoutBlobId);
54
55 std::vector<std::string> expectedList = {
56 activeImageBlobId, staticLayoutBlobId, hashBlobId, verifyBlobId};
57
58 EXPECT_THAT(handler->getBlobIds(), UnorderedElementsAreArray(expectedList));
59
60 for (const auto& blob : expectedList)
61 {
62 EXPECT_TRUE(handler->canHandleBlob(blob));
63 }
64}
65
66/*
Patrick Venture237e2c62019-05-23 20:35:33 -070067 * stat(session)
68 */
69TEST_F(FirmwareHandlerVerificationStartedTest,
70 StatOnVerifyBlobIdAfterCommitChecksStateAndReturnsRunning)
71{
72 getToVerificationStarted(staticLayoutBlobId);
Patrick Venturef1f0f652019-06-03 09:10:19 -070073 EXPECT_CALL(*verifyMockPtr, status())
Patrick Ventureda66fd82019-06-03 11:11:24 -070074 .WillOnce(Return(ActionStatus::running));
Patrick Venture237e2c62019-05-23 20:35:33 -070075
76 blobs::BlobMeta meta, expectedMeta = {};
77 expectedMeta.size = 0;
78 expectedMeta.blobState = flags | blobs::StateFlags::committing;
79 expectedMeta.metadata.push_back(
Patrick Ventureda66fd82019-06-03 11:11:24 -070080 static_cast<std::uint8_t>(ActionStatus::running));
Patrick Venture237e2c62019-05-23 20:35:33 -070081
82 EXPECT_TRUE(handler->stat(session, &meta));
83 EXPECT_EQ(expectedMeta, meta);
84}
85
86TEST_F(FirmwareHandlerVerificationStartedTest,
Patrick Ventured52c2c32019-05-30 09:54:35 -070087 StatOnVerifyBlobIdAfterCommitChecksStateAndReturnsOther)
88{
89 getToVerificationStarted(staticLayoutBlobId);
Patrick Venturef1f0f652019-06-03 09:10:19 -070090 EXPECT_CALL(*verifyMockPtr, status())
Patrick Ventureda66fd82019-06-03 11:11:24 -070091 .WillOnce(Return(ActionStatus::unknown));
Patrick Ventured52c2c32019-05-30 09:54:35 -070092
93 blobs::BlobMeta meta, expectedMeta = {};
94 expectedMeta.size = 0;
95 expectedMeta.blobState = flags | blobs::StateFlags::committing;
96 expectedMeta.metadata.push_back(
Patrick Ventureda66fd82019-06-03 11:11:24 -070097 static_cast<std::uint8_t>(ActionStatus::unknown));
Patrick Ventured52c2c32019-05-30 09:54:35 -070098
99 EXPECT_TRUE(handler->stat(session, &meta));
100 EXPECT_EQ(expectedMeta, meta);
101}
102
103TEST_F(FirmwareHandlerVerificationStartedTest,
Patrick Venture237e2c62019-05-23 20:35:33 -0700104 StatOnVerifyBlobIdAfterCommitCheckStateAndReturnsFailed)
105{
106 /* If the returned state from the verification handler is failed, it sets
107 * commit_error and transitions to verificationCompleted.
108 */
109 getToVerificationStarted(staticLayoutBlobId);
Patrick Venturef1f0f652019-06-03 09:10:19 -0700110 EXPECT_CALL(*verifyMockPtr, status())
Patrick Ventureda66fd82019-06-03 11:11:24 -0700111 .WillOnce(Return(ActionStatus::failed));
Patrick Venture237e2c62019-05-23 20:35:33 -0700112
113 blobs::BlobMeta meta, expectedMeta = {};
114 expectedMeta.size = 0;
115 expectedMeta.blobState = flags | blobs::StateFlags::commit_error;
116 expectedMeta.metadata.push_back(
Patrick Ventureda66fd82019-06-03 11:11:24 -0700117 static_cast<std::uint8_t>(ActionStatus::failed));
Patrick Venture237e2c62019-05-23 20:35:33 -0700118
Patrick Venture237e2c62019-05-23 20:35:33 -0700119 EXPECT_TRUE(handler->stat(session, &meta));
120 EXPECT_EQ(expectedMeta, meta);
Patrick Venture6fdd02e2019-05-28 13:02:04 -0700121 expectedState(FirmwareBlobHandler::UpdateState::verificationCompleted);
Patrick Venture237e2c62019-05-23 20:35:33 -0700122}
123
124TEST_F(FirmwareHandlerVerificationStartedTest,
125 StatOnVerifyBlobIdAfterCommitCheckStateAndReturnsSuccess)
126{
127 /* If the returned state from the verification handler is success, it sets
128 * committed and transitions to verificationCompleted.
129 */
130 getToVerificationStarted(staticLayoutBlobId);
Patrick Venturef1f0f652019-06-03 09:10:19 -0700131 EXPECT_CALL(*verifyMockPtr, status())
Patrick Ventureda66fd82019-06-03 11:11:24 -0700132 .WillOnce(Return(ActionStatus::success));
Patrick Venture237e2c62019-05-23 20:35:33 -0700133
134 blobs::BlobMeta meta, expectedMeta = {};
135 expectedMeta.size = 0;
136 expectedMeta.blobState = flags | blobs::StateFlags::committed;
137 expectedMeta.metadata.push_back(
Patrick Ventureda66fd82019-06-03 11:11:24 -0700138 static_cast<std::uint8_t>(ActionStatus::success));
Patrick Venture237e2c62019-05-23 20:35:33 -0700139
Patrick Venture237e2c62019-05-23 20:35:33 -0700140 EXPECT_TRUE(handler->stat(session, &meta));
141 EXPECT_EQ(expectedMeta, meta);
Patrick Venture6fdd02e2019-05-28 13:02:04 -0700142 expectedState(FirmwareBlobHandler::UpdateState::verificationCompleted);
Patrick Venture237e2c62019-05-23 20:35:33 -0700143}
144
145/* TODO: Once verificationCompleted is the state, canHandleBlob should accept
146 * updateBlobId.
147 */
148
Patrick Venture2c014152019-05-28 18:16:05 -0700149/* TODO: deleteBlob(blob) */
Patrick Venturea04997b2019-05-24 10:15:48 -0700150
151/*
Patrick Venture237e2c62019-05-23 20:35:33 -0700152 * stat(blob)
Patrick Venturea04997b2019-05-24 10:15:48 -0700153 */
154TEST_F(FirmwareHandlerVerificationStartedTest, StatOnActiveImageReturnsFailure)
155{
156 getToVerificationStarted(staticLayoutBlobId);
Patrick Venture930c7b72019-05-24 11:11:08 -0700157 ASSERT_TRUE(handler->canHandleBlob(activeImageBlobId));
Patrick Venturea04997b2019-05-24 10:15:48 -0700158
159 blobs::BlobMeta meta;
160 EXPECT_FALSE(handler->stat(activeImageBlobId, &meta));
161}
162
163TEST_F(FirmwareHandlerVerificationStartedTest, StatOnActiveHashReturnsFailure)
164{
Patrick Venture930c7b72019-05-24 11:11:08 -0700165 getToVerificationStarted(hashBlobId);
166 ASSERT_TRUE(handler->canHandleBlob(activeHashBlobId));
Patrick Venturea04997b2019-05-24 10:15:48 -0700167
168 blobs::BlobMeta meta;
169 EXPECT_FALSE(handler->stat(activeHashBlobId, &meta));
170}
171
172TEST_F(FirmwareHandlerVerificationStartedTest, StatOnVerifyBlobReturnsFailure)
173{
174 /* the verifyBlobId is available starting at verificationPending. */
175 getToVerificationStarted(staticLayoutBlobId);
Patrick Venture930c7b72019-05-24 11:11:08 -0700176 ASSERT_TRUE(handler->canHandleBlob(verifyBlobId));
Patrick Venturea04997b2019-05-24 10:15:48 -0700177
178 blobs::BlobMeta meta;
179 EXPECT_FALSE(handler->stat(verifyBlobId, &meta));
180}
181
182TEST_F(FirmwareHandlerVerificationStartedTest, StatOnNormalBlobsReturnsSuccess)
183{
184 getToVerificationStarted(staticLayoutBlobId);
185
186 blobs::BlobMeta expected;
187 expected.blobState = FirmwareBlobHandler::UpdateFlags::ipmi;
188 expected.size = 0;
189
190 std::vector<std::string> testBlobs = {staticLayoutBlobId, hashBlobId};
191 for (const auto& blob : testBlobs)
192 {
Patrick Venture930c7b72019-05-24 11:11:08 -0700193 ASSERT_TRUE(handler->canHandleBlob(blob));
194
Patrick Venturea04997b2019-05-24 10:15:48 -0700195 blobs::BlobMeta meta = {};
196 EXPECT_TRUE(handler->stat(blob, &meta));
197 EXPECT_EQ(expected, meta);
198 }
199}
200
201/*
Patrick Venturefb74ad52019-05-24 15:03:35 -0700202 * writemeta(session)
203 */
204TEST_F(FirmwareHandlerVerificationStartedTest,
205 WriteMetaOnVerifySessionReturnsFailure)
206{
207 getToVerificationStarted(staticLayoutBlobId);
208
209 std::vector<std::uint8_t> bytes = {0x01, 0x02};
210 EXPECT_FALSE(handler->writeMeta(session, 0, bytes));
211}
212
213/*
214 * write(session)
215 */
Patrick Venture9c6de5a2019-05-24 15:12:26 -0700216TEST_F(FirmwareHandlerVerificationStartedTest,
217 WriteOnVerifySessionReturnsFailure)
218{
219 getToVerificationStarted(staticLayoutBlobId);
220
221 std::vector<std::uint8_t> bytes = {0x01, 0x02};
222 EXPECT_FALSE(handler->write(session, 0, bytes));
223}
Patrick Venturefb74ad52019-05-24 15:03:35 -0700224
225/*
Patrick Venture237e2c62019-05-23 20:35:33 -0700226 * open(blob) - there is nothing you can open, this state has an open file.
Patrick Ventured4509102019-05-24 15:22:04 -0700227 */
228TEST_F(FirmwareHandlerVerificationStartedTest,
229 AttemptToOpenImageFileReturnsFailure)
230{
231 /* Attempt to open a file one normally can open, however, as there is
232 * already a file open, this will fail.
233 */
234 getToVerificationStarted(staticLayoutBlobId);
235
Patrick Venture2c014152019-05-28 18:16:05 -0700236 auto blobsToOpen = handler->getBlobIds();
237 for (const auto& blob : blobsToOpen)
238 {
239 EXPECT_FALSE(handler->open(session + 1, flags, blob));
240 }
Patrick Ventured4509102019-05-24 15:22:04 -0700241}
242
243/*
Patrick Venture8facb382019-05-24 15:27:36 -0700244 * read(session)
245 */
246TEST_F(FirmwareHandlerVerificationStartedTest, ReadOfVerifyBlobReturnsEmpty)
247{
248 getToVerificationStarted(staticLayoutBlobId);
Patrick Venture2c014152019-05-28 18:16:05 -0700249 EXPECT_THAT(handler->read(session, 0, 1), IsEmpty());
Patrick Venture8facb382019-05-24 15:27:36 -0700250}
251
252/*
Patrick Ventureddc35072019-05-24 15:30:57 -0700253 * commit(session)
254 */
255TEST_F(FirmwareHandlerVerificationStartedTest,
256 CommitOnVerifyDuringVerificationHasNoImpact)
257{
258 getToVerificationStarted(staticLayoutBlobId);
259 EXPECT_TRUE(handler->commit(session, {}));
Patrick Venture6fdd02e2019-05-28 13:02:04 -0700260 expectedState(FirmwareBlobHandler::UpdateState::verificationStarted);
Patrick Ventureddc35072019-05-24 15:30:57 -0700261}
262
263/*
Patrick Venturea04997b2019-05-24 10:15:48 -0700264 * close(session) - close while state if verificationStarted without calling
265 * stat first will abort.
Patrick Venture35b3fc92019-05-24 15:36:01 -0700266 * TODO: implement this test when we implement abort.
Patrick Venture237e2c62019-05-23 20:35:33 -0700267 */
268
269} // namespace
270} // namespace ipmi_flash