blob: 4968d396852e0b5ea6d8e4a7331f8daf895f5d4a [file] [log] [blame]
Tom Joseph7dae7772019-04-10 14:44:44 +05301#include <string.h>
2
3#include <array>
4
5#include "libpldm/base.h"
6#include "libpldm/file_io.h"
7
8#include <gtest/gtest.h>
9
10TEST(ReadFileIntoMemory, testGoodDecodeRequest)
11{
12 std::array<uint8_t, PLDM_READ_FILE_MEM_REQ_BYTES> requestMsg{};
13
14 // Random value for fileHandle, offset, length, address
15 uint32_t fileHandle = 0x12345678;
16 uint32_t offset = 0x87654321;
17 uint32_t length = 0x13245768;
18 uint64_t address = 0x124356879ACBDE0F;
19
20 memcpy(requestMsg.data(), &fileHandle, sizeof(fileHandle));
21 memcpy(requestMsg.data() + sizeof(fileHandle), &offset, sizeof(offset));
22 memcpy(requestMsg.data() + sizeof(fileHandle) + sizeof(offset), &length,
23 sizeof(length));
24 memcpy(requestMsg.data() + sizeof(fileHandle) + sizeof(offset) +
25 sizeof(length),
26 &address, sizeof(address));
27
28 uint32_t retFileHandle = 0;
29 uint32_t retOffset = 0;
30 uint32_t retLength = 0;
31 uint64_t retAddress = 0;
32
33 // Invoke decode the read file memory request
34 auto rc = decode_read_file_memory_req(requestMsg.data(), requestMsg.size(),
35 &retFileHandle, &retOffset,
36 &retLength, &retAddress);
37
38 ASSERT_EQ(rc, PLDM_SUCCESS);
39 ASSERT_EQ(fileHandle, retFileHandle);
40 ASSERT_EQ(offset, retOffset);
41 ASSERT_EQ(length, retLength);
42 ASSERT_EQ(address, retAddress);
43}
44
45TEST(ReadFileIntoMemory, testBadDecodeRequest)
46{
47 uint32_t fileHandle = 0;
48 uint32_t offset = 0;
49 uint32_t length = 0;
50 uint64_t address = 0;
51
52 // Request payload message is missing
53 auto rc = decode_read_file_memory_req(NULL, 0, &fileHandle, &offset,
54 &length, &address);
55 ASSERT_EQ(rc, PLDM_ERROR_INVALID_DATA);
56
57 std::array<uint8_t, PLDM_READ_FILE_MEM_REQ_BYTES> requestMsg{};
58
59 // Address is NULL
60 rc = decode_read_file_memory_req(requestMsg.data(), requestMsg.size(),
61 &fileHandle, &offset, &length, NULL);
62 ASSERT_EQ(rc, PLDM_ERROR_INVALID_DATA);
63
64 // Payload length is invalid
65 rc = decode_read_file_memory_req(requestMsg.data(), 0, &fileHandle, &offset,
66 &length, &address);
67 ASSERT_EQ(rc, PLDM_ERROR_INVALID_LENGTH);
68}
69
70TEST(ReadFileIntoMemory, testGoodEncodeResponse)
71{
72 std::array<uint8_t, sizeof(pldm_msg_hdr) + PLDM_READ_FILE_MEM_RESP_BYTES>
73 responseMsg{};
74 uint32_t length = 0xFF00EE11;
75 pldm_msg* response = reinterpret_cast<pldm_msg*>(responseMsg.data());
76
77 auto rc = encode_read_file_memory_resp(0, PLDM_SUCCESS, length, response);
78
79 ASSERT_EQ(rc, PLDM_SUCCESS);
80 ASSERT_EQ(response->hdr.request, PLDM_RESPONSE);
81 ASSERT_EQ(response->hdr.instance_id, 0);
82 ASSERT_EQ(response->hdr.type, PLDM_IBM_OEM_TYPE);
83 ASSERT_EQ(response->hdr.command, PLDM_READ_FILE_INTO_MEMORY);
84 ASSERT_EQ(response->payload[0], PLDM_SUCCESS);
85 ASSERT_EQ(0, memcmp(response->payload + sizeof(response->payload[0]),
86 &length, sizeof(length)));
87}
88
89TEST(ReadFileIntoMemory, testBadEncodeResponse)
90{
91 std::array<uint8_t, sizeof(pldm_msg_hdr) + PLDM_READ_FILE_MEM_RESP_BYTES>
92 responseMsg{};
93 uint32_t length = 0;
94 pldm_msg* response = reinterpret_cast<pldm_msg*>(responseMsg.data());
95
96 auto rc = encode_read_file_memory_resp(0, PLDM_ERROR, length, response);
97
98 ASSERT_EQ(rc, PLDM_SUCCESS);
99 ASSERT_EQ(response->hdr.request, PLDM_RESPONSE);
100 ASSERT_EQ(response->hdr.instance_id, 0);
101 ASSERT_EQ(response->hdr.type, PLDM_IBM_OEM_TYPE);
102 ASSERT_EQ(response->hdr.command, PLDM_READ_FILE_INTO_MEMORY);
103 ASSERT_EQ(response->payload[0], PLDM_ERROR);
104}