blob: 975bd74b89f498a76a533e4ebb846e1bd543912a [file] [log] [blame]
Manojkiran Eda9a8e4972022-11-28 16:38:21 +05301#include <endian.h>
Andrew Jeffery9c766792022-08-10 23:12:49 +09302
3#include <array>
Manojkiran Eda9a8e4972022-11-28 16:38:21 +05304#include <cstdint>
Andrew Jeffery5a706072023-04-05 19:45:31 +09305#include <cstring>
Manojkiran Eda9a8e4972022-11-28 16:38:21 +05306#include <vector>
Andrew Jeffery9c766792022-08-10 23:12:49 +09307
8#include "libpldm/base.h"
Andrew Jeffery7992eb82023-04-06 16:13:53 +09309#include "libpldm/entity.h"
Andrew Jeffery9c766792022-08-10 23:12:49 +093010#include "libpldm/platform.h"
Manojkiran Eda9a8e4972022-11-28 16:38:21 +053011#include "pldm_types.h"
Andrew Jeffery9c766792022-08-10 23:12:49 +093012
13#include <gtest/gtest.h>
14
15constexpr auto hdrSize = sizeof(pldm_msg_hdr);
16
17TEST(SetStateEffecterStates, testEncodeResponse)
18{
19 std::array<uint8_t,
20 sizeof(pldm_msg_hdr) + PLDM_SET_STATE_EFFECTER_STATES_RESP_BYTES>
21 responseMsg{};
22 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
23 uint8_t completionCode = 0;
24
25 auto rc = encode_set_state_effecter_states_resp(0, PLDM_SUCCESS, response);
26
27 EXPECT_EQ(rc, PLDM_SUCCESS);
28 EXPECT_EQ(completionCode, response->payload[0]);
29}
30
31TEST(SetStateEffecterStates, testEncodeRequest)
32{
33 std::array<uint8_t,
34 sizeof(pldm_msg_hdr) + PLDM_SET_STATE_EFFECTER_STATES_REQ_BYTES>
35 requestMsg{};
36 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
37
38 uint16_t effecterId = 0x0A;
39 uint8_t compEffecterCnt = 0x2;
40 std::array<set_effecter_state_field, 8> stateField{};
41 stateField[0] = {PLDM_REQUEST_SET, 2};
42 stateField[1] = {PLDM_REQUEST_SET, 3};
43
44 auto rc = encode_set_state_effecter_states_req(
45 0, effecterId, compEffecterCnt, stateField.data(), request);
46
47 EXPECT_EQ(rc, PLDM_SUCCESS);
48 EXPECT_EQ(effecterId, request->payload[0]);
49 EXPECT_EQ(compEffecterCnt, request->payload[sizeof(effecterId)]);
50 EXPECT_EQ(stateField[0].set_request,
51 request->payload[sizeof(effecterId) + sizeof(compEffecterCnt)]);
52 EXPECT_EQ(stateField[0].effecter_state,
53 request->payload[sizeof(effecterId) + sizeof(compEffecterCnt) +
54 sizeof(stateField[0].set_request)]);
55 EXPECT_EQ(stateField[1].set_request,
56 request->payload[sizeof(effecterId) + sizeof(compEffecterCnt) +
57 sizeof(stateField[0])]);
58 EXPECT_EQ(stateField[1].effecter_state,
59 request->payload[sizeof(effecterId) + sizeof(compEffecterCnt) +
60 sizeof(stateField[0]) +
61 sizeof(stateField[1].set_request)]);
62}
63
64TEST(SetStateEffecterStates, testGoodDecodeResponse)
65{
66 std::array<uint8_t, hdrSize + PLDM_SET_STATE_EFFECTER_STATES_RESP_BYTES>
67 responseMsg{};
68
69 uint8_t retcompletion_code = 0;
70
71 responseMsg[hdrSize] = PLDM_SUCCESS;
72
73 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
74
75 auto rc = decode_set_state_effecter_states_resp(
76 response, responseMsg.size() - hdrSize, &retcompletion_code);
77
78 EXPECT_EQ(rc, PLDM_SUCCESS);
79 EXPECT_EQ(PLDM_SUCCESS, retcompletion_code);
80}
81
82TEST(SetStateEffecterStates, testGoodDecodeRequest)
83{
84 std::array<uint8_t, hdrSize + PLDM_SET_STATE_EFFECTER_STATES_REQ_BYTES>
85 requestMsg{};
86
87 uint16_t effecterId = 0x32;
88 uint16_t effecterIdLE = htole16(effecterId);
89 uint8_t compEffecterCnt = 0x2;
90
91 std::array<set_effecter_state_field, 8> stateField{};
92 stateField[0] = {PLDM_REQUEST_SET, 3};
93 stateField[1] = {PLDM_REQUEST_SET, 4};
94
95 uint16_t retEffecterId = 0;
96 uint8_t retCompEffecterCnt = 0;
97
98 std::array<set_effecter_state_field, 8> retStateField{};
99
100 memcpy(requestMsg.data() + hdrSize, &effecterIdLE, sizeof(effecterIdLE));
101 memcpy(requestMsg.data() + sizeof(effecterIdLE) + hdrSize, &compEffecterCnt,
102 sizeof(compEffecterCnt));
103 memcpy(requestMsg.data() + sizeof(effecterIdLE) + sizeof(compEffecterCnt) +
104 hdrSize,
105 &stateField, sizeof(stateField));
106
107 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
108
109 auto rc = decode_set_state_effecter_states_req(
110 request, requestMsg.size() - hdrSize, &retEffecterId,
111 &retCompEffecterCnt, retStateField.data());
112
113 EXPECT_EQ(rc, PLDM_SUCCESS);
114 EXPECT_EQ(effecterId, retEffecterId);
115 EXPECT_EQ(retCompEffecterCnt, compEffecterCnt);
116 EXPECT_EQ(retStateField[0].set_request, stateField[0].set_request);
117 EXPECT_EQ(retStateField[0].effecter_state, stateField[0].effecter_state);
118 EXPECT_EQ(retStateField[1].set_request, stateField[1].set_request);
119 EXPECT_EQ(retStateField[1].effecter_state, stateField[1].effecter_state);
120}
121
122TEST(SetStateEffecterStates, testBadDecodeRequest)
123{
124 const struct pldm_msg* msg = NULL;
125
126 auto rc = decode_set_state_effecter_states_req(msg, sizeof(*msg), NULL,
127 NULL, NULL);
128
129 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
130}
131
132TEST(SetStateEffecterStates, testBadDecodeResponse)
133{
134 std::array<uint8_t, PLDM_SET_STATE_EFFECTER_STATES_RESP_BYTES>
135 responseMsg{};
136
137 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
138
139 auto rc = decode_set_state_effecter_states_resp(response,
140 responseMsg.size(), NULL);
141
142 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
143}
144
145TEST(GetPDR, testGoodEncodeResponse)
146{
147 uint8_t completionCode = 0;
148 uint32_t nextRecordHndl = 0x12;
149 uint32_t nextDataTransferHndl = 0x13;
150 uint8_t transferFlag = PLDM_END;
151 uint16_t respCnt = 0x5;
152 std::vector<uint8_t> recordData{1, 2, 3, 4, 5};
153 uint8_t transferCRC = 6;
154
155 // + size of record data and transfer CRC
156 std::vector<uint8_t> responseMsg(hdrSize + PLDM_GET_PDR_MIN_RESP_BYTES +
157 recordData.size() + 1);
158 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
159
160 auto rc = encode_get_pdr_resp(0, PLDM_SUCCESS, nextRecordHndl,
161 nextDataTransferHndl, transferFlag, respCnt,
162 recordData.data(), transferCRC, response);
163
164 EXPECT_EQ(rc, PLDM_SUCCESS);
165 struct pldm_get_pdr_resp* resp =
166 reinterpret_cast<struct pldm_get_pdr_resp*>(response->payload);
167
168 EXPECT_EQ(completionCode, resp->completion_code);
169 EXPECT_EQ(nextRecordHndl, le32toh(resp->next_record_handle));
170 EXPECT_EQ(nextDataTransferHndl, le32toh(resp->next_data_transfer_handle));
171 EXPECT_EQ(transferFlag, resp->transfer_flag);
172 EXPECT_EQ(respCnt, le16toh(resp->response_count));
173 EXPECT_EQ(0,
174 memcmp(recordData.data(), resp->record_data, recordData.size()));
175 EXPECT_EQ(*(response->payload + sizeof(pldm_get_pdr_resp) - 1 +
176 recordData.size()),
177 transferCRC);
178
179 transferFlag = PLDM_START_AND_END; // No CRC in this case
180 responseMsg.resize(responseMsg.size() - sizeof(transferCRC));
181 rc = encode_get_pdr_resp(0, PLDM_SUCCESS, nextRecordHndl,
182 nextDataTransferHndl, transferFlag, respCnt,
183 recordData.data(), transferCRC, response);
184 EXPECT_EQ(rc, PLDM_SUCCESS);
185}
186
187TEST(GetPDR, testBadEncodeResponse)
188{
189 uint32_t nextRecordHndl = 0x12;
190 uint32_t nextDataTransferHndl = 0x13;
191 uint8_t transferFlag = PLDM_START_AND_END;
192 uint16_t respCnt = 0x5;
193 std::vector<uint8_t> recordData{1, 2, 3, 4, 5};
194 uint8_t transferCRC = 0;
195
196 auto rc = encode_get_pdr_resp(0, PLDM_SUCCESS, nextRecordHndl,
197 nextDataTransferHndl, transferFlag, respCnt,
198 recordData.data(), transferCRC, nullptr);
199
200 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
201}
202
203TEST(GetPDR, testGoodDecodeRequest)
204{
205 std::array<uint8_t, hdrSize + PLDM_GET_PDR_REQ_BYTES> requestMsg{};
206
207 uint32_t recordHndl = 0x32;
208 uint32_t dataTransferHndl = 0x11;
209 uint8_t transferOpFlag = PLDM_GET_FIRSTPART;
210 uint16_t requestCnt = 0x5;
211 uint16_t recordChangeNum = 0x01;
212
213 uint32_t retRecordHndl = 0;
214 uint32_t retDataTransferHndl = 0;
215 uint8_t retTransferOpFlag = 0;
216 uint16_t retRequestCnt = 0;
217 uint16_t retRecordChangeNum = 0;
218
219 auto req = reinterpret_cast<pldm_msg*>(requestMsg.data());
220 struct pldm_get_pdr_req* request =
221 reinterpret_cast<struct pldm_get_pdr_req*>(req->payload);
222
223 request->record_handle = htole32(recordHndl);
224 request->data_transfer_handle = htole32(dataTransferHndl);
225 request->transfer_op_flag = transferOpFlag;
226 request->request_count = htole16(requestCnt);
227 request->record_change_number = htole16(recordChangeNum);
228
229 auto rc = decode_get_pdr_req(
230 req, requestMsg.size() - hdrSize, &retRecordHndl, &retDataTransferHndl,
231 &retTransferOpFlag, &retRequestCnt, &retRecordChangeNum);
232
233 EXPECT_EQ(rc, PLDM_SUCCESS);
234 EXPECT_EQ(retRecordHndl, recordHndl);
235 EXPECT_EQ(retDataTransferHndl, dataTransferHndl);
236 EXPECT_EQ(retTransferOpFlag, transferOpFlag);
237 EXPECT_EQ(retRequestCnt, requestCnt);
238 EXPECT_EQ(retRecordChangeNum, recordChangeNum);
239}
240
241TEST(GetPDR, testBadDecodeRequest)
242{
243 std::array<uint8_t, PLDM_GET_PDR_REQ_BYTES> requestMsg{};
244 auto req = reinterpret_cast<pldm_msg*>(requestMsg.data());
245
246 auto rc = decode_get_pdr_req(req, requestMsg.size(), NULL, NULL, NULL, NULL,
247 NULL);
248
249 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
250}
251
252TEST(GetPDR, testGoodEncodeRequest)
253{
254 uint32_t record_hndl = 0;
255 uint32_t data_transfer_hndl = 0;
256 uint8_t transfer_op_flag = PLDM_GET_FIRSTPART;
257 uint16_t request_cnt = 20;
258 uint16_t record_chg_num = 0;
259
260 std::vector<uint8_t> requestMsg(hdrSize + PLDM_GET_PDR_REQ_BYTES);
261 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
262
263 auto rc = encode_get_pdr_req(0, record_hndl, data_transfer_hndl,
264 transfer_op_flag, request_cnt, record_chg_num,
265 request, PLDM_GET_PDR_REQ_BYTES);
266 EXPECT_EQ(rc, PLDM_SUCCESS);
267 struct pldm_get_pdr_req* req =
268 reinterpret_cast<struct pldm_get_pdr_req*>(request->payload);
269 EXPECT_EQ(record_hndl, le32toh(req->record_handle));
270 EXPECT_EQ(data_transfer_hndl, le32toh(req->data_transfer_handle));
271 EXPECT_EQ(transfer_op_flag, req->transfer_op_flag);
272 EXPECT_EQ(request_cnt, le16toh(req->request_count));
273 EXPECT_EQ(record_chg_num, le16toh(req->record_change_number));
274}
275
276TEST(GetPDR, testBadEncodeRequest)
277{
278 uint32_t record_hndl = 0;
279 uint32_t data_transfer_hndl = 0;
280 uint8_t transfer_op_flag = PLDM_GET_FIRSTPART;
281 uint16_t request_cnt = 32;
282 uint16_t record_chg_num = 0;
283
284 std::vector<uint8_t> requestMsg(hdrSize + PLDM_GET_PDR_REQ_BYTES);
285 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
286
287 auto rc = encode_get_pdr_req(0, record_hndl, data_transfer_hndl,
288 transfer_op_flag, request_cnt, record_chg_num,
289 nullptr, PLDM_GET_PDR_REQ_BYTES);
290 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
291
292 rc = encode_get_pdr_req(0, record_hndl, data_transfer_hndl,
293 transfer_op_flag, request_cnt, record_chg_num,
294 request, PLDM_GET_PDR_REQ_BYTES + 1);
295 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
296}
297
298TEST(GetPDR, testGoodDecodeResponse)
299{
300 const char* recordData = "123456789";
301 uint8_t completionCode = PLDM_SUCCESS;
302 uint32_t nextRecordHndl = 0;
303 uint32_t nextDataTransferHndl = 0;
304 uint8_t transferFlag = PLDM_END;
305 constexpr uint16_t respCnt = 9;
306 uint8_t transferCRC = 96;
307 size_t recordDataLength = 32;
308 std::array<uint8_t, hdrSize + PLDM_GET_PDR_MIN_RESP_BYTES + respCnt +
309 sizeof(transferCRC)>
310 responseMsg{};
311
312 uint8_t retCompletionCode = 0;
313 uint8_t retRecordData[32] = {0};
314 uint32_t retNextRecordHndl = 0;
315 uint32_t retNextDataTransferHndl = 0;
316 uint8_t retTransferFlag = 0;
317 uint16_t retRespCnt = 0;
318 uint8_t retTransferCRC = 0;
319
320 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
321 struct pldm_get_pdr_resp* resp =
322 reinterpret_cast<struct pldm_get_pdr_resp*>(response->payload);
323 resp->completion_code = completionCode;
324 resp->next_record_handle = htole32(nextRecordHndl);
325 resp->next_data_transfer_handle = htole32(nextDataTransferHndl);
326 resp->transfer_flag = transferFlag;
327 resp->response_count = htole16(respCnt);
328 memcpy(resp->record_data, recordData, respCnt);
329 response->payload[PLDM_GET_PDR_MIN_RESP_BYTES + respCnt] = transferCRC;
330
331 auto rc = decode_get_pdr_resp(
332 response, responseMsg.size() - hdrSize, &retCompletionCode,
333 &retNextRecordHndl, &retNextDataTransferHndl, &retTransferFlag,
334 &retRespCnt, retRecordData, recordDataLength, &retTransferCRC);
335 EXPECT_EQ(rc, PLDM_SUCCESS);
336 EXPECT_EQ(retCompletionCode, completionCode);
337 EXPECT_EQ(retNextRecordHndl, nextRecordHndl);
338 EXPECT_EQ(retNextDataTransferHndl, nextDataTransferHndl);
339 EXPECT_EQ(retTransferFlag, transferFlag);
340 EXPECT_EQ(retRespCnt, respCnt);
341 EXPECT_EQ(retTransferCRC, transferCRC);
342 EXPECT_EQ(0, memcmp(recordData, resp->record_data, respCnt));
343}
344
345TEST(GetPDR, testBadDecodeResponse)
346{
347 const char* recordData = "123456789";
348 uint8_t completionCode = PLDM_SUCCESS;
349 uint32_t nextRecordHndl = 0;
350 uint32_t nextDataTransferHndl = 0;
351 uint8_t transferFlag = PLDM_END;
352 constexpr uint16_t respCnt = 9;
353 uint8_t transferCRC = 96;
354 size_t recordDataLength = 32;
355 std::array<uint8_t, hdrSize + PLDM_GET_PDR_MIN_RESP_BYTES + respCnt +
356 sizeof(transferCRC)>
357 responseMsg{};
358
359 uint8_t retCompletionCode = 0;
360 uint8_t retRecordData[32] = {0};
361 uint32_t retNextRecordHndl = 0;
362 uint32_t retNextDataTransferHndl = 0;
363 uint8_t retTransferFlag = 0;
364 uint16_t retRespCnt = 0;
365 uint8_t retTransferCRC = 0;
366
367 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
368 struct pldm_get_pdr_resp* resp =
369 reinterpret_cast<struct pldm_get_pdr_resp*>(response->payload);
370 resp->completion_code = completionCode;
371 resp->next_record_handle = htole32(nextRecordHndl);
372 resp->next_data_transfer_handle = htole32(nextDataTransferHndl);
373 resp->transfer_flag = transferFlag;
374 resp->response_count = htole16(respCnt);
375 memcpy(resp->record_data, recordData, respCnt);
376 response->payload[PLDM_GET_PDR_MIN_RESP_BYTES + respCnt] = transferCRC;
377
378 auto rc = decode_get_pdr_resp(response, responseMsg.size() - hdrSize, NULL,
379 NULL, NULL, NULL, NULL, NULL, 0, NULL);
380 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
381
382 rc = decode_get_pdr_resp(
383 response, responseMsg.size() - hdrSize - 1, &retCompletionCode,
384 &retNextRecordHndl, &retNextDataTransferHndl, &retTransferFlag,
385 &retRespCnt, retRecordData, recordDataLength, &retTransferCRC);
386 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
387}
388
389TEST(GetPDRRepositoryInfo, testGoodEncodeResponse)
390{
391 uint8_t completionCode = 0;
392 uint8_t repositoryState = PLDM_AVAILABLE;
393 uint8_t updateTime[PLDM_TIMESTAMP104_SIZE] = {0};
394 uint8_t oemUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
395 uint32_t recordCount = 100;
396 uint32_t repositorySize = 100;
397 uint32_t largestRecordSize = UINT32_MAX;
398 uint8_t dataTransferHandleTimeout = PLDM_NO_TIMEOUT;
399
400 std::vector<uint8_t> responseMsg(hdrSize +
401 PLDM_GET_PDR_REPOSITORY_INFO_RESP_BYTES);
402 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
403
404 auto rc = encode_get_pdr_repository_info_resp(
405 0, PLDM_SUCCESS, repositoryState, updateTime, oemUpdateTime,
406 recordCount, repositorySize, largestRecordSize,
407 dataTransferHandleTimeout, response);
408
409 EXPECT_EQ(rc, PLDM_SUCCESS);
410 struct pldm_pdr_repository_info_resp* resp =
411 reinterpret_cast<struct pldm_pdr_repository_info_resp*>(
412 response->payload);
413
414 EXPECT_EQ(completionCode, resp->completion_code);
415 EXPECT_EQ(repositoryState, resp->repository_state);
416 EXPECT_EQ(0, memcmp(updateTime, resp->update_time, PLDM_TIMESTAMP104_SIZE));
417 EXPECT_EQ(0, memcmp(oemUpdateTime, resp->oem_update_time,
418 PLDM_TIMESTAMP104_SIZE));
419 EXPECT_EQ(recordCount, le32toh(resp->record_count));
420 EXPECT_EQ(repositorySize, le32toh(resp->repository_size));
421 EXPECT_EQ(largestRecordSize, le32toh(resp->largest_record_size));
422 EXPECT_EQ(dataTransferHandleTimeout, resp->data_transfer_handle_timeout);
423}
424
425TEST(GetPDRRepositoryInfo, testBadEncodeResponse)
426{
427 uint8_t repositoryState = PLDM_AVAILABLE;
428 uint8_t updateTime[PLDM_TIMESTAMP104_SIZE] = {0};
429 uint8_t oemUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
430 uint32_t recordCount = 100;
431 uint32_t repositorySize = 100;
432 uint32_t largestRecordSize = UINT32_MAX;
433 uint8_t dataTransferHandleTimeout = PLDM_NO_TIMEOUT;
434
435 auto rc = encode_get_pdr_repository_info_resp(
436 0, PLDM_SUCCESS, repositoryState, updateTime, oemUpdateTime,
437 recordCount, repositorySize, largestRecordSize,
438 dataTransferHandleTimeout, nullptr);
439 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
440}
441
Gilbert Chenb7c73e52022-11-10 11:29:52 +0800442TEST(GetPDRRepositoryInfo, testGoodDecodeResponse)
443{
444 uint8_t completionCode = PLDM_SUCCESS;
445 uint8_t repositoryState = PLDM_AVAILABLE;
446 uint8_t updateTime[PLDM_TIMESTAMP104_SIZE] = {0};
447 uint8_t oemUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
448 uint32_t recordCount = 100;
449 uint32_t repositorySize = 100;
450 uint32_t largestRecordSize = UINT32_MAX;
451 uint8_t dataTransferHandleTimeout = PLDM_NO_TIMEOUT;
452
453 std::array<uint8_t, hdrSize + PLDM_GET_PDR_REPOSITORY_INFO_RESP_BYTES>
454 responseMsg{};
455 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
456 struct pldm_pdr_repository_info_resp* resp =
457 reinterpret_cast<struct pldm_pdr_repository_info_resp*>(
458 response->payload);
459 resp->completion_code = completionCode;
460 resp->repository_state = repositoryState;
461 memcpy(resp->update_time, updateTime, PLDM_TIMESTAMP104_SIZE);
462 memcpy(resp->oem_update_time, oemUpdateTime, PLDM_TIMESTAMP104_SIZE);
463 resp->record_count = htole32(recordCount);
464 resp->repository_size = htole32(repositorySize);
465 resp->largest_record_size = htole32(largestRecordSize);
466 resp->data_transfer_handle_timeout = dataTransferHandleTimeout;
467
468 uint8_t retCompletionCode = 0;
469 uint8_t retRepositoryState = 0;
470 uint8_t retUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
471 uint8_t retOemUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
472 uint32_t retRecordCount = 0;
473 uint32_t retRepositorySize = 0;
474 uint32_t retLargestRecordSize = 0;
475 uint8_t retDataTransferHandleTimeout = 0;
476
477 auto rc = decode_get_pdr_repository_info_resp(
478 response, responseMsg.size() - hdrSize, &retCompletionCode,
479 &retRepositoryState, retUpdateTime, retOemUpdateTime, &retRecordCount,
480 &retRepositorySize, &retLargestRecordSize,
481 &retDataTransferHandleTimeout);
482
483 EXPECT_EQ(rc, PLDM_SUCCESS);
484 EXPECT_EQ(completionCode, retCompletionCode);
485 EXPECT_EQ(repositoryState, retRepositoryState);
486 EXPECT_EQ(0, memcmp(updateTime, retUpdateTime, PLDM_TIMESTAMP104_SIZE));
487 EXPECT_EQ(0,
488 memcmp(oemUpdateTime, retOemUpdateTime, PLDM_TIMESTAMP104_SIZE));
489 EXPECT_EQ(recordCount, recordCount);
490 EXPECT_EQ(repositorySize, repositorySize);
491 EXPECT_EQ(largestRecordSize, largestRecordSize);
492 EXPECT_EQ(dataTransferHandleTimeout, dataTransferHandleTimeout);
493}
494
495TEST(GetPDRRepositoryInfo, testBadDecodeResponse)
496{
497 uint8_t completionCode = PLDM_SUCCESS;
498 uint8_t repositoryState = PLDM_AVAILABLE;
499 uint8_t updateTime[PLDM_TIMESTAMP104_SIZE] = {0};
500 uint8_t oemUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
501 uint32_t recordCount = htole32(100);
502 uint32_t repositorySize = htole32(100);
503 uint32_t largestRecordSize = htole32(UINT32_MAX);
504 uint8_t dataTransferHandleTimeout = PLDM_NO_TIMEOUT;
505
506 std::array<uint8_t, hdrSize + PLDM_GET_PDR_REPOSITORY_INFO_RESP_BYTES>
507 responseMsg{};
508 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
509 struct pldm_pdr_repository_info_resp* resp =
510 reinterpret_cast<struct pldm_pdr_repository_info_resp*>(
511 response->payload);
512 resp->completion_code = completionCode;
513 resp->repository_state = repositoryState;
514 memcpy(resp->update_time, updateTime, PLDM_TIMESTAMP104_SIZE);
515 memcpy(resp->oem_update_time, oemUpdateTime, PLDM_TIMESTAMP104_SIZE);
516 resp->record_count = recordCount;
517 resp->repository_size = repositorySize;
518 resp->largest_record_size = largestRecordSize;
519 resp->data_transfer_handle_timeout = dataTransferHandleTimeout;
520
521 uint8_t retCompletionCode = 0;
522 uint8_t retRepositoryState = 0;
523 uint8_t retUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
524 uint8_t retOemUpdateTime[PLDM_TIMESTAMP104_SIZE] = {0};
525 uint32_t retRecordCount = 0;
526 uint32_t retRepositorySize = 0;
527 uint32_t retLargestRecordSize = 0;
528 uint8_t retDataTransferHandleTimeout = 0;
529
530 auto rc = decode_get_pdr_repository_info_resp(
531 response, responseMsg.size() - hdrSize, NULL, NULL, NULL, NULL, NULL,
532 NULL, NULL, NULL);
533 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
534
535 rc = decode_get_pdr_repository_info_resp(
536 response, responseMsg.size() - hdrSize - 1, &retCompletionCode,
537 &retRepositoryState, retUpdateTime, retOemUpdateTime, &retRecordCount,
538 &retRepositorySize, &retLargestRecordSize,
539 &retDataTransferHandleTimeout);
540 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
541
542 resp->repository_state = PLDM_FAILED + 1;
543 rc = decode_get_pdr_repository_info_resp(
544 response, responseMsg.size() - hdrSize, &retCompletionCode,
545 &retRepositoryState, retUpdateTime, retOemUpdateTime, &retRecordCount,
546 &retRepositorySize, &retLargestRecordSize,
547 &retDataTransferHandleTimeout);
548 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
549}
550
Andrew Jeffery9c766792022-08-10 23:12:49 +0930551TEST(SetNumericEffecterValue, testGoodDecodeRequest)
552{
553 std::array<uint8_t,
554 hdrSize + PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES + 3>
555 requestMsg{};
556
557 uint16_t effecter_id = 32768;
558 uint8_t effecter_data_size = PLDM_EFFECTER_DATA_SIZE_UINT32;
559 uint32_t effecter_value = 123456789;
560
561 uint16_t reteffecter_id;
562 uint8_t reteffecter_data_size;
563 uint8_t reteffecter_value[4];
564
565 auto req = reinterpret_cast<pldm_msg*>(requestMsg.data());
566 struct pldm_set_numeric_effecter_value_req* request =
567 reinterpret_cast<struct pldm_set_numeric_effecter_value_req*>(
568 req->payload);
569
570 request->effecter_id = htole16(effecter_id);
571 request->effecter_data_size = effecter_data_size;
572 uint32_t effecter_value_le = htole32(effecter_value);
573 memcpy(request->effecter_value, &effecter_value_le,
574 sizeof(effecter_value_le));
575
576 auto rc = decode_set_numeric_effecter_value_req(
577 req, requestMsg.size() - hdrSize, &reteffecter_id,
578 &reteffecter_data_size, reteffecter_value);
579
580 uint32_t value = *(reinterpret_cast<uint32_t*>(reteffecter_value));
581 EXPECT_EQ(rc, PLDM_SUCCESS);
582 EXPECT_EQ(reteffecter_id, effecter_id);
583 EXPECT_EQ(reteffecter_data_size, effecter_data_size);
584 EXPECT_EQ(value, effecter_value);
585}
586
587TEST(SetNumericEffecterValue, testBadDecodeRequest)
588{
589 std::array<uint8_t, hdrSize + PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES>
590 requestMsg{};
591
592 auto rc = decode_set_numeric_effecter_value_req(
593 NULL, requestMsg.size() - hdrSize, NULL, NULL, NULL);
594 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
595
596 uint16_t effecter_id = 0x10;
597 uint8_t effecter_data_size = PLDM_EFFECTER_DATA_SIZE_UINT8;
598 uint8_t effecter_value = 1;
599
600 uint16_t reteffecter_id;
601 uint8_t reteffecter_data_size;
602 uint8_t reteffecter_value[4];
603
604 auto req = reinterpret_cast<pldm_msg*>(requestMsg.data());
605 struct pldm_set_numeric_effecter_value_req* request =
606 reinterpret_cast<struct pldm_set_numeric_effecter_value_req*>(
607 req->payload);
608
609 request->effecter_id = effecter_id;
610 request->effecter_data_size = effecter_data_size;
611 memcpy(request->effecter_value, &effecter_value, sizeof(effecter_value));
612
613 rc = decode_set_numeric_effecter_value_req(
614 req, requestMsg.size() - hdrSize - 1, &reteffecter_id,
615 &reteffecter_data_size, reinterpret_cast<uint8_t*>(&reteffecter_value));
616 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
617}
618
619TEST(SetNumericEffecterValue, testGoodEncodeRequest)
620{
621 uint16_t effecter_id = 0;
622 uint8_t effecter_data_size = PLDM_EFFECTER_DATA_SIZE_UINT16;
623 uint16_t effecter_value = 65534;
624
625 std::vector<uint8_t> requestMsg(
626 hdrSize + PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES + 1);
627 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
628
629 auto rc = encode_set_numeric_effecter_value_req(
630 0, effecter_id, effecter_data_size,
631 reinterpret_cast<uint8_t*>(&effecter_value), request,
632 PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES + 1);
633 EXPECT_EQ(rc, PLDM_SUCCESS);
634
635 struct pldm_set_numeric_effecter_value_req* req =
636 reinterpret_cast<struct pldm_set_numeric_effecter_value_req*>(
637 request->payload);
638 EXPECT_EQ(effecter_id, req->effecter_id);
639 EXPECT_EQ(effecter_data_size, req->effecter_data_size);
640 uint16_t* val = (uint16_t*)req->effecter_value;
641 *val = le16toh(*val);
642 EXPECT_EQ(effecter_value, *val);
643}
644
645TEST(SetNumericEffecterValue, testBadEncodeRequest)
646{
647 std::vector<uint8_t> requestMsg(
648 hdrSize + PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES);
649 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
650
651 auto rc = encode_set_numeric_effecter_value_req(
652 0, 0, 0, NULL, NULL, PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES);
653 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
654
655 uint16_t effecter_value;
656 rc = encode_set_numeric_effecter_value_req(
657 0, 0, 6, reinterpret_cast<uint8_t*>(&effecter_value), request,
658 PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES);
659 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
660}
661
662TEST(SetNumericEffecterValue, testGoodDecodeResponse)
663{
664 std::array<uint8_t, hdrSize + PLDM_SET_NUMERIC_EFFECTER_VALUE_RESP_BYTES>
665 responseMsg{};
666
667 uint8_t completion_code = 0xA0;
668
669 uint8_t retcompletion_code;
670
671 memcpy(responseMsg.data() + hdrSize, &completion_code,
672 sizeof(completion_code));
673
674 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
675
676 auto rc = decode_set_numeric_effecter_value_resp(
677 response, responseMsg.size() - hdrSize, &retcompletion_code);
678
679 EXPECT_EQ(rc, PLDM_SUCCESS);
680 EXPECT_EQ(completion_code, retcompletion_code);
681}
682
683TEST(SetNumericEffecterValue, testBadDecodeResponse)
684{
685 std::array<uint8_t, PLDM_SET_NUMERIC_EFFECTER_VALUE_RESP_BYTES>
686 responseMsg{};
687
688 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
689
690 auto rc = decode_set_numeric_effecter_value_resp(response,
691 responseMsg.size(), NULL);
692
693 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
694}
695
696TEST(SetNumericEffecterValue, testGoodEncodeResponse)
697{
698 std::array<uint8_t, sizeof(pldm_msg_hdr) +
699 PLDM_SET_NUMERIC_EFFECTER_VALUE_RESP_BYTES>
700 responseMsg{};
701 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
702 uint8_t completionCode = 0;
703
704 auto rc = encode_set_numeric_effecter_value_resp(
705 0, PLDM_SUCCESS, response, PLDM_SET_NUMERIC_EFFECTER_VALUE_RESP_BYTES);
706
707 EXPECT_EQ(rc, PLDM_SUCCESS);
708 EXPECT_EQ(completionCode, response->payload[0]);
709}
710
711TEST(SetNumericEffecterValue, testBadEncodeResponse)
712{
713 auto rc = encode_set_numeric_effecter_value_resp(
714 0, PLDM_SUCCESS, NULL, PLDM_SET_NUMERIC_EFFECTER_VALUE_RESP_BYTES);
715 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
716}
717
718TEST(GetStateSensorReadings, testGoodEncodeResponse)
719{
720 std::array<uint8_t, hdrSize +
721 PLDM_GET_STATE_SENSOR_READINGS_MIN_RESP_BYTES +
722 sizeof(get_sensor_state_field) * 2>
723 responseMsg{};
724
725 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
726 uint8_t completionCode = 0;
727 uint8_t comp_sensorCnt = 0x2;
728
729 std::array<get_sensor_state_field, 2> stateField{};
730 stateField[0] = {PLDM_SENSOR_ENABLED, PLDM_SENSOR_NORMAL,
731 PLDM_SENSOR_WARNING, PLDM_SENSOR_UNKNOWN};
732 stateField[1] = {PLDM_SENSOR_FAILED, PLDM_SENSOR_UPPERFATAL,
733 PLDM_SENSOR_UPPERCRITICAL, PLDM_SENSOR_FATAL};
734
735 auto rc = encode_get_state_sensor_readings_resp(
736 0, PLDM_SUCCESS, comp_sensorCnt, stateField.data(), response);
737
738 struct pldm_get_state_sensor_readings_resp* resp =
739 reinterpret_cast<struct pldm_get_state_sensor_readings_resp*>(
740 response->payload);
741
742 EXPECT_EQ(rc, PLDM_SUCCESS);
743 EXPECT_EQ(completionCode, resp->completion_code);
744 EXPECT_EQ(comp_sensorCnt, resp->comp_sensor_count);
745 EXPECT_EQ(stateField[0].sensor_op_state, resp->field->sensor_op_state);
746 EXPECT_EQ(stateField[0].present_state, resp->field->present_state);
747 EXPECT_EQ(stateField[0].previous_state, resp->field->previous_state);
748 EXPECT_EQ(stateField[0].event_state, resp->field->event_state);
749 EXPECT_EQ(stateField[1].sensor_op_state, resp->field[1].sensor_op_state);
750 EXPECT_EQ(stateField[1].present_state, resp->field[1].present_state);
751 EXPECT_EQ(stateField[1].previous_state, resp->field[1].previous_state);
752 EXPECT_EQ(stateField[1].event_state, resp->field[1].event_state);
753}
754
755TEST(GetStateSensorReadings, testBadEncodeResponse)
756{
757 auto rc = encode_get_state_sensor_readings_resp(0, PLDM_SUCCESS, 0, nullptr,
758 nullptr);
759
760 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
761}
762
763TEST(GetStateSensorReadings, testGoodDecodeResponse)
764{
765 std::array<uint8_t, hdrSize +
766 PLDM_GET_STATE_SENSOR_READINGS_MIN_RESP_BYTES +
767 sizeof(get_sensor_state_field) * 2>
768 responseMsg{};
769
770 uint8_t completionCode = 0;
771 uint8_t comp_sensorCnt = 2;
772
773 std::array<get_sensor_state_field, 2> stateField{};
774 stateField[0] = {PLDM_SENSOR_DISABLED, PLDM_SENSOR_UNKNOWN,
775 PLDM_SENSOR_UNKNOWN, PLDM_SENSOR_UNKNOWN};
776 stateField[1] = {PLDM_SENSOR_ENABLED, PLDM_SENSOR_LOWERFATAL,
777 PLDM_SENSOR_LOWERCRITICAL, PLDM_SENSOR_WARNING};
778
779 uint8_t retcompletion_code = 0;
780 uint8_t retcomp_sensorCnt = 0;
781 std::array<get_sensor_state_field, 2> retstateField{};
782
783 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
784 struct pldm_get_state_sensor_readings_resp* resp =
785 reinterpret_cast<struct pldm_get_state_sensor_readings_resp*>(
786 response->payload);
787
788 resp->completion_code = completionCode;
789 resp->comp_sensor_count = comp_sensorCnt;
790 memcpy(resp->field, &stateField,
791 (sizeof(get_sensor_state_field) * comp_sensorCnt));
792
793 auto rc = decode_get_state_sensor_readings_resp(
794 response, responseMsg.size() - hdrSize, &retcompletion_code,
795 &retcomp_sensorCnt, retstateField.data());
796
797 EXPECT_EQ(rc, PLDM_SUCCESS);
798 EXPECT_EQ(completionCode, retcompletion_code);
799 EXPECT_EQ(comp_sensorCnt, retcomp_sensorCnt);
800 EXPECT_EQ(stateField[0].sensor_op_state, retstateField[0].sensor_op_state);
801 EXPECT_EQ(stateField[0].present_state, retstateField[0].present_state);
802 EXPECT_EQ(stateField[0].previous_state, retstateField[0].previous_state);
803 EXPECT_EQ(stateField[0].event_state, retstateField[0].event_state);
804 EXPECT_EQ(stateField[1].sensor_op_state, retstateField[1].sensor_op_state);
805 EXPECT_EQ(stateField[1].present_state, retstateField[1].present_state);
806 EXPECT_EQ(stateField[1].previous_state, retstateField[1].previous_state);
807 EXPECT_EQ(stateField[1].event_state, retstateField[1].event_state);
808}
809
810TEST(GetStateSensorReadings, testBadDecodeResponse)
811{
812 std::array<uint8_t, hdrSize +
813 PLDM_GET_STATE_SENSOR_READINGS_MIN_RESP_BYTES +
814 sizeof(get_sensor_state_field) * 2>
815 responseMsg{};
816
817 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
818
819 auto rc = decode_get_state_sensor_readings_resp(
820 response, responseMsg.size() - hdrSize, nullptr, nullptr, nullptr);
821
822 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
823
824 uint8_t completionCode = 0;
825 uint8_t comp_sensorCnt = 1;
826
827 std::array<get_sensor_state_field, 1> stateField{};
828 stateField[0] = {PLDM_SENSOR_ENABLED, PLDM_SENSOR_UPPERFATAL,
829 PLDM_SENSOR_UPPERCRITICAL, PLDM_SENSOR_WARNING};
830
831 uint8_t retcompletion_code = 0;
832 uint8_t retcomp_sensorCnt = 0;
833 std::array<get_sensor_state_field, 1> retstateField{};
834
835 struct pldm_get_state_sensor_readings_resp* resp =
836 reinterpret_cast<struct pldm_get_state_sensor_readings_resp*>(
837 response->payload);
838
839 resp->completion_code = completionCode;
840 resp->comp_sensor_count = comp_sensorCnt;
841 memcpy(resp->field, &stateField,
842 (sizeof(get_sensor_state_field) * comp_sensorCnt));
843
844 rc = decode_get_state_sensor_readings_resp(
845 response, responseMsg.size() - hdrSize + 1, &retcompletion_code,
846 &retcomp_sensorCnt, retstateField.data());
847
848 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
849}
850
851TEST(GetStateSensorReadings, testGoodEncodeRequest)
852{
853 std::array<uint8_t, hdrSize + PLDM_GET_STATE_SENSOR_READINGS_REQ_BYTES>
854 requestMsg{};
855
856 uint16_t sensorId = 0xAB;
857 bitfield8_t sensorRearm;
858 sensorRearm.byte = 0x03;
859
860 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
861 auto rc = encode_get_state_sensor_readings_req(0, sensorId, sensorRearm, 0,
862 request);
863
864 struct pldm_get_state_sensor_readings_req* req =
865 reinterpret_cast<struct pldm_get_state_sensor_readings_req*>(
866 request->payload);
867
868 EXPECT_EQ(rc, PLDM_SUCCESS);
869 EXPECT_EQ(sensorId, le16toh(req->sensor_id));
870 EXPECT_EQ(sensorRearm.byte, req->sensor_rearm.byte);
871}
872
873TEST(GetStateSensorReadings, testBadEncodeRequest)
874{
875 bitfield8_t sensorRearm;
876 sensorRearm.byte = 0x0;
877
878 auto rc =
879 encode_get_state_sensor_readings_req(0, 0, sensorRearm, 0, nullptr);
880
881 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
882}
883
884TEST(GetStateSensorReadings, testGoodDecodeRequest)
885{
886 std::array<uint8_t, hdrSize + PLDM_GET_STATE_SENSOR_READINGS_REQ_BYTES>
887 requestMsg{};
888
889 uint16_t sensorId = 0xCD;
890 bitfield8_t sensorRearm;
891 sensorRearm.byte = 0x10;
892
893 uint16_t retsensorId;
894 bitfield8_t retsensorRearm;
895 uint8_t retreserved;
896
897 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
898
899 struct pldm_get_state_sensor_readings_req* req =
900 reinterpret_cast<struct pldm_get_state_sensor_readings_req*>(
901 request->payload);
902
903 req->sensor_id = htole16(sensorId);
904 req->sensor_rearm.byte = sensorRearm.byte;
905
906 auto rc = decode_get_state_sensor_readings_req(
907 request, requestMsg.size() - hdrSize, &retsensorId, &retsensorRearm,
908 &retreserved);
909
910 EXPECT_EQ(rc, PLDM_SUCCESS);
911 EXPECT_EQ(sensorId, retsensorId);
912 EXPECT_EQ(sensorRearm.byte, retsensorRearm.byte);
913 EXPECT_EQ(0, retreserved);
914}
915
916TEST(GetStateSensorReadings, testBadDecodeRequest)
917{
918 std::array<uint8_t, hdrSize + PLDM_GET_STATE_SENSOR_READINGS_REQ_BYTES>
919 requestMsg{};
920
921 auto rc = decode_get_state_sensor_readings_req(
922 nullptr, requestMsg.size() - hdrSize, nullptr, nullptr, nullptr);
923
924 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
925 uint16_t sensorId = 0x11;
926 bitfield8_t sensorRearm;
927 sensorRearm.byte = 0x04;
928
929 uint16_t retsensorId;
930 bitfield8_t retsensorRearm;
931 uint8_t retreserved;
932
933 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
934
935 struct pldm_get_state_sensor_readings_req* req =
936 reinterpret_cast<struct pldm_get_state_sensor_readings_req*>(
937 request->payload);
938
939 req->sensor_id = htole16(sensorId);
940 req->sensor_rearm.byte = sensorRearm.byte;
941
942 rc = decode_get_state_sensor_readings_req(
943 request, requestMsg.size() - hdrSize - 1, &retsensorId, &retsensorRearm,
944 &retreserved);
945
946 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
947}
948
Dung Caod6ae8982022-11-02 10:00:10 +0700949TEST(EventMessageBufferSize, testGoodEventMessageBufferSizeRequest)
950{
951 uint8_t eventBufferSize = 32;
952
953 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_BUFFER_SIZE_REQ_BYTES>
954 requestMsg{};
955 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
956
957 auto rc = encode_event_message_buffer_size_req(0, eventBufferSize, request);
958
959 EXPECT_EQ(rc, PLDM_SUCCESS);
960}
961
962TEST(EventMessageBufferSize, testGoodEventMessageBufferSizeResponse)
963{
964 uint8_t completionCode = PLDM_SUCCESS;
965 uint16_t terminusMaxBufferSize = 256;
966
967 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_BUFFER_SIZE_RESP_BYTES>
968 responseMsg{};
969
970 uint8_t retCompletionCode;
971 uint16_t retMaxBufferSize = 0;
972
973 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
974 struct pldm_event_message_buffer_size_resp* resp =
975 reinterpret_cast<struct pldm_event_message_buffer_size_resp*>(
976 response->payload);
977
978 resp->completion_code = completionCode;
979 resp->terminus_max_buffer_size = terminusMaxBufferSize;
980
981 auto rc = decode_event_message_buffer_size_resp(
982 response, responseMsg.size() - hdrSize, &retCompletionCode,
983 &retMaxBufferSize);
984
985 EXPECT_EQ(rc, PLDM_SUCCESS);
986 EXPECT_EQ(retCompletionCode, completionCode);
987 EXPECT_EQ(terminusMaxBufferSize, retMaxBufferSize);
988}
989
990TEST(EventMessageBufferSize, testBadEventMessageBufferSizeResponse)
991{
992 uint8_t completionCode = PLDM_SUCCESS;
993 uint16_t terminusMaxBufferSize = 256;
994
995 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_BUFFER_SIZE_RESP_BYTES>
996 responseMsg{};
997
998 uint8_t retCompletionCode;
999 uint16_t retMaxBufferSize = 0;
1000
1001 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1002 struct pldm_event_message_buffer_size_resp* resp =
1003 reinterpret_cast<struct pldm_event_message_buffer_size_resp*>(
1004 response->payload);
1005 resp->completion_code = completionCode;
1006 resp->terminus_max_buffer_size = terminusMaxBufferSize;
1007
1008 auto rc =
1009 decode_event_message_buffer_size_resp(response, 0, nullptr, nullptr);
1010 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1011
1012 rc = decode_event_message_buffer_size_resp(
1013 response, responseMsg.size(), &retCompletionCode, &retMaxBufferSize);
1014 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1015}
1016
Dung Cao1bf8c872022-11-29 05:32:58 +07001017TEST(PlatformEventMessageSupported, testGoodEncodeRequest)
1018{
1019 uint8_t formatVersion = 0x01;
1020
1021 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_SUPPORTED_REQ_BYTES>
1022 requestMsg{};
1023
1024 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1025
1026 auto rc = encode_event_message_supported_req(0, formatVersion, request);
1027
1028 struct pldm_event_message_supported_req* req =
1029 reinterpret_cast<struct pldm_event_message_supported_req*>(
1030 request->payload);
1031
1032 EXPECT_EQ(rc, PLDM_SUCCESS);
1033 EXPECT_EQ(formatVersion, req->format_version);
1034}
1035
1036TEST(PlatformEventMessageSupported, testBadEncodeRequest)
1037{
1038 uint8_t eventData = 34;
1039 uint8_t formatVersion = 0x0;
1040
1041 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_SUPPORTED_REQ_BYTES +
1042 sizeof(eventData)>
1043 requestMsg{};
1044 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1045
1046 auto rc = encode_event_message_supported_req(0, formatVersion, request);
1047 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1048
1049 rc = encode_event_message_supported_req(0, formatVersion, nullptr);
1050 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1051}
1052
1053TEST(PlatformEventMessageSupported, testGoodDecodeRespond)
1054{
1055 uint8_t completionCode = PLDM_SUCCESS;
1056 uint8_t synchConfiguration = PLDM_MESSAGE_TYPE_SYNCHRONOUS;
1057 bitfield8_t synchConfigSupported;
1058 synchConfigSupported.byte = 0xe;
1059 uint8_t numberEventClassReturned = 0x3;
1060 std::vector<uint8_t> eventClass{0x0, 0x5, 0xfa};
1061 constexpr uint8_t eventClassCount = 3;
1062
1063 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_SUPPORTED_MIN_RESP_BYTES +
1064 eventClassCount>
1065 responseMsg{};
1066
1067 uint8_t retCompletionCode;
1068 uint8_t retSynchConfig = 0;
1069 uint8_t retNumberEventClass = 0;
1070 bitfield8_t retSynchConfigSupport;
1071 uint8_t retEventClass[eventClassCount] = {0};
1072
1073 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1074 struct pldm_event_message_supported_resp* resp =
1075 reinterpret_cast<struct pldm_event_message_supported_resp*>(
1076 response->payload);
1077
1078 resp->completion_code = completionCode;
1079 resp->synchrony_configuration = synchConfiguration;
1080 resp->synchrony_configuration_supported.byte = synchConfigSupported.byte;
1081 resp->number_event_class_returned = numberEventClassReturned;
1082 memcpy(resp->event_class, eventClass.data(), numberEventClassReturned);
1083
1084 auto rc = decode_event_message_supported_resp(
1085 response, responseMsg.size() - hdrSize, &retCompletionCode,
1086 &retSynchConfig, &retSynchConfigSupport, &retNumberEventClass,
1087 retEventClass, eventClassCount);
1088
1089 EXPECT_EQ(rc, PLDM_SUCCESS);
1090 EXPECT_EQ(retCompletionCode, completionCode);
1091 EXPECT_EQ(retSynchConfig, synchConfiguration);
1092 EXPECT_EQ(retNumberEventClass, numberEventClassReturned);
1093 EXPECT_EQ(retSynchConfigSupport.byte, synchConfigSupported.byte);
1094 EXPECT_EQ(0, memcmp(eventClass.data(), resp->event_class,
1095 numberEventClassReturned));
1096}
1097
1098TEST(PlatformEventMessageSupported, testBadSynchConfiguration)
1099{
1100 uint8_t completionCode = PLDM_SUCCESS;
1101 uint8_t synchConfiguration = 0x4;
1102 bitfield8_t synchConfigSupported;
1103 synchConfigSupported.byte = 0xe;
1104 uint8_t numberEventClassReturned = 0x3;
1105 std::vector<uint8_t> eventClass{0x0, 0x5, 0xfa};
1106 constexpr uint8_t eventClassCount = 3;
1107
1108 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_SUPPORTED_MIN_RESP_BYTES +
1109 eventClassCount>
1110 responseMsg{};
1111
1112 uint8_t retCompletionCode;
1113 uint8_t retSynchConfig = 0;
1114 uint8_t retNumberEventClass = 0;
1115 bitfield8_t retSynchConfigSupport;
1116 uint8_t retEventClass[eventClassCount] = {0};
1117
1118 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1119 struct pldm_event_message_supported_resp* resp =
1120 reinterpret_cast<struct pldm_event_message_supported_resp*>(
1121 response->payload);
1122
1123 resp->completion_code = completionCode;
1124 resp->synchrony_configuration = synchConfiguration;
1125 resp->synchrony_configuration_supported.byte = synchConfigSupported.byte;
1126 resp->number_event_class_returned = numberEventClassReturned;
1127 memcpy(resp->event_class, eventClass.data(), numberEventClassReturned);
1128
1129 auto rc = decode_event_message_supported_resp(
1130 response, responseMsg.size() - hdrSize, &retCompletionCode,
1131 &retSynchConfig, &retSynchConfigSupport, &retNumberEventClass,
1132 retEventClass, eventClassCount);
1133
1134 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1135}
1136
1137TEST(PlatformEventMessageSupported, testBadDecodeRespond)
1138{
1139 uint8_t completionCode = PLDM_SUCCESS;
1140 uint8_t synchConfiguration = PLDM_MESSAGE_TYPE_SYNCHRONOUS;
1141 bitfield8_t synchConfigSupported;
1142 synchConfigSupported.byte = 0xe;
1143 uint8_t numberEventClassReturned = 0x3;
1144 std::vector<uint8_t> eventClass{0x0, 0x5, 0xfa};
1145 constexpr uint8_t eventClassCount = 3;
1146
1147 std::array<uint8_t, hdrSize + PLDM_EVENT_MESSAGE_SUPPORTED_MIN_RESP_BYTES +
1148 eventClassCount>
1149 responseMsg{};
1150
1151 uint8_t retCompletionCode;
1152 uint8_t retSynchConfig = 0;
1153 uint8_t retNumberEventClass = 0;
1154 bitfield8_t retSynchConfigSupport;
1155 uint8_t retEventClass[eventClassCount] = {0};
1156
1157 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1158 struct pldm_event_message_supported_resp* resp =
1159 reinterpret_cast<struct pldm_event_message_supported_resp*>(
1160 response->payload);
1161 resp->completion_code = completionCode;
1162 resp->synchrony_configuration = synchConfiguration;
1163 resp->synchrony_configuration_supported.byte = synchConfigSupported.byte;
1164 resp->number_event_class_returned = numberEventClassReturned;
1165 memcpy(resp->event_class, eventClass.data(), numberEventClassReturned);
1166
1167 auto rc = decode_event_message_supported_resp(response, 0, nullptr, nullptr,
1168 nullptr, nullptr, nullptr, 0);
1169 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1170
1171 rc = decode_event_message_supported_resp(
1172 response, PLDM_EVENT_MESSAGE_SUPPORTED_MIN_RESP_BYTES - 1,
1173 &retCompletionCode, &retSynchConfig, &retSynchConfigSupport,
1174 &retNumberEventClass, retEventClass, eventClassCount);
1175 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1176
1177 rc = decode_event_message_supported_resp(
1178 response, responseMsg.size() - hdrSize, &retCompletionCode,
1179 &retSynchConfig, &retSynchConfigSupport, &retNumberEventClass,
1180 retEventClass, 1);
1181 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1182}
1183
Andrew Jeffery9c766792022-08-10 23:12:49 +09301184TEST(PlatformEventMessage, testGoodStateSensorDecodeRequest)
1185{
1186 std::array<uint8_t,
1187 hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES +
1188 PLDM_PLATFORM_EVENT_MESSAGE_STATE_SENSOR_STATE_REQ_BYTES>
1189 requestMsg{};
1190
1191 uint8_t retFormatVersion = 0;
1192 uint8_t retTid = 0;
1193 uint8_t retEventClass = 0;
1194 size_t retEventDataOffset = 0;
1195
1196 auto req = reinterpret_cast<pldm_msg*>(requestMsg.data());
1197 struct pldm_platform_event_message_req* request =
1198 reinterpret_cast<struct pldm_platform_event_message_req*>(req->payload);
1199
1200 uint8_t formatVersion = 0x01;
1201 uint8_t tid = 0x02;
1202 // Sensor Event
1203 uint8_t eventClass = 0x00;
1204
1205 request->format_version = formatVersion;
1206 request->tid = tid;
1207 request->event_class = eventClass;
1208 size_t eventDataOffset =
1209 sizeof(formatVersion) + sizeof(tid) + sizeof(eventClass);
1210
1211 auto rc = decode_platform_event_message_req(
1212 req, requestMsg.size() - hdrSize, &retFormatVersion, &retTid,
1213 &retEventClass, &retEventDataOffset);
1214
1215 EXPECT_EQ(rc, PLDM_SUCCESS);
1216 EXPECT_EQ(retFormatVersion, formatVersion);
1217 EXPECT_EQ(retTid, tid);
1218 EXPECT_EQ(retEventClass, eventClass);
1219 EXPECT_EQ(retEventDataOffset, eventDataOffset);
1220}
1221
1222TEST(PlatformEventMessage, testBadDecodeRequest)
1223{
1224 const struct pldm_msg* msg = NULL;
1225 std::array<uint8_t,
1226 hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES +
1227 PLDM_PLATFORM_EVENT_MESSAGE_STATE_SENSOR_STATE_REQ_BYTES - 1>
1228 requestMsg{};
1229 auto req = reinterpret_cast<pldm_msg*>(requestMsg.data());
1230 uint8_t retFormatVersion;
1231 uint8_t retTid = 0;
1232 uint8_t retEventClass = 0;
1233 size_t retEventDataOffset;
1234
1235 auto rc = decode_platform_event_message_req(msg, sizeof(*msg), NULL, NULL,
1236 NULL, NULL);
1237 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1238
1239 rc = decode_platform_event_message_req(
1240 req,
1241 requestMsg.size() - hdrSize -
1242 PLDM_PLATFORM_EVENT_MESSAGE_STATE_SENSOR_STATE_REQ_BYTES,
1243 &retFormatVersion, &retTid, &retEventClass, &retEventDataOffset);
1244 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1245}
1246
1247TEST(PlatformEventMessage, testGoodEncodeResponse)
1248{
1249 std::array<uint8_t,
1250 hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES +
1251 PLDM_PLATFORM_EVENT_MESSAGE_STATE_SENSOR_STATE_REQ_BYTES - 1>
1252 responseMsg{};
1253 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1254 uint8_t completionCode = 0;
1255 uint8_t instanceId = 0x01;
1256 uint8_t platformEventStatus = 0x01;
1257
1258 auto rc = encode_platform_event_message_resp(instanceId, PLDM_SUCCESS,
1259 platformEventStatus, response);
1260
1261 EXPECT_EQ(rc, PLDM_SUCCESS);
1262 EXPECT_EQ(completionCode, response->payload[0]);
1263 EXPECT_EQ(platformEventStatus, response->payload[1]);
1264}
1265
1266TEST(PlatformEventMessage, testBadEncodeResponse)
1267{
1268 auto rc = encode_platform_event_message_resp(0, PLDM_SUCCESS, 1, NULL);
1269 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1270}
1271
1272TEST(PlatformEventMessage, testGoodEncodeRequest)
1273{
1274 uint8_t formatVersion = 0x01;
1275 uint8_t Tid = 0x03;
1276 uint8_t eventClass = 0x00;
1277 uint8_t eventData = 34;
1278
1279 std::array<uint8_t, hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES +
1280 sizeof(eventData)>
1281 requestMsg{};
1282
1283 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1284 auto rc = encode_platform_event_message_req(
1285 0, formatVersion, Tid, eventClass,
1286 reinterpret_cast<uint8_t*>(&eventData), sizeof(eventData), request,
1287 sizeof(eventData) + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES);
1288
1289 struct pldm_platform_event_message_req* req =
1290 reinterpret_cast<struct pldm_platform_event_message_req*>(
1291 request->payload);
1292
1293 EXPECT_EQ(rc, PLDM_SUCCESS);
1294 EXPECT_EQ(formatVersion, req->format_version);
1295 EXPECT_EQ(Tid, req->tid);
1296 EXPECT_EQ(eventClass, req->event_class);
1297 EXPECT_EQ(0, memcmp(&eventData, req->event_data, sizeof(eventData)));
1298}
1299
1300TEST(PlatformEventMessage, testBadEncodeRequest)
1301{
1302 uint8_t Tid = 0x03;
1303 uint8_t eventClass = 0x00;
1304 uint8_t eventData = 34;
1305 size_t sz_eventData = sizeof(eventData);
1306 size_t payloadLen =
1307 sz_eventData + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES;
1308 uint8_t formatVersion = 0x01;
1309
1310 std::array<uint8_t, hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES +
1311 sizeof(eventData)>
1312 requestMsg{};
1313 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1314
1315 auto rc = encode_platform_event_message_req(
1316 0, formatVersion, Tid, eventClass,
1317 reinterpret_cast<uint8_t*>(&eventData), sz_eventData, nullptr,
1318 payloadLen);
1319 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1320 rc = encode_platform_event_message_req(
1321 0, 0, Tid, eventClass, reinterpret_cast<uint8_t*>(&eventData),
1322 sz_eventData, request, payloadLen);
1323 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1324 rc = encode_platform_event_message_req(0, formatVersion, Tid, eventClass,
1325 nullptr, 0, request, payloadLen);
1326 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1327 rc = encode_platform_event_message_req(
1328 0, formatVersion, Tid, eventClass,
1329 reinterpret_cast<uint8_t*>(&eventData), sz_eventData, request, 0);
1330 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1331}
1332
1333TEST(PlatformEventMessage, testGoodDecodeResponse)
1334{
1335 std::array<uint8_t, hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_RESP_BYTES>
1336 responseMsg{};
1337
1338 uint8_t completionCode = PLDM_SUCCESS;
1339 uint8_t platformEventStatus = 0x01;
1340
1341 uint8_t retcompletionCode;
1342 uint8_t retplatformEventStatus;
1343
1344 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1345 struct pldm_platform_event_message_resp* resp =
1346 reinterpret_cast<struct pldm_platform_event_message_resp*>(
1347 response->payload);
1348
1349 resp->completion_code = completionCode;
1350 resp->platform_event_status = platformEventStatus;
1351
1352 auto rc = decode_platform_event_message_resp(
1353 response, responseMsg.size() - hdrSize, &retcompletionCode,
1354 &retplatformEventStatus);
1355
1356 EXPECT_EQ(rc, PLDM_SUCCESS);
1357 EXPECT_EQ(completionCode, retcompletionCode);
1358 EXPECT_EQ(platformEventStatus, retplatformEventStatus);
1359}
1360
1361TEST(PlatformEventMessage, testBadDecodeResponse)
1362{
1363 std::array<uint8_t, hdrSize + PLDM_PLATFORM_EVENT_MESSAGE_RESP_BYTES>
1364 responseMsg{};
1365
1366 uint8_t completionCode = PLDM_SUCCESS;
1367 uint8_t platformEventStatus = 0x01;
1368
1369 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1370 struct pldm_platform_event_message_resp* resp =
1371 reinterpret_cast<struct pldm_platform_event_message_resp*>(
1372 response->payload);
1373 resp->completion_code = completionCode;
1374 resp->platform_event_status = platformEventStatus;
1375
1376 auto rc = decode_platform_event_message_resp(
1377 nullptr, responseMsg.size() - hdrSize, nullptr, nullptr);
1378
1379 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1380
1381 rc = decode_platform_event_message_resp(
1382 response, responseMsg.size() - hdrSize - 1, &completionCode,
1383 &platformEventStatus);
1384
1385 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1386}
1387
1388TEST(PlatformEventMessage, testGoodSensorEventDataDecodeRequest)
1389{
1390 std::array<uint8_t, PLDM_SENSOR_EVENT_SENSOR_OP_STATE_DATA_LENGTH +
1391 PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES>
1392 eventDataArr{};
1393 uint16_t sensorId = 0x1234;
1394 uint8_t sensorEventClassType = PLDM_SENSOR_OP_STATE;
1395
1396 struct pldm_sensor_event_data* eventData =
1397 (struct pldm_sensor_event_data*)eventDataArr.data();
1398 eventData->sensor_id = sensorId;
1399 eventData->sensor_event_class_type = sensorEventClassType;
1400
1401 size_t retSensorOpDataOffset;
1402 uint16_t retSensorId = 0;
1403 uint8_t retSensorEventClassType;
1404 size_t sensorOpDataOffset = sizeof(sensorId) + sizeof(sensorEventClassType);
1405 auto rc = decode_sensor_event_data(
1406 reinterpret_cast<uint8_t*>(eventData), eventDataArr.size(),
1407 &retSensorId, &retSensorEventClassType, &retSensorOpDataOffset);
1408 EXPECT_EQ(rc, PLDM_SUCCESS);
1409 EXPECT_EQ(retSensorId, sensorId);
1410 EXPECT_EQ(retSensorEventClassType, sensorEventClassType);
1411 EXPECT_EQ(retSensorOpDataOffset, sensorOpDataOffset);
1412}
1413
1414TEST(PlatformEventMessage, testBadSensorEventDataDecodeRequest)
1415{
1416
1417 std::array<uint8_t, PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_MAX_DATA_LENGTH +
1418 PLDM_PLATFORM_EVENT_MESSAGE_MIN_REQ_BYTES>
1419 eventDataArr{};
1420
1421 struct pldm_sensor_event_data* eventData =
1422 (struct pldm_sensor_event_data*)eventDataArr.data();
1423
1424 size_t retSensorOpDataOffset;
1425 uint16_t retSensorId = 0;
1426 uint8_t retSensorEventClassType;
1427 auto rc = decode_sensor_event_data(NULL, eventDataArr.size(), &retSensorId,
1428 &retSensorEventClassType,
1429 &retSensorOpDataOffset);
1430 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1431
1432 rc = decode_sensor_event_data(
1433 reinterpret_cast<uint8_t*>(eventDataArr.data()),
1434 eventDataArr.size() -
1435 PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_MAX_DATA_LENGTH,
1436 &retSensorId, &retSensorEventClassType, &retSensorOpDataOffset);
1437 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1438
1439 eventData->sensor_event_class_type = PLDM_SENSOR_OP_STATE;
1440
1441 rc = decode_sensor_event_data(
1442 reinterpret_cast<uint8_t*>(eventDataArr.data()), eventDataArr.size(),
1443 &retSensorId, &retSensorEventClassType, &retSensorOpDataOffset);
1444 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1445
1446 eventData->sensor_event_class_type = PLDM_STATE_SENSOR_STATE;
1447 rc = decode_sensor_event_data(
1448 reinterpret_cast<uint8_t*>(eventDataArr.data()), eventDataArr.size(),
1449 &retSensorId, &retSensorEventClassType, &retSensorOpDataOffset);
1450 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1451
1452 eventData->sensor_event_class_type = PLDM_NUMERIC_SENSOR_STATE;
1453 rc = decode_sensor_event_data(
1454 reinterpret_cast<uint8_t*>(eventDataArr.data()),
1455 eventDataArr.size() + 1, &retSensorId, &retSensorEventClassType,
1456 &retSensorOpDataOffset);
1457 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1458}
1459
1460TEST(PlatformEventMessage, testGoodSensorOpEventDataDecodeRequest)
1461{
1462 std::array<uint8_t, PLDM_SENSOR_EVENT_SENSOR_OP_STATE_DATA_LENGTH>
1463 eventDataArr{};
1464
1465 struct pldm_sensor_event_sensor_op_state* sensorData =
1466 (struct pldm_sensor_event_sensor_op_state*)eventDataArr.data();
1467 uint8_t presentState = PLDM_SENSOR_ENABLED;
1468 uint8_t previousState = PLDM_SENSOR_INITIALIZING;
1469 sensorData->present_op_state = presentState;
1470 sensorData->previous_op_state = previousState;
1471
1472 uint8_t retPresentState;
1473 uint8_t retPreviousState;
1474 auto rc = decode_sensor_op_data(reinterpret_cast<uint8_t*>(sensorData),
1475 eventDataArr.size(), &retPresentState,
1476 &retPreviousState);
1477 EXPECT_EQ(rc, PLDM_SUCCESS);
1478 EXPECT_EQ(retPresentState, presentState);
1479 EXPECT_EQ(retPreviousState, previousState);
1480}
1481
1482TEST(PlatformEventMessage, testBadSensorOpEventDataDecodeRequest)
1483{
1484 uint8_t presentOpState;
1485 uint8_t previousOpState;
1486 size_t sensorDataLength = PLDM_SENSOR_EVENT_SENSOR_OP_STATE_DATA_LENGTH;
1487 auto rc = decode_sensor_op_data(NULL, sensorDataLength, &presentOpState,
1488 &previousOpState);
1489 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1490
1491 std::array<uint8_t, PLDM_SENSOR_EVENT_SENSOR_OP_STATE_DATA_LENGTH>
1492 sensorData{};
1493 rc = decode_sensor_op_data(reinterpret_cast<uint8_t*>(sensorData.data()),
1494 sensorDataLength + 1, &presentOpState,
1495 &previousOpState);
1496 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1497
1498 rc = decode_sensor_op_data(reinterpret_cast<uint8_t*>(sensorData.data()),
1499 sensorDataLength, nullptr, &previousOpState);
1500 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1501}
1502
1503TEST(PlatformEventMessage, testGoodSensorStateEventDataDecodeRequest)
1504{
1505 std::array<uint8_t, PLDM_SENSOR_EVENT_STATE_SENSOR_STATE_DATA_LENGTH>
1506 eventDataArr{};
1507
1508 struct pldm_sensor_event_state_sensor_state* sensorData =
1509 (struct pldm_sensor_event_state_sensor_state*)eventDataArr.data();
1510 uint8_t sensorOffset = 0x02;
1511 uint8_t eventState = PLDM_SENSOR_SHUTTINGDOWN;
1512 uint8_t previousEventState = PLDM_SENSOR_INTEST;
1513 sensorData->sensor_offset = sensorOffset;
1514 sensorData->event_state = eventState;
1515 sensorData->previous_event_state = previousEventState;
1516
1517 uint8_t retSensorOffset;
1518 uint8_t retEventState;
1519 uint8_t retPreviousState;
1520 auto rc = decode_state_sensor_data(reinterpret_cast<uint8_t*>(sensorData),
1521 eventDataArr.size(), &retSensorOffset,
1522 &retEventState, &retPreviousState);
1523 EXPECT_EQ(rc, PLDM_SUCCESS);
1524 EXPECT_EQ(retSensorOffset, sensorOffset);
1525 EXPECT_EQ(retEventState, eventState);
1526 EXPECT_EQ(retPreviousState, previousEventState);
1527}
1528
1529TEST(PlatformEventMessage, testBadStateSensorEventDataDecodeRequest)
1530{
1531 uint8_t sensorOffset;
1532 uint8_t eventState;
1533 uint8_t previousEventState;
1534 size_t sensorDataLength = PLDM_SENSOR_EVENT_STATE_SENSOR_STATE_DATA_LENGTH;
1535 auto rc = decode_state_sensor_data(NULL, sensorDataLength, &sensorOffset,
1536 &eventState, &previousEventState);
1537 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1538
1539 std::array<uint8_t, PLDM_SENSOR_EVENT_STATE_SENSOR_STATE_DATA_LENGTH>
1540 sensorData{};
1541 rc = decode_state_sensor_data(reinterpret_cast<uint8_t*>(sensorData.data()),
1542 sensorDataLength - 1, &sensorOffset,
1543 &eventState, &previousEventState);
1544 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1545
1546 rc = decode_state_sensor_data(reinterpret_cast<uint8_t*>(sensorData.data()),
1547 sensorDataLength, &sensorOffset, nullptr,
1548 &previousEventState);
1549 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1550}
1551
1552TEST(PlatformEventMessage, testGoodNumericSensorEventDataDecodeRequest)
1553{
1554 std::array<uint8_t, PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_MAX_DATA_LENGTH>
1555 eventDataArr{};
1556 struct pldm_sensor_event_numeric_sensor_state* sensorData =
1557 (struct pldm_sensor_event_numeric_sensor_state*)eventDataArr.data();
1558
1559 size_t sensorDataLength =
1560 PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_32BIT_DATA_LENGTH;
1561 uint8_t eventState = PLDM_SENSOR_SHUTTINGDOWN;
1562 uint8_t previousEventState = PLDM_SENSOR_INTEST;
1563 uint8_t sensorDataSize = PLDM_SENSOR_DATA_SIZE_UINT32;
1564 uint32_t presentReading = 305441741;
1565 sensorData->event_state = eventState;
1566 sensorData->previous_event_state = previousEventState;
1567 sensorData->sensor_data_size = sensorDataSize;
1568 sensorData->present_reading[3] =
1569 static_cast<uint8_t>(htole32(presentReading) & (0x000000ff));
1570 sensorData->present_reading[2] =
1571 static_cast<uint8_t>((htole32(presentReading) & (0x0000ff00)) >> 8);
1572 sensorData->present_reading[1] =
1573 static_cast<uint8_t>((htole32(presentReading) & (0x00ff0000)) >> 16);
1574 sensorData->present_reading[0] =
1575 static_cast<uint8_t>((htole32(presentReading) & (0xff000000)) >> 24);
1576
1577 uint8_t retEventState;
1578 uint8_t retPreviousEventState;
1579 uint8_t retSensorDataSize;
1580 uint32_t retPresentReading;
1581
1582 auto rc = decode_numeric_sensor_data(
1583 reinterpret_cast<uint8_t*>(sensorData), sensorDataLength,
1584 &retEventState, &retPreviousEventState, &retSensorDataSize,
1585 &retPresentReading);
1586 EXPECT_EQ(rc, PLDM_SUCCESS);
1587 EXPECT_EQ(retEventState, eventState);
1588 EXPECT_EQ(retPreviousEventState, previousEventState);
1589 EXPECT_EQ(retSensorDataSize, sensorDataSize);
1590 EXPECT_EQ(retPresentReading, presentReading);
1591
1592 int16_t presentReadingNew = -31432;
1593 sensorData->present_reading[1] =
1594 static_cast<uint8_t>(htole16(presentReadingNew) & (0x000000ff));
1595 sensorData->present_reading[0] =
1596 static_cast<uint8_t>((htole16(presentReadingNew) & (0x0000ff00)) >> 8);
1597 sensorDataSize = PLDM_SENSOR_DATA_SIZE_SINT16;
1598 sensorData->sensor_data_size = sensorDataSize;
1599 sensorDataLength = PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_16BIT_DATA_LENGTH;
1600
1601 rc = decode_numeric_sensor_data(reinterpret_cast<uint8_t*>(sensorData),
1602 sensorDataLength, &retEventState,
1603 &retPreviousEventState, &retSensorDataSize,
1604 &retPresentReading);
1605 EXPECT_EQ(rc, PLDM_SUCCESS);
1606 EXPECT_EQ(retEventState, eventState);
1607 EXPECT_EQ(retPreviousEventState, previousEventState);
1608 EXPECT_EQ(retSensorDataSize, sensorDataSize);
1609 EXPECT_EQ(static_cast<int16_t>(retPresentReading), presentReadingNew);
1610}
1611
1612TEST(PlatformEventMessage, testBadNumericSensorEventDataDecodeRequest)
1613{
1614 uint8_t eventState;
1615 uint8_t previousEventState;
1616 uint8_t sensorDataSize;
1617 uint32_t presentReading;
1618 size_t sensorDataLength =
1619 PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_MAX_DATA_LENGTH;
1620 auto rc = decode_numeric_sensor_data(NULL, sensorDataLength, &eventState,
1621 &previousEventState, &sensorDataSize,
1622 &presentReading);
1623 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1624
1625 std::array<uint8_t, PLDM_SENSOR_EVENT_NUMERIC_SENSOR_STATE_MAX_DATA_LENGTH>
1626 sensorData{};
1627 rc = decode_numeric_sensor_data(
1628 reinterpret_cast<uint8_t*>(sensorData.data()), sensorDataLength - 1,
1629 &eventState, &previousEventState, &sensorDataSize, &presentReading);
1630 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1631
1632 struct pldm_sensor_event_numeric_sensor_state* numericSensorData =
1633 (struct pldm_sensor_event_numeric_sensor_state*)sensorData.data();
1634 numericSensorData->sensor_data_size = PLDM_SENSOR_DATA_SIZE_UINT8;
1635 rc = decode_numeric_sensor_data(
1636 reinterpret_cast<uint8_t*>(sensorData.data()), sensorDataLength,
1637 &eventState, &previousEventState, &sensorDataSize, &presentReading);
1638 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1639
1640 numericSensorData->sensor_data_size = PLDM_SENSOR_DATA_SIZE_UINT16;
1641 rc = decode_numeric_sensor_data(
1642 reinterpret_cast<uint8_t*>(sensorData.data()), sensorDataLength,
1643 &eventState, &previousEventState, &sensorDataSize, &presentReading);
1644 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1645
1646 numericSensorData->sensor_data_size = PLDM_SENSOR_DATA_SIZE_UINT32;
1647 rc = decode_numeric_sensor_data(
1648 reinterpret_cast<uint8_t*>(sensorData.data()), sensorDataLength - 1,
1649 &eventState, &previousEventState, &sensorDataSize, &presentReading);
1650 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1651}
1652
1653TEST(GetNumericEffecterValue, testGoodEncodeRequest)
1654{
1655 std::vector<uint8_t> requestMsg(hdrSize +
1656 PLDM_GET_NUMERIC_EFFECTER_VALUE_REQ_BYTES);
1657
1658 uint16_t effecter_id = 0xAB01;
1659
1660 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1661
1662 auto rc = encode_get_numeric_effecter_value_req(0, effecter_id, request);
1663
1664 struct pldm_get_numeric_effecter_value_req* req =
1665 reinterpret_cast<struct pldm_get_numeric_effecter_value_req*>(
1666 request->payload);
1667
1668 EXPECT_EQ(rc, PLDM_SUCCESS);
1669 EXPECT_EQ(effecter_id, le16toh(req->effecter_id));
1670}
1671
1672TEST(GetNumericEffecterValue, testBadEncodeRequest)
1673{
1674 std::vector<uint8_t> requestMsg(
1675 hdrSize + PLDM_SET_NUMERIC_EFFECTER_VALUE_MIN_REQ_BYTES);
1676
1677 auto rc = encode_get_numeric_effecter_value_req(0, 0, nullptr);
1678 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1679}
1680
1681TEST(GetNumericEffecterValue, testGoodDecodeRequest)
1682{
1683 std::array<uint8_t, hdrSize + PLDM_GET_NUMERIC_EFFECTER_VALUE_REQ_BYTES>
1684 requestMsg{};
1685
1686 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1687 struct pldm_get_numeric_effecter_value_req* req =
1688 reinterpret_cast<struct pldm_get_numeric_effecter_value_req*>(
1689 request->payload);
1690
1691 uint16_t effecter_id = 0x12AB;
1692 req->effecter_id = htole16(effecter_id);
1693
1694 uint16_t reteffecter_id;
1695
1696 auto rc = decode_get_numeric_effecter_value_req(
1697 request, requestMsg.size() - hdrSize, &reteffecter_id);
1698
1699 EXPECT_EQ(rc, PLDM_SUCCESS);
1700 EXPECT_EQ(effecter_id, reteffecter_id);
1701}
1702
1703TEST(GetNumericEffecterValue, testBadDecodeRequest)
1704{
1705 std::array<uint8_t, hdrSize + PLDM_GET_NUMERIC_EFFECTER_VALUE_REQ_BYTES>
1706 requestMsg{};
1707
1708 auto rc = decode_get_numeric_effecter_value_req(
1709 nullptr, requestMsg.size() - hdrSize, nullptr);
1710
1711 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1712
1713 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
1714 struct pldm_set_numeric_effecter_value_req* req =
1715 reinterpret_cast<struct pldm_set_numeric_effecter_value_req*>(
1716 request->payload);
1717
1718 uint16_t effecter_id = 0x1A;
1719 req->effecter_id = htole16(effecter_id);
1720 uint16_t reteffecter_id;
1721
1722 rc = decode_get_numeric_effecter_value_req(
1723 request, requestMsg.size() - hdrSize - 1, &reteffecter_id);
1724
1725 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1726}
1727
1728TEST(GetNumericEffecterValue, testGoodEncodeResponse)
1729{
1730 uint8_t completionCode = 0;
1731 uint8_t effecter_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT32;
1732 uint8_t effecter_operState = EFFECTER_OPER_STATE_ENABLED_NOUPDATEPENDING;
1733 uint32_t pendingValue = 0x12345678;
1734 uint32_t presentValue = 0xABCDEF11;
1735
1736 std::array<uint8_t,
1737 hdrSize + PLDM_GET_NUMERIC_EFFECTER_VALUE_MIN_RESP_BYTES + 6>
1738 responseMsg{};
1739 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1740
1741 auto rc = encode_get_numeric_effecter_value_resp(
1742 0, completionCode, effecter_dataSize, effecter_operState,
1743 reinterpret_cast<uint8_t*>(&pendingValue),
1744 reinterpret_cast<uint8_t*>(&presentValue), response,
1745 responseMsg.size() - hdrSize);
1746
1747 struct pldm_get_numeric_effecter_value_resp* resp =
1748 reinterpret_cast<struct pldm_get_numeric_effecter_value_resp*>(
1749 response->payload);
1750
1751 uint32_t* val_pending = (uint32_t*)(&resp->pending_and_present_values[0]);
1752 *val_pending = le32toh(*val_pending);
1753 uint32_t* val_present = (uint32_t*)(&resp->pending_and_present_values[4]);
1754 *val_present = le32toh(*val_present);
1755
1756 EXPECT_EQ(rc, PLDM_SUCCESS);
1757 EXPECT_EQ(effecter_dataSize, resp->effecter_data_size);
1758 EXPECT_EQ(effecter_operState, resp->effecter_oper_state);
1759 EXPECT_EQ(pendingValue, *val_pending);
1760 EXPECT_EQ(presentValue, *val_present);
1761}
1762
1763TEST(GetNumericEffecterValue, testBadEncodeResponse)
1764{
1765 std::array<uint8_t,
1766 hdrSize + PLDM_GET_NUMERIC_EFFECTER_VALUE_MIN_RESP_BYTES + 2>
1767 responseMsg{};
1768 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1769
1770 uint8_t pendingValue = 0x01;
1771 uint8_t presentValue = 0x02;
1772
1773 auto rc = encode_get_numeric_effecter_value_resp(
1774 0, PLDM_SUCCESS, 0, 0, nullptr, nullptr, nullptr,
1775 responseMsg.size() - hdrSize);
1776 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1777
1778 rc = encode_get_numeric_effecter_value_resp(
1779 0, PLDM_SUCCESS, 6, 9, reinterpret_cast<uint8_t*>(&pendingValue),
1780 reinterpret_cast<uint8_t*>(&presentValue), response,
1781 responseMsg.size() - hdrSize);
1782 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1783
1784 uint8_t effecter_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT8;
1785 uint8_t effecter_operState = EFFECTER_OPER_STATE_FAILED;
1786
1787 rc = encode_get_numeric_effecter_value_resp(
1788 0, PLDM_SUCCESS, effecter_dataSize, effecter_operState,
1789 reinterpret_cast<uint8_t*>(&pendingValue),
1790 reinterpret_cast<uint8_t*>(&presentValue), response,
1791 responseMsg.size() - hdrSize);
1792 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1793}
1794
1795TEST(GetNumericEffecterValue, testGoodDecodeResponse)
1796{
1797 std::array<uint8_t,
1798 hdrSize + PLDM_GET_NUMERIC_EFFECTER_VALUE_MIN_RESP_BYTES + 2>
1799 responseMsg{};
1800
1801 uint8_t completionCode = 0;
1802 uint8_t effecter_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT16;
1803 uint8_t effecter_operState = EFFECTER_OPER_STATE_ENABLED_NOUPDATEPENDING;
1804 uint16_t pendingValue = 0x4321;
1805 uint16_t presentValue = 0xDCBA;
1806
1807 uint8_t retcompletionCode;
1808 uint8_t reteffecter_dataSize;
1809 uint8_t reteffecter_operState;
1810 uint8_t retpendingValue[2];
1811 uint8_t retpresentValue[2];
1812
1813 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1814 struct pldm_get_numeric_effecter_value_resp* resp =
1815 reinterpret_cast<struct pldm_get_numeric_effecter_value_resp*>(
1816 response->payload);
1817
1818 resp->completion_code = completionCode;
1819 resp->effecter_data_size = effecter_dataSize;
1820 resp->effecter_oper_state = effecter_operState;
1821
1822 uint16_t pendingValue_le = htole16(pendingValue);
1823 memcpy(resp->pending_and_present_values, &pendingValue_le,
1824 sizeof(pendingValue_le));
1825 uint16_t presentValue_le = htole16(presentValue);
1826 memcpy(&resp->pending_and_present_values[2], &presentValue_le,
1827 sizeof(presentValue_le));
1828
1829 auto rc = decode_get_numeric_effecter_value_resp(
1830 response, responseMsg.size() - hdrSize, &retcompletionCode,
1831 &reteffecter_dataSize, &reteffecter_operState, retpendingValue,
1832 retpresentValue);
1833
1834 EXPECT_EQ(rc, PLDM_SUCCESS);
1835 EXPECT_EQ(completionCode, retcompletionCode);
1836 EXPECT_EQ(effecter_dataSize, reteffecter_dataSize);
1837 EXPECT_EQ(effecter_operState, reteffecter_operState);
1838 EXPECT_EQ(pendingValue, *(reinterpret_cast<uint16_t*>(retpendingValue)));
1839 EXPECT_EQ(presentValue, *(reinterpret_cast<uint16_t*>(retpresentValue)));
1840}
1841
1842TEST(GetNumericEffecterValue, testBadDecodeResponse)
1843{
1844 std::array<uint8_t,
1845 hdrSize + PLDM_GET_NUMERIC_EFFECTER_VALUE_MIN_RESP_BYTES + 6>
1846 responseMsg{};
1847
1848 auto rc = decode_get_numeric_effecter_value_resp(
1849 nullptr, responseMsg.size() - hdrSize, nullptr, nullptr, nullptr,
1850 nullptr, nullptr);
1851
1852 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1853
1854 uint8_t completionCode = 0;
1855 uint8_t effecter_dataSize = PLDM_EFFECTER_DATA_SIZE_SINT16;
1856 uint8_t effecter_operState = EFFECTER_OPER_STATE_DISABLED;
1857 uint16_t pendingValue = 0x5678;
1858 uint16_t presentValue = 0xCDEF;
1859
1860 uint8_t retcompletionCode;
1861 uint8_t reteffecter_dataSize;
1862 uint8_t reteffecter_operState;
1863 uint8_t retpendingValue[2];
1864 uint8_t retpresentValue[2];
1865
1866 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
1867 struct pldm_get_numeric_effecter_value_resp* resp =
1868 reinterpret_cast<struct pldm_get_numeric_effecter_value_resp*>(
1869 response->payload);
1870
1871 resp->completion_code = completionCode;
1872 resp->effecter_data_size = effecter_dataSize;
1873 resp->effecter_oper_state = effecter_operState;
1874
1875 uint16_t pendingValue_le = htole16(pendingValue);
1876 memcpy(resp->pending_and_present_values, &pendingValue_le,
1877 sizeof(pendingValue_le));
1878 uint16_t presentValue_le = htole16(presentValue);
1879 memcpy(&resp->pending_and_present_values[2], &presentValue_le,
1880 sizeof(presentValue_le));
1881
1882 rc = decode_get_numeric_effecter_value_resp(
1883 response, responseMsg.size() - hdrSize, &retcompletionCode,
1884 &reteffecter_dataSize, &reteffecter_operState, retpendingValue,
1885 retpresentValue);
1886
1887 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1888}
1889
1890TEST(PldmPDRRepositoryChgEventEvent, testGoodDecodeRequest)
1891{
1892 const uint8_t eventDataFormat = FORMAT_IS_PDR_HANDLES;
1893 const uint8_t numberOfChangeRecords = 2;
1894 uint8_t eventDataOperation1 = PLDM_RECORDS_DELETED;
1895 const uint8_t numberOfChangeEntries1 = 2;
1896 std::array<uint32_t, numberOfChangeEntries1> changeRecordArr1{
1897 {0x00000000, 0x12345678}};
1898 uint8_t eventDataOperation2 = PLDM_RECORDS_ADDED;
1899 const uint8_t numberOfChangeEntries2 = 5;
1900 std::array<uint32_t, numberOfChangeEntries2> changeRecordArr2{
1901 {0x01234567, 0x11223344, 0x45678901, 0x21222324, 0x98765432}};
1902 std::array<uint8_t, PLDM_PDR_REPOSITORY_CHG_EVENT_MIN_LENGTH +
1903 PLDM_PDR_REPOSITORY_CHANGE_RECORD_MIN_LENGTH *
1904 numberOfChangeRecords +
1905 (numberOfChangeEntries1 + numberOfChangeEntries2) *
1906 sizeof(uint32_t)>
1907 eventDataArr{};
1908
1909 struct pldm_pdr_repository_chg_event_data* eventData =
1910 reinterpret_cast<struct pldm_pdr_repository_chg_event_data*>(
1911 eventDataArr.data());
1912 eventData->event_data_format = eventDataFormat;
1913 eventData->number_of_change_records = numberOfChangeRecords;
1914 struct pldm_pdr_repository_change_record_data* changeRecord1 =
1915 reinterpret_cast<struct pldm_pdr_repository_change_record_data*>(
1916 eventData->change_records);
1917 changeRecord1->event_data_operation = eventDataOperation1;
1918 changeRecord1->number_of_change_entries = numberOfChangeEntries1;
1919 memcpy(changeRecord1->change_entry, &changeRecordArr1[0],
1920 changeRecordArr1.size() * sizeof(uint32_t));
1921 struct pldm_pdr_repository_change_record_data* changeRecord2 =
1922 reinterpret_cast<struct pldm_pdr_repository_change_record_data*>(
1923 eventData->change_records +
1924 PLDM_PDR_REPOSITORY_CHANGE_RECORD_MIN_LENGTH +
1925 (changeRecordArr1.size() * sizeof(uint32_t)));
1926 changeRecord2->event_data_operation = eventDataOperation2;
1927 changeRecord2->number_of_change_entries = numberOfChangeEntries2;
1928 memcpy(changeRecord2->change_entry, &changeRecordArr2[0],
1929 changeRecordArr2.size() * sizeof(uint32_t));
1930
1931 uint8_t retEventDataFormat{};
1932 uint8_t retNumberOfChangeRecords{};
1933 size_t retChangeRecordDataOffset{0};
1934 auto rc = decode_pldm_pdr_repository_chg_event_data(
1935 reinterpret_cast<const uint8_t*>(eventData), eventDataArr.size(),
1936 &retEventDataFormat, &retNumberOfChangeRecords,
1937 &retChangeRecordDataOffset);
1938 EXPECT_EQ(rc, PLDM_SUCCESS);
1939 EXPECT_EQ(retEventDataFormat, FORMAT_IS_PDR_HANDLES);
1940 EXPECT_EQ(retNumberOfChangeRecords, numberOfChangeRecords);
1941
1942 const uint8_t* changeRecordData =
1943 reinterpret_cast<const uint8_t*>(changeRecord1);
1944 size_t changeRecordDataSize =
1945 eventDataArr.size() - PLDM_PDR_REPOSITORY_CHG_EVENT_MIN_LENGTH;
1946 uint8_t retEventDataOperation;
1947 uint8_t retNumberOfChangeEntries;
1948 size_t retChangeEntryDataOffset;
1949
1950 rc = decode_pldm_pdr_repository_change_record_data(
1951 reinterpret_cast<const uint8_t*>(changeRecordData),
1952 changeRecordDataSize, &retEventDataOperation, &retNumberOfChangeEntries,
1953 &retChangeEntryDataOffset);
1954 EXPECT_EQ(rc, PLDM_SUCCESS);
1955 EXPECT_EQ(retEventDataOperation, eventDataOperation1);
1956 EXPECT_EQ(retNumberOfChangeEntries, numberOfChangeEntries1);
1957 changeRecordData += retChangeEntryDataOffset;
1958 EXPECT_EQ(0, memcmp(changeRecordData, &changeRecordArr1[0],
1959 sizeof(uint32_t) * retNumberOfChangeEntries));
1960
1961 changeRecordData += sizeof(uint32_t) * retNumberOfChangeEntries;
1962 changeRecordDataSize -= sizeof(uint32_t) * retNumberOfChangeEntries -
1963 PLDM_PDR_REPOSITORY_CHANGE_RECORD_MIN_LENGTH;
1964 rc = decode_pldm_pdr_repository_change_record_data(
1965 reinterpret_cast<const uint8_t*>(changeRecordData),
1966 changeRecordDataSize, &retEventDataOperation, &retNumberOfChangeEntries,
1967 &retChangeEntryDataOffset);
1968 EXPECT_EQ(rc, PLDM_SUCCESS);
1969 EXPECT_EQ(retEventDataOperation, eventDataOperation2);
1970 EXPECT_EQ(retNumberOfChangeEntries, numberOfChangeEntries2);
1971 changeRecordData += retChangeEntryDataOffset;
1972 EXPECT_EQ(0, memcmp(changeRecordData, &changeRecordArr2[0],
1973 sizeof(uint32_t) * retNumberOfChangeEntries));
1974}
1975
1976TEST(PldmPDRRepositoryChgEventEvent, testBadDecodeRequest)
1977{
1978 uint8_t eventDataFormat{};
1979 uint8_t numberOfChangeRecords{};
1980 size_t changeRecordDataOffset{};
1981 auto rc = decode_pldm_pdr_repository_chg_event_data(
1982 NULL, 0, &eventDataFormat, &numberOfChangeRecords,
1983 &changeRecordDataOffset);
1984 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1985
1986 std::array<uint8_t, 2> eventData{};
1987 rc = decode_pldm_pdr_repository_chg_event_data(
1988 reinterpret_cast<const uint8_t*>(eventData.data()), 0, &eventDataFormat,
1989 &numberOfChangeRecords, &changeRecordDataOffset);
1990 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
1991
1992 uint8_t eventDataOperation{};
1993 uint8_t numberOfChangeEntries{};
1994 size_t changeEntryDataOffset{};
1995 rc = decode_pldm_pdr_repository_change_record_data(
1996 NULL, 0, &eventDataOperation, &numberOfChangeEntries,
1997 &changeEntryDataOffset);
1998 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
1999
2000 std::array<uint8_t, 2> changeRecord{};
2001 rc = decode_pldm_pdr_repository_change_record_data(
2002 reinterpret_cast<const uint8_t*>(changeRecord.data()), 0,
2003 &eventDataOperation, &numberOfChangeEntries, &changeEntryDataOffset);
2004 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
2005}
2006
2007TEST(GetSensorReading, testGoodEncodeRequest)
2008{
2009 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_REQ_BYTES>
2010 requestMsg{};
2011
2012 uint16_t sensorId = 0x1234;
2013 bool8_t rearmEventState = 0x01;
2014
2015 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2016 auto rc =
2017 encode_get_sensor_reading_req(0, sensorId, rearmEventState, request);
2018
2019 struct pldm_get_sensor_reading_req* req =
2020 reinterpret_cast<struct pldm_get_sensor_reading_req*>(request->payload);
2021
2022 EXPECT_EQ(rc, PLDM_SUCCESS);
2023 EXPECT_EQ(sensorId, le16toh(req->sensor_id));
2024 EXPECT_EQ(rearmEventState, req->rearm_event_state);
2025}
2026
2027TEST(GetSensorReading, testBadEncodeRequest)
2028{
2029 auto rc = encode_get_sensor_reading_req(0, 0, 0, nullptr);
2030
2031 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2032}
2033
2034TEST(GetSensorReading, testGoodDecodeRequest)
2035{
2036 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_REQ_BYTES>
2037 requestMsg{};
2038
2039 uint16_t sensorId = 0xABCD;
2040 bool8_t rearmEventState = 0xA;
2041
2042 uint16_t retsensorId;
2043 bool8_t retrearmEventState;
2044
2045 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2046
2047 struct pldm_get_sensor_reading_req* req =
2048 reinterpret_cast<struct pldm_get_sensor_reading_req*>(request->payload);
2049
2050 req->sensor_id = htole16(sensorId);
2051 req->rearm_event_state = rearmEventState;
2052
2053 auto rc =
2054 decode_get_sensor_reading_req(request, requestMsg.size() - hdrSize,
2055 &retsensorId, &retrearmEventState);
2056
2057 EXPECT_EQ(rc, PLDM_SUCCESS);
2058 EXPECT_EQ(sensorId, retsensorId);
2059 EXPECT_EQ(rearmEventState, retrearmEventState);
2060}
2061
2062TEST(GetSensorReading, testBadDecodeRequest)
2063{
2064 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_REQ_BYTES>
2065 requestMsg{};
2066
2067 auto rc = decode_get_sensor_reading_req(
2068 nullptr, requestMsg.size() - hdrSize, nullptr, nullptr);
2069 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2070
2071 uint16_t sensorId = 0xABCD;
2072 bool8_t rearmEventState = 0xA;
2073
2074 uint16_t retsensorId;
2075 bool8_t retrearmEventState;
2076
2077 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2078
2079 struct pldm_get_sensor_reading_req* req =
2080 reinterpret_cast<struct pldm_get_sensor_reading_req*>(request->payload);
2081
2082 req->sensor_id = htole16(sensorId);
2083 req->rearm_event_state = rearmEventState;
2084
2085 rc = decode_get_sensor_reading_req(request, requestMsg.size() - hdrSize - 1,
2086 &retsensorId, &retrearmEventState);
2087
2088 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
2089}
2090
2091TEST(GetSensorReading, testGoodEncodeResponse)
2092{
2093 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_MIN_RESP_BYTES>
2094 responseMsg{};
2095
2096 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2097
2098 uint8_t completionCode = 0;
2099 uint8_t sensor_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT8;
2100 uint8_t sensor_operationalState = PLDM_SENSOR_ENABLED;
2101 uint8_t sensor_event_messageEnable = PLDM_NO_EVENT_GENERATION;
2102 uint8_t presentState = PLDM_SENSOR_NORMAL;
2103 uint8_t previousState = PLDM_SENSOR_WARNING;
2104 uint8_t eventState = PLDM_SENSOR_UPPERWARNING;
2105 uint8_t presentReading = 0x21;
2106
2107 auto rc = encode_get_sensor_reading_resp(
2108 0, completionCode, sensor_dataSize, sensor_operationalState,
2109 sensor_event_messageEnable, presentState, previousState, eventState,
2110 reinterpret_cast<uint8_t*>(&presentReading), response,
2111 responseMsg.size() - hdrSize);
2112
2113 struct pldm_get_sensor_reading_resp* resp =
2114 reinterpret_cast<struct pldm_get_sensor_reading_resp*>(
2115 response->payload);
2116
2117 EXPECT_EQ(rc, PLDM_SUCCESS);
2118 EXPECT_EQ(completionCode, resp->completion_code);
2119 EXPECT_EQ(sensor_dataSize, resp->sensor_data_size);
2120 EXPECT_EQ(sensor_operationalState, resp->sensor_operational_state);
2121 EXPECT_EQ(sensor_event_messageEnable, resp->sensor_event_message_enable);
2122 EXPECT_EQ(presentState, resp->present_state);
2123 EXPECT_EQ(previousState, resp->previous_state);
2124 EXPECT_EQ(eventState, resp->event_state);
2125 EXPECT_EQ(presentReading,
2126 *(reinterpret_cast<uint8_t*>(&resp->present_reading[0])));
2127}
2128
2129TEST(GetSensorReading, testBadEncodeResponse)
2130{
2131 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_MIN_RESP_BYTES + 3>
2132 responseMsg{};
2133
2134 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2135
2136 uint8_t presentReading = 0x1;
2137
2138 auto rc = encode_get_sensor_reading_resp(0, PLDM_SUCCESS, 0, 0, 0, 0, 0, 0,
2139 nullptr, nullptr,
2140 responseMsg.size() - hdrSize);
2141 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2142
2143 rc = encode_get_sensor_reading_resp(
2144 0, PLDM_SUCCESS, 6, 1, 1, 1, 1, 1,
2145 reinterpret_cast<uint8_t*>(&presentReading), response,
2146 responseMsg.size() - hdrSize);
2147 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2148
2149 uint8_t sensor_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT8;
2150
2151 rc = encode_get_sensor_reading_resp(
2152 0, PLDM_SUCCESS, sensor_dataSize, 1, 1, 1, 1, 1,
2153 reinterpret_cast<uint8_t*>(&presentReading), response,
2154 responseMsg.size() - hdrSize);
2155 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
2156}
2157
2158TEST(GetSensorReading, testGoodDecodeResponse)
2159{
2160 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_MIN_RESP_BYTES + 3>
2161 responseMsg{};
2162
2163 uint8_t completionCode = 0;
2164 uint8_t sensor_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT32;
2165 uint8_t sensor_operationalState = PLDM_SENSOR_STATUSUNKOWN;
2166 uint8_t sensor_event_messageEnable = PLDM_EVENTS_ENABLED;
2167 uint8_t presentState = PLDM_SENSOR_CRITICAL;
2168 uint8_t previousState = PLDM_SENSOR_UPPERCRITICAL;
2169 uint8_t eventState = PLDM_SENSOR_WARNING;
2170 uint32_t presentReading = 0xABCDEF11;
2171
2172 uint8_t retcompletionCode;
2173 uint8_t retsensor_dataSize = PLDM_SENSOR_DATA_SIZE_UINT32;
2174 uint8_t retsensor_operationalState;
2175 uint8_t retsensor_event_messageEnable;
2176 uint8_t retpresentState;
2177 uint8_t retpreviousState;
2178 uint8_t reteventState;
2179 uint8_t retpresentReading[4];
2180
2181 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2182 struct pldm_get_sensor_reading_resp* resp =
2183 reinterpret_cast<struct pldm_get_sensor_reading_resp*>(
2184 response->payload);
2185
2186 resp->completion_code = completionCode;
2187 resp->sensor_data_size = sensor_dataSize;
2188 resp->sensor_operational_state = sensor_operationalState;
2189 resp->sensor_event_message_enable = sensor_event_messageEnable;
2190 resp->present_state = presentState;
2191 resp->previous_state = previousState;
2192 resp->event_state = eventState;
2193
2194 uint32_t presentReading_le = htole32(presentReading);
2195 memcpy(resp->present_reading, &presentReading_le,
2196 sizeof(presentReading_le));
2197
2198 auto rc = decode_get_sensor_reading_resp(
2199 response, responseMsg.size() - hdrSize, &retcompletionCode,
2200 &retsensor_dataSize, &retsensor_operationalState,
2201 &retsensor_event_messageEnable, &retpresentState, &retpreviousState,
2202 &reteventState, retpresentReading);
2203
2204 EXPECT_EQ(rc, PLDM_SUCCESS);
2205 EXPECT_EQ(completionCode, retcompletionCode);
2206 EXPECT_EQ(sensor_dataSize, retsensor_dataSize);
2207 EXPECT_EQ(sensor_operationalState, retsensor_operationalState);
2208 EXPECT_EQ(sensor_event_messageEnable, retsensor_event_messageEnable);
2209 EXPECT_EQ(presentState, retpresentState);
2210 EXPECT_EQ(previousState, retpreviousState);
2211 EXPECT_EQ(eventState, reteventState);
2212 EXPECT_EQ(presentReading,
2213 *(reinterpret_cast<uint32_t*>(retpresentReading)));
2214}
2215
2216TEST(GetSensorReading, testBadDecodeResponse)
2217{
2218 std::array<uint8_t, hdrSize + PLDM_GET_SENSOR_READING_MIN_RESP_BYTES + 1>
2219 responseMsg{};
2220
2221 auto rc = decode_get_sensor_reading_resp(
2222 nullptr, responseMsg.size() - hdrSize, nullptr, nullptr, nullptr,
2223 nullptr, nullptr, nullptr, nullptr, nullptr);
2224
2225 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2226
2227 uint8_t completionCode = 0;
2228 uint8_t sensor_dataSize = PLDM_EFFECTER_DATA_SIZE_UINT8;
2229 uint8_t sensor_operationalState = PLDM_SENSOR_INTEST;
2230 uint8_t sensor_event_messageEnable = PLDM_EVENTS_DISABLED;
2231 uint8_t presentState = PLDM_SENSOR_FATAL;
2232 uint8_t previousState = PLDM_SENSOR_UPPERFATAL;
2233 uint8_t eventState = PLDM_SENSOR_WARNING;
2234 uint8_t presentReading = 0xA;
2235
2236 uint8_t retcompletionCode;
2237 uint8_t retsensor_dataSize = PLDM_SENSOR_DATA_SIZE_SINT16;
2238 uint8_t retsensor_operationalState;
2239 uint8_t retsensor_event_messageEnable;
2240 uint8_t retpresent_state;
2241 uint8_t retprevious_state;
2242 uint8_t retevent_state;
2243 uint8_t retpresentReading;
2244
2245 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2246 struct pldm_get_sensor_reading_resp* resp =
2247 reinterpret_cast<struct pldm_get_sensor_reading_resp*>(
2248 response->payload);
2249
2250 resp->completion_code = completionCode;
2251 resp->sensor_data_size = sensor_dataSize;
2252 resp->sensor_operational_state = sensor_operationalState;
2253 resp->sensor_event_message_enable = sensor_event_messageEnable;
2254 resp->present_state = presentState;
2255 resp->previous_state = previousState;
2256 resp->event_state = eventState;
2257 resp->present_reading[0] = presentReading;
2258
2259 rc = decode_get_sensor_reading_resp(
2260 response, responseMsg.size() - hdrSize, &retcompletionCode,
2261 &retsensor_dataSize, &retsensor_operationalState,
2262 &retsensor_event_messageEnable, &retpresent_state, &retprevious_state,
2263 &retevent_state, reinterpret_cast<uint8_t*>(&retpresentReading));
2264
2265 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
2266}
2267
2268TEST(SetEventReceiver, testGoodEncodeRequest)
2269{
2270 uint8_t eventMessageGlobalEnable =
2271 PLDM_EVENT_MESSAGE_GLOBAL_ENABLE_ASYNC_KEEP_ALIVE;
2272 uint8_t transportProtocolType = PLDM_TRANSPORT_PROTOCOL_TYPE_MCTP;
2273 uint8_t eventReceiverAddressInfo = 0x08;
2274 uint16_t heartbeatTimer = 0x78;
2275
2276 std::vector<uint8_t> requestMsg(hdrSize +
2277 PLDM_SET_EVENT_RECEIVER_REQ_BYTES);
2278 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2279
2280 auto rc = encode_set_event_receiver_req(
2281 0, eventMessageGlobalEnable, transportProtocolType,
2282 eventReceiverAddressInfo, heartbeatTimer, request);
2283
2284 EXPECT_EQ(rc, PLDM_SUCCESS);
2285 struct pldm_set_event_receiver_req* req =
2286 reinterpret_cast<struct pldm_set_event_receiver_req*>(request->payload);
2287 EXPECT_EQ(eventMessageGlobalEnable, req->event_message_global_enable);
2288 EXPECT_EQ(transportProtocolType, req->transport_protocol_type);
2289 EXPECT_EQ(eventReceiverAddressInfo, req->event_receiver_address_info);
2290 EXPECT_EQ(heartbeatTimer, le16toh(req->heartbeat_timer));
2291}
2292
2293TEST(SetEventReceiver, testBadEncodeRequest)
2294{
2295 uint8_t eventMessageGlobalEnable =
2296 PLDM_EVENT_MESSAGE_GLOBAL_ENABLE_ASYNC_KEEP_ALIVE;
2297 uint8_t transportProtocolType = PLDM_TRANSPORT_PROTOCOL_TYPE_MCTP;
2298 uint8_t eventReceiverAddressInfo = 0x08;
2299 uint16_t heartbeatTimer = 0;
2300
2301 std::vector<uint8_t> requestMsg(hdrSize +
2302 PLDM_SET_EVENT_RECEIVER_REQ_BYTES);
2303 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2304
2305 auto rc = encode_set_event_receiver_req(
2306 0, eventMessageGlobalEnable, transportProtocolType,
2307 eventReceiverAddressInfo, heartbeatTimer, request);
2308
2309 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2310}
2311
2312TEST(SetEventReceiver, testGoodDecodeResponse)
2313{
2314 std::array<uint8_t, hdrSize + PLDM_SET_EVENT_RECEIVER_RESP_BYTES>
2315 responseMsg{};
2316
2317 uint8_t retcompletion_code = 0;
2318 responseMsg[hdrSize] = PLDM_SUCCESS;
2319
2320 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2321 auto rc = decode_set_event_receiver_resp(
2322 response, responseMsg.size() - sizeof(pldm_msg_hdr),
2323 &retcompletion_code);
2324
2325 EXPECT_EQ(rc, PLDM_SUCCESS);
2326 EXPECT_EQ(PLDM_SUCCESS, retcompletion_code);
2327}
2328
2329TEST(SetEventReceiver, testBadDecodeResponse)
2330{
2331 std::array<uint8_t, hdrSize + PLDM_SET_EVENT_RECEIVER_RESP_BYTES>
2332 responseMsg{};
2333 uint8_t retcompletion_code = 0;
2334 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2335
2336 auto rc = decode_set_event_receiver_resp(
2337 response, responseMsg.size() - sizeof(pldm_msg_hdr), NULL);
2338
2339 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2340
2341 rc = decode_set_event_receiver_resp(
2342 nullptr, responseMsg.size() - sizeof(pldm_msg_hdr),
2343 &retcompletion_code);
2344
2345 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2346}
2347
2348TEST(SetEventReceiver, testGoodEncodeResponse)
2349{
2350 std::array<uint8_t,
2351 sizeof(pldm_msg_hdr) + PLDM_SET_EVENT_RECEIVER_RESP_BYTES>
2352 responseMsg{};
2353 auto response = reinterpret_cast<pldm_msg*>(responseMsg.data());
2354 uint8_t completionCode = 0;
2355
2356 auto rc = encode_set_event_receiver_resp(0, PLDM_SUCCESS, response);
2357
2358 EXPECT_EQ(rc, PLDM_SUCCESS);
2359 EXPECT_EQ(completionCode, response->payload[0]);
2360}
2361
2362TEST(SetEventReceiver, testBadEncodeResponse)
2363{
2364 auto rc = encode_set_event_receiver_resp(0, PLDM_SUCCESS, NULL);
2365 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2366}
2367
2368TEST(SetEventReceiver, testGoodDecodeRequest)
2369{
2370
2371 std::array<uint8_t, hdrSize + PLDM_SET_EVENT_RECEIVER_REQ_BYTES>
2372 requestMsg{};
2373
2374 uint8_t eventMessageGlobalEnable =
2375 PLDM_EVENT_MESSAGE_GLOBAL_ENABLE_ASYNC_KEEP_ALIVE;
2376 uint8_t transportProtocolType = PLDM_TRANSPORT_PROTOCOL_TYPE_MCTP;
2377 uint8_t eventReceiverAddressInfo = 0x08;
2378 uint16_t heartbeatTimer = 0x78;
2379
2380 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2381 struct pldm_set_event_receiver_req* req =
2382 reinterpret_cast<struct pldm_set_event_receiver_req*>(request->payload);
2383
2384 req->event_message_global_enable = eventMessageGlobalEnable;
2385 req->transport_protocol_type = transportProtocolType;
2386 req->event_receiver_address_info = eventReceiverAddressInfo;
2387 req->heartbeat_timer = htole16(heartbeatTimer);
2388
2389 uint8_t reteventMessageGlobalEnable;
2390 uint8_t rettransportProtocolType;
2391 uint8_t reteventReceiverAddressInfo;
2392 uint16_t retheartbeatTimer;
2393 auto rc = decode_set_event_receiver_req(
2394 request, requestMsg.size() - hdrSize, &reteventMessageGlobalEnable,
2395 &rettransportProtocolType, &reteventReceiverAddressInfo,
2396 &retheartbeatTimer);
2397
2398 EXPECT_EQ(rc, PLDM_SUCCESS);
2399 EXPECT_EQ(eventMessageGlobalEnable, reteventMessageGlobalEnable);
2400 EXPECT_EQ(transportProtocolType, rettransportProtocolType);
2401 EXPECT_EQ(eventReceiverAddressInfo, reteventReceiverAddressInfo);
2402 EXPECT_EQ(heartbeatTimer, retheartbeatTimer);
2403}
2404
2405TEST(SetEventReceiver, testBadDecodeRequest)
2406{
2407 std::array<uint8_t, hdrSize + PLDM_SET_EVENT_RECEIVER_REQ_BYTES>
2408 requestMsg{};
2409
2410 auto rc = decode_set_event_receiver_req(NULL, requestMsg.size() - hdrSize,
2411 NULL, NULL, NULL, NULL);
2412 EXPECT_EQ(rc, PLDM_ERROR_INVALID_DATA);
2413
2414 uint8_t eventMessageGlobalEnable =
2415 PLDM_EVENT_MESSAGE_GLOBAL_ENABLE_ASYNC_KEEP_ALIVE;
2416 uint8_t transportProtocolType = PLDM_TRANSPORT_PROTOCOL_TYPE_MCTP;
2417 uint8_t eventReceiverAddressInfo = 0x08;
2418 uint16_t heartbeatTimer = 0x78;
2419
2420 auto request = reinterpret_cast<pldm_msg*>(requestMsg.data());
2421 struct pldm_set_event_receiver_req* req =
2422 reinterpret_cast<struct pldm_set_event_receiver_req*>(request->payload);
2423
2424 req->event_message_global_enable = eventMessageGlobalEnable;
2425 req->transport_protocol_type = transportProtocolType;
2426 req->event_receiver_address_info = eventReceiverAddressInfo;
2427 req->heartbeat_timer = htole16(heartbeatTimer);
2428
2429 uint8_t reteventMessageGlobalEnable;
2430 uint8_t rettransportProtocolType;
2431 uint8_t reteventReceiverAddressInfo;
2432 uint16_t retheartbeatTimer;
2433 rc = decode_set_event_receiver_req(
2434 request, requestMsg.size() - hdrSize - 1, &reteventMessageGlobalEnable,
2435 &rettransportProtocolType, &reteventReceiverAddressInfo,
2436 &retheartbeatTimer);
2437 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
2438}
Andrew Jeffery7992eb82023-04-06 16:13:53 +09302439
2440TEST(decodeNumericSensorPdrData, Uint8Test)
2441{
2442 std::vector<uint8_t> pdr1{
2443 0x1,
2444 0x0,
2445 0x0,
2446 0x0, // record handle
2447 0x1, // PDRHeaderVersion
2448 PLDM_NUMERIC_SENSOR_PDR, // PDRType
2449 0x0,
2450 0x0, // recordChangeNumber
2451 PLDM_PDR_NUMERIC_SENSOR_PDR_MIN_LENGTH,
2452 0, // dataLength
2453 0,
2454 0, // PLDMTerminusHandle
2455 0x1,
2456 0x0, // sensorID=1
2457 PLDM_ENTITY_POWER_SUPPLY,
2458 0, // entityType=Power Supply(120)
2459 1,
2460 0, // entityInstanceNumber
2461 1,
2462 0, // containerID=1
2463 PLDM_NO_INIT, // sensorInit
2464 false, // sensorAuxiliaryNamesPDR
2465 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
2466 0, // unitModifier
2467 0, // rateUnit
2468 0, // baseOEMUnitHandle
2469 0, // auxUnit
2470 0, // auxUnitModifier
2471 0, // auxRateUnit
2472 0, // rel
2473 0, // auxOEMUnitHandle
2474 true, // isLinear
2475 PLDM_SENSOR_DATA_SIZE_UINT8, // sensorDataSize
2476 0,
2477 0,
2478 0xc0,
2479 0x3f, // resolution=1.5
2480 0,
2481 0,
2482 0x80,
2483 0x3f, // offset=1.0
2484 0,
2485 0, // accuracy
2486 0, // plusTolerance
2487 0, // minusTolerance
2488 3, // hysteresis = 3
2489 0, // supportedThresholds
2490 0, // thresholdAndHysteresisVolatility
2491 0,
2492 0,
2493 0x80,
2494 0x3f, // stateTransistionInterval=1.0
2495 0,
2496 0,
2497 0x80,
2498 0x3f, // updateInverval=1.0
2499 255, // maxReadable
2500 0, // minReadable
2501 PLDM_RANGE_FIELD_FORMAT_UINT8, // rangeFieldFormat
2502 0, // rangeFieldsupport
2503 50, // nominalValue = 50
2504 60, // normalMax = 60
2505 40, // normalMin = 40
2506 70, // warningHigh = 70
2507 30, // warningLow = 30
2508 80, // criticalHigh = 80
2509 20, // criticalLow = 20
2510 90, // fatalHigh = 90
2511 10 // fatalLow = 10
2512 };
2513
2514 struct pldm_numeric_sensor_value_pdr decodedPdr;
2515 auto rc =
2516 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
2517 EXPECT_EQ(PLDM_SUCCESS, rc);
2518 EXPECT_EQ(1, decodedPdr.hdr.record_handle);
2519 EXPECT_EQ(1, decodedPdr.hdr.version);
2520 EXPECT_EQ(PLDM_NUMERIC_SENSOR_PDR, decodedPdr.hdr.type);
2521 EXPECT_EQ(0, decodedPdr.hdr.record_change_num);
2522 EXPECT_EQ(PLDM_PDR_NUMERIC_SENSOR_PDR_MIN_LENGTH, decodedPdr.hdr.length);
2523 EXPECT_EQ(1, decodedPdr.sensor_id);
2524 EXPECT_EQ(PLDM_ENTITY_POWER_SUPPLY, decodedPdr.entity_type);
2525 EXPECT_EQ(1, decodedPdr.entity_instance_num);
2526 EXPECT_EQ(1, decodedPdr.container_id);
2527 EXPECT_EQ(PLDM_NO_INIT, decodedPdr.sensor_init);
2528 EXPECT_EQ(false, decodedPdr.sensor_auxiliary_names_pdr);
2529 EXPECT_EQ(PLDM_SENSOR_UNIT_DEGRESS_C, decodedPdr.base_unit);
2530 EXPECT_EQ(0, decodedPdr.unit_modifier);
2531 EXPECT_EQ(0, decodedPdr.rate_unit);
2532 EXPECT_EQ(0, decodedPdr.base_oem_unit_handle);
2533 EXPECT_EQ(0, decodedPdr.aux_unit);
2534 EXPECT_EQ(0, decodedPdr.aux_unit_modifier);
2535 EXPECT_EQ(0, decodedPdr.aux_rate_unit);
2536 EXPECT_EQ(0, decodedPdr.rel);
2537 EXPECT_EQ(0, decodedPdr.aux_oem_unit_handle);
2538 EXPECT_EQ(true, decodedPdr.is_linear);
2539 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_UINT8, decodedPdr.sensor_data_size);
2540 EXPECT_FLOAT_EQ(1.5f, decodedPdr.resolution);
2541 EXPECT_FLOAT_EQ(1.0f, decodedPdr.offset);
2542 EXPECT_EQ(0, decodedPdr.accuracy);
2543 EXPECT_EQ(0, decodedPdr.plus_tolerance);
2544 EXPECT_EQ(0, decodedPdr.minus_tolerance);
2545 EXPECT_EQ(3, decodedPdr.hysteresis.value_u8);
2546 EXPECT_EQ(0, decodedPdr.supported_thresholds.byte);
2547 EXPECT_EQ(0, decodedPdr.threshold_and_hysteresis_volatility.byte);
2548 EXPECT_FLOAT_EQ(1.0f, decodedPdr.state_transition_interval);
2549 EXPECT_FLOAT_EQ(1.0f, decodedPdr.update_interval);
2550 EXPECT_EQ(255, decodedPdr.max_readable.value_u8);
2551 EXPECT_EQ(0, decodedPdr.min_readable.value_u8);
2552 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_UINT8, decodedPdr.range_field_format);
2553 EXPECT_EQ(0, decodedPdr.range_field_support.byte);
2554 EXPECT_EQ(50, decodedPdr.nominal_value.value_u8);
2555 EXPECT_EQ(60, decodedPdr.normal_max.value_u8);
2556 EXPECT_EQ(40, decodedPdr.normal_min.value_u8);
2557 EXPECT_EQ(70, decodedPdr.warning_high.value_u8);
2558 EXPECT_EQ(30, decodedPdr.warning_low.value_u8);
2559 EXPECT_EQ(80, decodedPdr.critical_high.value_u8);
2560 EXPECT_EQ(20, decodedPdr.critical_low.value_u8);
2561 EXPECT_EQ(90, decodedPdr.fatal_high.value_u8);
2562 EXPECT_EQ(10, decodedPdr.fatal_low.value_u8);
2563}
2564
2565TEST(decodeNumericSensorPdrData, Sint8Test)
2566{
2567 std::vector<uint8_t> pdr1{
2568 0x1,
2569 0x0,
2570 0x0,
2571 0x0, // record handle
2572 0x1, // PDRHeaderVersion
2573 PLDM_NUMERIC_SENSOR_PDR, // PDRType
2574 0x0,
2575 0x0, // recordChangeNumber
2576 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH +
2577 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_SENSOR_DATA_SIZE_MIN_LENGTH +
2578 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_RANGE_FIELD_MIN_LENGTH,
2579 0, // dataLength
2580 0,
2581 0, // PLDMTerminusHandle
2582 0x1,
2583 0x0, // sensorID=1
2584 PLDM_ENTITY_POWER_SUPPLY,
2585 0, // entityType=Power Supply(120)
2586 1,
2587 0, // entityInstanceNumber
2588 0x1,
2589 0x0, // containerID=1
2590 PLDM_NO_INIT, // sensorInit
2591 false, // sensorAuxiliaryNamesPDR
2592 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
2593 0, // unitModifier
2594 0, // rateUnit
2595 0, // baseOEMUnitHandle
2596 0, // auxUnit
2597 0, // auxUnitModifier
2598 0, // auxRateUnit
2599 0, // rel
2600 0, // auxOEMUnitHandle
2601 true, // isLinear
2602 PLDM_RANGE_FIELD_FORMAT_SINT8, // sensorDataSize
2603 0,
2604 0,
2605 0,
2606 0, // resolution
2607 0,
2608 0,
2609 0,
2610 0, // offset
2611 0,
2612 0, // accuracy
2613 0, // plusTolerance
2614 0, // minusTolerance
2615 3, // hysteresis = 3
2616 0, // supportedThresholds
2617 0, // thresholdAndHysteresisVolatility
2618 0,
2619 0,
2620 0x80,
2621 0x3f, // stateTransistionInterval=1.0
2622 0,
2623 0,
2624 0x80,
2625 0x3f, // updateInverval=1.0
2626 0x64, // maxReadable = 100
2627 0x9c, // minReadable = -100
2628 PLDM_RANGE_FIELD_FORMAT_SINT8, // rangeFieldFormat
2629 0, // rangeFieldsupport
2630 0, // nominalValue = 0
2631 5, // normalMax = 5
2632 0xfb, // normalMin = -5
2633 10, // warningHigh = 10
2634 0xf6, // warningLow = -10
2635 20, // criticalHigh = 20
2636 0xec, // criticalLow = -20
2637 30, // fatalHigh = 30
2638 0xe2 // fatalLow = -30
2639 };
2640
2641 struct pldm_numeric_sensor_value_pdr decodedPdr;
2642 auto rc =
2643 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
2644 EXPECT_EQ(PLDM_SUCCESS, rc);
2645
2646 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_SINT8, decodedPdr.sensor_data_size);
2647 EXPECT_EQ(100, decodedPdr.max_readable.value_s8);
2648 EXPECT_EQ(-100, decodedPdr.min_readable.value_s8);
2649 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_SINT8, decodedPdr.range_field_format);
2650 EXPECT_EQ(0, decodedPdr.nominal_value.value_s8);
2651 EXPECT_EQ(5, decodedPdr.normal_max.value_s8);
2652 EXPECT_EQ(-5, decodedPdr.normal_min.value_s8);
2653 EXPECT_EQ(10, decodedPdr.warning_high.value_s8);
2654 EXPECT_EQ(-10, decodedPdr.warning_low.value_s8);
2655 EXPECT_EQ(20, decodedPdr.critical_high.value_s8);
2656 EXPECT_EQ(-20, decodedPdr.critical_low.value_s8);
2657 EXPECT_EQ(30, decodedPdr.fatal_high.value_s8);
2658 EXPECT_EQ(-30, decodedPdr.fatal_low.value_s8);
2659}
2660
2661TEST(decodeNumericSensorPdrData, Uint16Test)
2662{
2663 std::vector<uint8_t> pdr1{
2664 0x1,
2665 0x0,
2666 0x0,
2667 0x0, // record handle
2668 0x1, // PDRHeaderVersion
2669 PLDM_NUMERIC_SENSOR_PDR, // PDRType
2670 0x0,
2671 0x0, // recordChangeNumber
2672 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH +
2673 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_SENSOR_DATA_SIZE_MIN_LENGTH * 2 +
2674 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_RANGE_FIELD_MIN_LENGTH * 2,
2675 0, // dataLength
2676 0,
2677 0, // PLDMTerminusHandle
2678 0x1,
2679 0x0, // sensorID=1
2680 PLDM_ENTITY_POWER_SUPPLY,
2681 0, // entityType=Power Supply(120)
2682 1,
2683 0, // entityInstanceNumber
2684 0x1,
2685 0x0, // containerID=1
2686 PLDM_NO_INIT, // sensorInit
2687 false, // sensorAuxiliaryNamesPDR
2688 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
2689 0, // unitModifier
2690 0, // rateUnit
2691 0, // baseOEMUnitHandle
2692 0, // auxUnit
2693 0, // auxUnitModifier
2694 0, // auxRateUnit
2695 0, // rel
2696 0, // auxOEMUnitHandle
2697 true, // isLinear
2698 PLDM_SENSOR_DATA_SIZE_UINT16, // sensorDataSize
2699 0,
2700 0,
2701 0,
2702 0, // resolution
2703 0,
2704 0,
2705 0,
2706 0, // offset
2707 0,
2708 0, // accuracy
2709 0, // plusTolerance
2710 0, // minusTolerance
2711 3,
2712 0, // hysteresis = 3
2713 0, // supportedThresholds
2714 0, // thresholdAndHysteresisVolatility
2715 0,
2716 0,
2717 0x80,
2718 0x3f, // stateTransistionInterval=1.0
2719 0,
2720 0,
2721 0x80,
2722 0x3f, // updateInverval=1.0
2723 0,
2724 0x10, // maxReadable = 4096
2725 0,
2726 0, // minReadable = 0
2727 PLDM_RANGE_FIELD_FORMAT_UINT16, // rangeFieldFormat
2728 0, // rangeFieldsupport
2729 0x88,
2730 0x13, // nominalValue = 5,000
2731 0x70,
2732 0x17, // normalMax = 6,000
2733 0xa0,
2734 0x0f, // normalMin = 4,000
2735 0x58,
2736 0x1b, // warningHigh = 7,000
2737 0xb8,
2738 0x0b, // warningLow = 3,000
2739 0x40,
2740 0x1f, // criticalHigh = 8,000
2741 0xd0,
2742 0x07, // criticalLow = 2,000
2743 0x28,
2744 0x23, // fatalHigh = 9,000
2745 0xe8,
2746 0x03 // fatalLow = 1,000
2747 };
2748
2749 struct pldm_numeric_sensor_value_pdr decodedPdr;
2750 auto rc =
2751 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
2752 EXPECT_EQ(PLDM_SUCCESS, rc);
2753
2754 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_UINT16, decodedPdr.sensor_data_size);
2755 EXPECT_EQ(4096, decodedPdr.max_readable.value_u16);
2756 EXPECT_EQ(0, decodedPdr.min_readable.value_u16);
2757 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_UINT16, decodedPdr.range_field_format);
2758 EXPECT_EQ(5000, decodedPdr.nominal_value.value_u16);
2759 EXPECT_EQ(6000, decodedPdr.normal_max.value_u16);
2760 EXPECT_EQ(4000, decodedPdr.normal_min.value_u16);
2761 EXPECT_EQ(7000, decodedPdr.warning_high.value_u16);
2762 EXPECT_EQ(3000, decodedPdr.warning_low.value_u16);
2763 EXPECT_EQ(8000, decodedPdr.critical_high.value_u16);
2764 EXPECT_EQ(2000, decodedPdr.critical_low.value_u16);
2765 EXPECT_EQ(9000, decodedPdr.fatal_high.value_u16);
2766 EXPECT_EQ(1000, decodedPdr.fatal_low.value_u16);
2767}
2768
2769TEST(decodeNumericSensorPdrData, Sint16Test)
2770{
2771 std::vector<uint8_t> pdr1{
2772 0x1,
2773 0x0,
2774 0x0,
2775 0x0, // record handle
2776 0x1, // PDRHeaderVersion
2777 PLDM_NUMERIC_SENSOR_PDR, // PDRType
2778 0x0,
2779 0x0, // recordChangeNumber
2780 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH +
2781 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_SENSOR_DATA_SIZE_MIN_LENGTH * 2 +
2782 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_RANGE_FIELD_MIN_LENGTH * 2,
2783 0, // dataLength
2784 0,
2785 0, // PLDMTerminusHandle
2786 0x1,
2787 0x0, // sensorID=1
2788 PLDM_ENTITY_POWER_SUPPLY,
2789 0, // entityType=Power Supply(120)
2790 1,
2791 0, // entityInstanceNumber
2792 0x1,
2793 0x0, // containerID=1
2794 PLDM_NO_INIT, // sensorInit
2795 false, // sensorAuxiliaryNamesPDR
2796 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
2797 0, // unitModifier
2798 0, // rateUnit
2799 0, // baseOEMUnitHandle
2800 0, // auxUnit
2801 0, // auxUnitModifier
2802 0, // auxRateUnit
2803 0, // rel
2804 0, // auxOEMUnitHandle
2805 true, // isLinear
2806 PLDM_SENSOR_DATA_SIZE_SINT16, // sensorDataSize
2807 0,
2808 0,
2809 0,
2810 0, // resolution
2811 0,
2812 0,
2813 0,
2814 0, // offset
2815 0,
2816 0, // accuracy
2817 0, // plusTolerance
2818 0, // minusTolerance
2819 3,
2820 0, // hysteresis
2821 0, // supportedThresholds
2822 0, // thresholdAndHysteresisVolatility
2823 0,
2824 0,
2825 0x80,
2826 0x3f, // stateTransistionInterval=1.0
2827 0,
2828 0,
2829 0x80,
2830 0x3f, // updateInverval=1.0
2831 0xe8,
2832 0x03, // maxReadable = 1000
2833 0x18,
2834 0xfc, // minReadable = -1000
2835 PLDM_RANGE_FIELD_FORMAT_SINT16, // rangeFieldFormat
2836 0, // rangeFieldsupport
2837 0,
2838 0, // nominalValue = 0
2839 0xf4,
2840 0x01, // normalMax = 500
2841 0x0c,
2842 0xfe, // normalMin = -500
2843 0xe8,
2844 0x03, // warningHigh = 1,000
2845 0x18,
2846 0xfc, // warningLow = -1,000
2847 0xd0,
2848 0x07, // criticalHigh = 2,000
2849 0x30,
2850 0xf8, // criticalLow = -2,000
2851 0xb8,
2852 0x0b, // fatalHigh = 3,000
2853 0x48,
2854 0xf4 // fatalLow = -3,000
2855 };
2856
2857 struct pldm_numeric_sensor_value_pdr decodedPdr;
2858 auto rc =
2859 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
2860 EXPECT_EQ(PLDM_SUCCESS, rc);
2861
2862 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_SINT16, decodedPdr.sensor_data_size);
2863 EXPECT_EQ(1000, decodedPdr.max_readable.value_s16);
2864 EXPECT_EQ(-1000, decodedPdr.min_readable.value_s16);
2865 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_SINT16, decodedPdr.range_field_format);
2866 EXPECT_EQ(0, decodedPdr.nominal_value.value_s16);
2867 EXPECT_EQ(500, decodedPdr.normal_max.value_s16);
2868 EXPECT_EQ(-500, decodedPdr.normal_min.value_s16);
2869 EXPECT_EQ(1000, decodedPdr.warning_high.value_s16);
2870 EXPECT_EQ(-1000, decodedPdr.warning_low.value_s16);
2871 EXPECT_EQ(2000, decodedPdr.critical_high.value_s16);
2872 EXPECT_EQ(-2000, decodedPdr.critical_low.value_s16);
2873 EXPECT_EQ(3000, decodedPdr.fatal_high.value_s16);
2874 EXPECT_EQ(-3000, decodedPdr.fatal_low.value_s16);
2875}
2876
2877TEST(decodeNumericSensorPdrData, Uint32Test)
2878{
2879 std::vector<uint8_t> pdr1{
2880 0x1,
2881 0x0,
2882 0x0,
2883 0x0, // record handle
2884 0x1, // PDRHeaderVersion
2885 PLDM_NUMERIC_SENSOR_PDR, // PDRType
2886 0x0,
2887 0x0, // recordChangeNumber
2888 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH +
2889 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_SENSOR_DATA_SIZE_MIN_LENGTH * 4 +
2890 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_RANGE_FIELD_MIN_LENGTH * 4,
2891 0, // dataLength
2892 0,
2893 0, // PLDMTerminusHandle
2894 0x1,
2895 0x0, // sensorID=1
2896 PLDM_ENTITY_POWER_SUPPLY,
2897 0, // entityType=Power Supply(120)
2898 1,
2899 0, // entityInstanceNumber
2900 0x1,
2901 0x0, // containerID=1
2902 PLDM_NO_INIT, // sensorInit
2903 false, // sensorAuxiliaryNamesPDR
2904 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
2905 0, // unitModifier
2906 0, // rateUnit
2907 0, // baseOEMUnitHandle
2908 0, // auxUnit
2909 0, // auxUnitModifier
2910 0, // auxRateUnit
2911 0, // rel
2912 0, // auxOEMUnitHandle
2913 true, // isLinear
2914 PLDM_SENSOR_DATA_SIZE_UINT32, // sensorDataSize
2915 0,
2916 0,
2917 0,
2918 0, // resolution
2919 0,
2920 0,
2921 0,
2922 0, // offset
2923 0,
2924 0, // accuracy
2925 0, // plusTolerance
2926 0, // minusTolerance
2927 3,
2928 0,
2929 0,
2930 0, // hysteresis
2931 0, // supportedThresholds
2932 0, // thresholdAndHysteresisVolatility
2933 0,
2934 0,
2935 0x80,
2936 0x3f, // stateTransistionInterval=1.0
2937 0,
2938 0,
2939 0x80,
2940 0x3f, // updateInverval=1.0
2941 0,
2942 0x10,
2943 0,
2944 0, // maxReadable = 4096
2945 0,
2946 0,
2947 0,
2948 0, // minReadable = 0
2949 PLDM_RANGE_FIELD_FORMAT_UINT32, // rangeFieldFormat
2950 0, // rangeFieldsupport
2951 0x40,
2952 0x4b,
2953 0x4c,
2954 0x00, // nominalValue = 5,000,000
2955 0x80,
2956 0x8d,
2957 0x5b,
2958 0x00, // normalMax = 6,000,000
2959 0x00,
2960 0x09,
2961 0x3d,
2962 0x00, // normalMin = 4,000,000
2963 0xc0,
2964 0xcf,
2965 0x6a,
2966 0x00, // warningHigh = 7,000,000
2967 0xc0,
2968 0xc6,
2969 0x2d,
2970 0x00, // warningLow = 3,000,000
2971 0x00,
2972 0x12,
2973 0x7a,
2974 0x00, // criticalHigh = 8,000,000
2975 0x80,
2976 0x84,
2977 0x1e,
2978 0x00, // criticalLow = 2,000,000
2979 0x40,
2980 0x54,
2981 0x89,
2982 0x00, // fatalHigh = 9,000,000
2983 0x40,
2984 0x42,
2985 0x0f,
2986 0x00 // fatalLow = 1,000,000
2987 };
2988
2989 struct pldm_numeric_sensor_value_pdr decodedPdr;
2990 auto rc =
2991 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
2992 EXPECT_EQ(PLDM_SUCCESS, rc);
2993
2994 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_UINT32, decodedPdr.sensor_data_size);
2995 EXPECT_EQ(4096, decodedPdr.max_readable.value_u32);
2996 EXPECT_EQ(0, decodedPdr.min_readable.value_u32);
2997 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_UINT32, decodedPdr.range_field_format);
2998 EXPECT_EQ(5000000, decodedPdr.nominal_value.value_u32);
2999 EXPECT_EQ(6000000, decodedPdr.normal_max.value_u32);
3000 EXPECT_EQ(4000000, decodedPdr.normal_min.value_u32);
3001 EXPECT_EQ(7000000, decodedPdr.warning_high.value_u32);
3002 EXPECT_EQ(3000000, decodedPdr.warning_low.value_u32);
3003 EXPECT_EQ(8000000, decodedPdr.critical_high.value_u32);
3004 EXPECT_EQ(2000000, decodedPdr.critical_low.value_u32);
3005 EXPECT_EQ(9000000, decodedPdr.fatal_high.value_u32);
3006 EXPECT_EQ(1000000, decodedPdr.fatal_low.value_u32);
3007}
3008
3009TEST(decodeNumericSensorPdrData, Sint32Test)
3010{
3011 std::vector<uint8_t> pdr1{
3012 0x1,
3013 0x0,
3014 0x0,
3015 0x0, // record handle
3016 0x1, // PDRHeaderVersion
3017 PLDM_NUMERIC_SENSOR_PDR, // PDRType
3018 0x0,
3019 0x0, // recordChangeNumber
3020 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH +
3021 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_SENSOR_DATA_SIZE_MIN_LENGTH * 4 +
3022 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_RANGE_FIELD_MIN_LENGTH * 4,
3023 0, // dataLength
3024 0,
3025 0, // PLDMTerminusHandle
3026 0x1,
3027 0x0, // sensorID=1
3028 PLDM_ENTITY_POWER_SUPPLY,
3029 0, // entityType=Power Supply(120)
3030 1,
3031 0, // entityInstanceNumber
3032 0x1,
3033 0x0, // containerID=1
3034 PLDM_NO_INIT, // sensorInit
3035 false, // sensorAuxiliaryNamesPDR
3036 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
3037 0, // unitModifier
3038 0, // rateUnit
3039 0, // baseOEMUnitHandle
3040 0, // auxUnit
3041 0, // auxUnitModifier
3042 0, // auxRateUnit
3043 0, // rel
3044 0, // auxOEMUnitHandle
3045 true, // isLinear
3046 PLDM_SENSOR_DATA_SIZE_SINT32, // sensorDataSize
3047 0,
3048 0,
3049 0,
3050 0, // resolution
3051 0,
3052 0,
3053 0,
3054 0, // offset
3055 0,
3056 0, // accuracy
3057 0, // plusTolerance
3058 0, // minusTolerance
3059 3,
3060 0,
3061 0,
3062 0, // hysteresis
3063 0, // supportedThresholds
3064 0, // thresholdAndHysteresisVolatility
3065 0,
3066 0,
3067 0x80,
3068 0x3f, // stateTransistionInterval=1.0
3069 0,
3070 0,
3071 0x80,
3072 0x3f, // updateInverval=1.0
3073 0xa0,
3074 0x86,
3075 0x01,
3076 0x00, // maxReadable = 100000
3077 0x60,
3078 0x79,
3079 0xfe,
3080 0xff, // minReadable = -10000
3081 PLDM_RANGE_FIELD_FORMAT_SINT32, // rangeFieldFormat
3082 0, // rangeFieldsupport
3083 0,
3084 0,
3085 0,
3086 0, // nominalValue = 0
3087 0x20,
3088 0xa1,
3089 0x07,
3090 0x00, // normalMax = 500,000
3091 0xe0,
3092 0x5e,
3093 0xf8,
3094 0xff, // normalMin = -500,000
3095 0x40,
3096 0x42,
3097 0x0f,
3098 0x00, // warningHigh = 1,000,000
3099 0xc0,
3100 0xbd,
3101 0xf0,
3102 0xff, // warningLow = -1,000,000
3103 0x80,
3104 0x84,
3105 0x1e,
3106 0x00, // criticalHigh = 2,000,000
3107 0x80,
3108 0x7b,
3109 0xe1,
3110 0xff, // criticalLow = -2,000,000
3111 0xc0,
3112 0xc6,
3113 0x2d,
3114 0x00, // fatalHigh = 3,000,000
3115 0x40,
3116 0x39,
3117 0xd2,
3118 0xff // fatalLow = -3,000,000
3119 };
3120
3121 struct pldm_numeric_sensor_value_pdr decodedPdr;
3122 auto rc =
3123 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
3124 EXPECT_EQ(PLDM_SUCCESS, rc);
3125
3126 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_SINT32, decodedPdr.sensor_data_size);
3127 EXPECT_EQ(100000, decodedPdr.max_readable.value_s32);
3128 EXPECT_EQ(-100000, decodedPdr.min_readable.value_s32);
3129 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_SINT32, decodedPdr.range_field_format);
3130 EXPECT_EQ(0, decodedPdr.nominal_value.value_s32);
3131 EXPECT_EQ(500000, decodedPdr.normal_max.value_s32);
3132 EXPECT_EQ(-500000, decodedPdr.normal_min.value_s32);
3133 EXPECT_EQ(1000000, decodedPdr.warning_high.value_s32);
3134 EXPECT_EQ(-1000000, decodedPdr.warning_low.value_s32);
3135 EXPECT_EQ(2000000, decodedPdr.critical_high.value_s32);
3136 EXPECT_EQ(-2000000, decodedPdr.critical_low.value_s32);
3137 EXPECT_EQ(3000000, decodedPdr.fatal_high.value_s32);
3138 EXPECT_EQ(-3000000, decodedPdr.fatal_low.value_s32);
3139}
3140
3141TEST(decodeNumericSensorPdrData, Real32Test)
3142{
3143 std::vector<uint8_t> pdr1{
3144 0x1,
3145 0x0,
3146 0x0,
3147 0x0, // record handle
3148 0x1, // PDRHeaderVersion
3149 PLDM_NUMERIC_SENSOR_PDR, // PDRType
3150 0x0,
3151 0x0, // recordChangeNumber
3152 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH +
3153 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_SENSOR_DATA_SIZE_MIN_LENGTH * 4 +
3154 PLDM_PDR_NUMERIC_SENSOR_PDR_VARIED_RANGE_FIELD_MIN_LENGTH * 4,
3155 0, // dataLength
3156 0,
3157 0, // PLDMTerminusHandle
3158 0x1,
3159 0x0, // sensorID=1
3160 PLDM_ENTITY_POWER_SUPPLY,
3161 0, // entityType=Power Supply(120)
3162 1,
3163 0, // entityInstanceNumber
3164 0x1,
3165 0x0, // containerID=1
3166 PLDM_NO_INIT, // sensorInit
3167 false, // sensorAuxiliaryNamesPDR
3168 PLDM_SENSOR_UNIT_DEGRESS_C, // baseUint(2)=degrees C
3169 0, // unitModifier
3170 0, // rateUnit
3171 0, // baseOEMUnitHandle
3172 0, // auxUnit
3173 0, // auxUnitModifier
3174 0, // auxRateUnit
3175 0, // rel
3176 0, // auxOEMUnitHandle
3177 true, // isLinear
3178 PLDM_SENSOR_DATA_SIZE_SINT32, // sensorDataSize
3179 0,
3180 0,
3181 0,
3182 0, // resolution
3183 0,
3184 0,
3185 0,
3186 0, // offset
3187 0,
3188 0, // accuracy
3189 0, // plusTolerance
3190 0, // minusTolerance
3191 3,
3192 0,
3193 0,
3194 0, // hysteresis
3195 0, // supportedThresholds
3196 0, // thresholdAndHysteresisVolatility
3197 0,
3198 0,
3199 0x80,
3200 0x3f, // stateTransistionInterval=1.0
3201 0,
3202 0,
3203 0x80,
3204 0x3f, // updateInverval=1.0
3205 0xa0,
3206 0x86,
3207 0x01,
3208 0x00, // maxReadable = 100000
3209 0x60,
3210 0x79,
3211 0xfe,
3212 0xff, // minReadable = -10000
3213 PLDM_RANGE_FIELD_FORMAT_REAL32, // rangeFieldFormat
3214 0, // rangeFieldsupport
3215 0,
3216 0,
3217 0,
3218 0, // nominalValue = 0.0
3219 0x33,
3220 0x33,
3221 0x48,
3222 0x42, // normalMax = 50.05
3223 0x33,
3224 0x33,
3225 0x48,
3226 0xc2, // normalMin = -50.05
3227 0x83,
3228 0x00,
3229 0xc8,
3230 0x42, // warningHigh = 100.001
3231 0x83,
3232 0x00,
3233 0xc8,
3234 0xc2, // warningLow = -100.001
3235 0x83,
3236 0x00,
3237 0x48,
3238 0x43, // criticalHigh = 200.002
3239 0x83,
3240 0x00,
3241 0x48,
3242 0xc3, // criticalLow = -200.002
3243 0x62,
3244 0x00,
3245 0x96,
3246 0x43, // fatalHigh = 300.003
3247 0x62,
3248 0x00,
3249 0x96,
3250 0xc3 // fatalLow = -300.003
3251 };
3252
3253 struct pldm_numeric_sensor_value_pdr decodedPdr;
3254 auto rc =
3255 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
3256 EXPECT_EQ(PLDM_SUCCESS, rc);
3257
3258 EXPECT_EQ(PLDM_SENSOR_DATA_SIZE_SINT32, decodedPdr.sensor_data_size);
3259 EXPECT_EQ(100000, decodedPdr.max_readable.value_s32);
3260 EXPECT_EQ(-100000, decodedPdr.min_readable.value_s32);
3261 EXPECT_EQ(PLDM_RANGE_FIELD_FORMAT_REAL32, decodedPdr.range_field_format);
3262 EXPECT_FLOAT_EQ(0, decodedPdr.nominal_value.value_f32);
3263 EXPECT_FLOAT_EQ(50.05f, decodedPdr.normal_max.value_f32);
3264 EXPECT_FLOAT_EQ(-50.05f, decodedPdr.normal_min.value_f32);
3265 EXPECT_FLOAT_EQ(100.001f, decodedPdr.warning_high.value_f32);
3266 EXPECT_FLOAT_EQ(-100.001f, decodedPdr.warning_low.value_f32);
3267 EXPECT_FLOAT_EQ(200.002f, decodedPdr.critical_high.value_f32);
3268 EXPECT_FLOAT_EQ(-200.002f, decodedPdr.critical_low.value_f32);
3269 EXPECT_FLOAT_EQ(300.003f, decodedPdr.fatal_high.value_f32);
3270 EXPECT_FLOAT_EQ(-300.003f, decodedPdr.fatal_low.value_f32);
3271}
3272
3273TEST(decodeNumericSensorPdrDataDeathTest, InvalidSizeTest)
3274{
3275 // A corrupted PDR. The data after plusTolerance missed.
3276 std::vector<uint8_t> pdr1{
3277 0x1,
3278 0x0,
3279 0x0,
3280 0x0, // record handle
3281 0x1, // PDRHeaderVersion
3282 PLDM_NUMERIC_SENSOR_PDR, // PDRType
3283 0x0,
3284 0x0, // recordChangeNumber
3285 PLDM_PDR_NUMERIC_SENSOR_PDR_FIXED_LENGTH,
3286 0, // dataLength
3287 0,
3288 0, // PLDMTerminusHandle
3289 0x1,
3290 0x0, // sensorID=1
3291 PLDM_ENTITY_POWER_SUPPLY,
3292 0, // entityType=Power Supply(120)
3293 1,
3294 0, // entityInstanceNumber
3295 0x1,
3296 0x0, // containerID=1
3297 PLDM_NO_INIT, // sensorInit
3298 false, // sensorAuxiliaryNamesPDR
3299 2, // baseUint(2)=degrees C
3300 0, // unitModifier
3301 0, // rateUnit
3302 0, // baseOEMUnitHandle
3303 0, // auxUnit
3304 0, // auxUnitModifier
3305 0, // auxRateUnit
3306 0, // rel
3307 0, // auxOEMUnitHandle
3308 true, // isLinear
3309 PLDM_SENSOR_DATA_SIZE_UINT8, // sensorDataSize
3310 0,
3311 0,
3312 0,
3313 0, // resolution
3314 0,
3315 0,
3316 0,
3317 0, // offset
3318 0,
3319 0, // accuracy
3320 0 // plusTolerance
3321 };
3322
3323 struct pldm_numeric_sensor_value_pdr decodedPdr;
3324 int rc =
3325 decode_numeric_sensor_pdr_data(pdr1.data(), pdr1.size(), &decodedPdr);
3326 EXPECT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
3327}