blob: 97dad1b9949abff0e36b1c5780c954c89f43636d [file] [log] [blame]
Lawrence Tangd34f2b12022-07-19 15:36:31 +01001/**
2 * Defines tests for validating CPER-JSON IR output from the cper-parse library.
Ed Tanousfedd4572024-07-12 13:56:00 -07003 *
Lawrence Tangd34f2b12022-07-19 15:36:31 +01004 * Author: Lawrence.Tang@arm.com
5 **/
6
John Chungf8fc7052024-05-03 20:05:29 +08007#include <cctype>
Lawrence Tangd34f2b12022-07-19 15:36:31 +01008#include "gtest/gtest.h"
9#include "test-utils.hpp"
Lawrence Tang5202bbb2022-08-12 14:54:36 +010010#include <json.h>
Ed Tanousa2dce4b2025-03-05 15:33:06 -080011#include <charconv>
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -080012#include <nlohmann/json.hpp>
13#include <filesystem>
14#include <fstream>
Thu Nguyene42fb482024-10-15 14:43:11 +000015#include <libcper/cper-parse.h>
16#include <libcper/json-schema.h>
17#include <libcper/generator/cper-generate.h>
18#include <libcper/sections/cper-section.h>
19#include <libcper/generator/sections/gen-section.h>
Ed Tanousa2dce4b2025-03-05 15:33:06 -080020#include <format>
Lawrence Tangd34f2b12022-07-19 15:36:31 +010021
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -080022namespace fs = std::filesystem;
23
Lawrence Tangd34f2b12022-07-19 15:36:31 +010024/*
25* Test templates.
26*/
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -080027static const GEN_VALID_BITS_TEST_TYPE allValidbitsSet = ALL_VALID;
28static const GEN_VALID_BITS_TEST_TYPE fixedValidbitsSet = SOME_VALID;
29static const int GEN_EXAMPLES = 0;
30
31void cper_create_examples(const char *section_name)
32{
33 //Generate full CPER record for the given type.
34 fs::path file_path = LIBCPER_EXAMPLES;
35 file_path /= section_name;
Ed Tanousa2dce4b2025-03-05 15:33:06 -080036 fs::path cper_out = file_path.replace_extension("cperhex");
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -080037 fs::path json_out = file_path.replace_extension("json");
38
39 char *buf;
40 size_t size;
41 FILE *record = generate_record_memstream(&section_name, 1, &buf, &size,
42 0, fixedValidbitsSet);
43
44 // Write example CPER to disk
45 std::ofstream outFile(cper_out, std::ios::binary);
46 if (!outFile.is_open()) {
47 std::cerr << "Failed to create/open CPER output file: "
48 << cper_out << std::endl;
49 return;
50 }
51
Ed Tanousa2dce4b2025-03-05 15:33:06 -080052 std::vector<unsigned char> file_data;
53 fseek(record, 0, SEEK_END);
54 size_t file_size = ftell(record);
55 rewind(record);
56 file_data.resize(file_size);
57 if (fread(file_data.data(), 1, file_data.size(), record) != file_size) {
58 std::cerr << "Failed to read CPER data from memstream."
59 << std::endl;
60 FAIL();
61 return;
62 }
63 for (size_t index = 0; index < file_data.size(); index++) {
64 outFile << std::format("{:02x}", file_data[index]);
65 if (index % 30 == 29) {
66 outFile << "\n";
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -080067 }
68 }
69 outFile.close();
70
71 //Convert to IR, free resources.
72 rewind(record);
73 json_object *ir = cper_to_ir(record);
74 if (ir == NULL) {
75 std::cerr << "Empty JSON from CPER bin" << std::endl;
76 FAIL();
77 return;
78 }
79 char *str = strdup(json_object_to_json_string(ir));
80 nlohmann::json jsonData = nlohmann::json::parse(str, nullptr, false);
81 if (jsonData.is_discarded()) {
82 std::cerr << "cper_create_examples: JSON parse error:"
83 << std::endl;
84 }
85 free(str);
86 fclose(record);
87 free(buf);
88
89 //Write json output to disk
90 std::ofstream jsonOutFile(json_out);
91 jsonOutFile << std::setw(4) << jsonData << std::endl;
92 jsonOutFile.close();
93}
94
Ed Tanousa2dce4b2025-03-05 15:33:06 -080095std::vector<unsigned char> string_to_binary(const std::string &source)
96{
97 std::vector<unsigned char> retval;
98 bool uppernibble = true;
99 for (const char c : source) {
100 unsigned char val = 0;
101 if (c == '\n') {
102 continue;
103 }
104 std::from_chars_result r = std::from_chars(&c, &c + 1, val, 16);
105 EXPECT_TRUE(r.ec == std::error_code())
106 << "Invalid hex character in test file: " << c;
107
108 if (uppernibble) {
109 retval.push_back(val << 4);
110 } else {
111 retval.back() += val;
112 }
113 uppernibble = !uppernibble;
114 }
115 return retval;
116}
117
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800118//Tests fixed CPER sections for IR validity with an example set.
119void cper_example_section_ir_test(const char *section_name)
120{
121 //Open CPER record for the given type.
122 fs::path fpath = LIBCPER_EXAMPLES;
123 fpath /= section_name;
Ed Tanousa2dce4b2025-03-05 15:33:06 -0800124 fs::path cper = fpath.replace_extension("cperhex");
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800125 fs::path json = fpath.replace_extension("json");
126
Ed Tanousa2dce4b2025-03-05 15:33:06 -0800127 std::ifstream cper_file(cper, std::ios::binary);
128 if (!cper_file.is_open()) {
129 std::cerr << "Failed to open CPER file: " << cper << std::endl;
130 FAIL() << "Failed to open CPER file";
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800131 return;
132 }
Ed Tanousa2dce4b2025-03-05 15:33:06 -0800133 std::string cper_str((std::istreambuf_iterator<char>(cper_file)),
134 std::istreambuf_iterator<char>());
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800135
Ed Tanousa2dce4b2025-03-05 15:33:06 -0800136 std::vector<unsigned char> cper_bin = string_to_binary(cper_str);
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800137 //Convert to IR, free resources.
Ed Tanousa2dce4b2025-03-05 15:33:06 -0800138 json_object *ir = cper_buf_to_ir(cper_bin.data(), cper_bin.size());
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800139 if (ir == NULL) {
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800140 std::cerr << "Empty JSON from CPER bin" << std::endl;
141 FAIL();
142 return;
143 }
144 const char *str = json_object_to_json_string(ir);
145 nlohmann::json jsonData = nlohmann::json::parse(str, nullptr, false);
146 if (jsonData.is_discarded()) {
147 std::cerr << "cper_example_section_ir_test: JSON parse error:"
148 << std::endl;
149 FAIL() << "cper_example_section_ir_test: JSON parse error:";
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800150 json_object_put(ir);
151
152 return;
153 }
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800154
155 //Open json example file
156 nlohmann::json jGolden = loadJson(json.string().c_str());
157 if (jGolden.is_discarded()) {
158 std::cerr << "Could not open JSON example file: " << json
159 << std::endl;
160 FAIL() << "Could not open JSON example file";
161 }
162
163 json_object_put(ir);
164
165 EXPECT_EQ(jGolden, jsonData);
166}
Lawrence Tangcd505202022-07-19 16:55:11 +0100167
168//Tests a single randomly generated CPER section of the given type to ensure CPER-JSON IR validity.
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800169void cper_log_section_ir_test(const char *section_name, int single_section,
170 GEN_VALID_BITS_TEST_TYPE validBitsType)
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100171{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100172 //Generate full CPER record for the given type.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100173 char *buf;
174 size_t size;
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100175 FILE *record = generate_record_memstream(&section_name, 1, &buf, &size,
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800176 single_section, validBitsType);
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100177
Lawrence Tange407b4c2022-07-21 13:54:01 +0100178 //Convert to IR, free resources.
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100179 json_object *ir;
John Chungf8fc7052024-05-03 20:05:29 +0800180 if (single_section) {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100181 ir = cper_single_section_to_ir(record);
John Chungf8fc7052024-05-03 20:05:29 +0800182 } else {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100183 ir = cper_to_ir(record);
John Chungf8fc7052024-05-03 20:05:29 +0800184 }
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800185
186 char *str = strdup(json_object_to_json_string(ir));
187 nlohmann::json jsonData = nlohmann::json::parse(str, nullptr, false);
188 if (jsonData.is_discarded()) {
189 std::cerr << "Could not parse json output" << std::endl;
190 }
191 free(str);
Lawrence Tange407b4c2022-07-21 13:54:01 +0100192 fclose(record);
193 free(buf);
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100194
Lawrence Tange407b4c2022-07-21 13:54:01 +0100195 //Validate against schema.
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800196 std::string error_message;
197
198 int valid = schema_validate_from_file(LIBCPER_JSON_SPEC, jsonData,
199 error_message);
John Chungf8fc7052024-05-03 20:05:29 +0800200 json_object_put(ir);
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100201 ASSERT_TRUE(valid)
202 << "IR validation test failed (single section mode = "
203 << single_section << ") with message: " << error_message;
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100204}
205
Ed Tanous50b966f2025-03-11 09:06:19 -0700206std::string to_hex(char *input, size_t size)
207{
208 std::string out;
209 for (char c : std::span<unsigned char>((unsigned char *)input, size)) {
210 out += std::format("{:02x}", static_cast<unsigned char>(c));
211 }
212 return out;
213}
214
Lawrence Tangcd505202022-07-19 16:55:11 +0100215//Checks for binary round-trip equality for a given randomly generated CPER record.
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800216void cper_log_section_binary_test(const char *section_name, int single_section,
217 GEN_VALID_BITS_TEST_TYPE validBitsType)
Lawrence Tangcd505202022-07-19 16:55:11 +0100218{
Lawrence Tange407b4c2022-07-21 13:54:01 +0100219 //Generate CPER record for the given type.
220 char *buf;
221 size_t size;
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100222 FILE *record = generate_record_memstream(&section_name, 1, &buf, &size,
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800223 single_section, validBitsType);
224 if (record == NULL) {
225 std::cerr << "Could not generate memstream for binary test"
226 << std::endl;
227 return;
228 }
Lawrence Tangcd505202022-07-19 16:55:11 +0100229
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100230 //Convert to IR.
231 json_object *ir;
John Chungf8fc7052024-05-03 20:05:29 +0800232 if (single_section) {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100233 ir = cper_single_section_to_ir(record);
John Chungf8fc7052024-05-03 20:05:29 +0800234 } else {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100235 ir = cper_to_ir(record);
John Chungf8fc7052024-05-03 20:05:29 +0800236 }
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100237
238 //Now convert back to binary, and get a stream out.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100239 char *cper_buf;
240 size_t cper_buf_size;
241 FILE *stream = open_memstream(&cper_buf, &cper_buf_size);
John Chungf8fc7052024-05-03 20:05:29 +0800242 if (single_section) {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100243 ir_single_section_to_cper(ir, stream);
John Chungf8fc7052024-05-03 20:05:29 +0800244 } else {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100245 ir_to_cper(ir, stream);
John Chungf8fc7052024-05-03 20:05:29 +0800246 }
Lawrence Tange407b4c2022-07-21 13:54:01 +0100247 fclose(stream);
Lawrence Tangcd505202022-07-19 16:55:11 +0100248
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800249 std::cout << "size: " << size << ", cper_buf_size: " << cper_buf_size
250 << std::endl;
Ed Tanous50b966f2025-03-11 09:06:19 -0700251 EXPECT_EQ(to_hex(buf, size),
252 to_hex(cper_buf, std::min(size, cper_buf_size)))
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100253 << "Binary output was not identical to input (single section mode = "
254 << single_section << ").";
Lawrence Tange407b4c2022-07-21 13:54:01 +0100255
256 //Free everything up.
257 fclose(record);
258 free(buf);
259 free(cper_buf);
John Chungf8fc7052024-05-03 20:05:29 +0800260 json_object_put(ir);
Lawrence Tangcd505202022-07-19 16:55:11 +0100261}
262
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100263//Tests randomly generated CPER sections for IR validity of a given type, in both single section mode and full CPER log mode.
264void cper_log_section_dual_ir_test(const char *section_name)
265{
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800266 cper_log_section_ir_test(section_name, 0, allValidbitsSet);
267 cper_log_section_ir_test(section_name, 1, allValidbitsSet);
268 //Validate against examples
269 cper_example_section_ir_test(section_name);
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100270}
271
272//Tests randomly generated CPER sections for binary compatibility of a given type, in both single section mode and full CPER log mode.
273void cper_log_section_dual_binary_test(const char *section_name)
274{
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800275 cper_log_section_binary_test(section_name, 0, allValidbitsSet);
276 cper_log_section_binary_test(section_name, 1, allValidbitsSet);
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100277}
278
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100279/*
Lawrence Tang580423f2022-08-24 09:37:53 +0100280* Non-single section assertions.
281*/
282TEST(CompileTimeAssertions, TwoWayConversion)
283{
John Chungf8fc7052024-05-03 20:05:29 +0800284 for (size_t i = 0; i < section_definitions_len; i++) {
Lawrence Tang580423f2022-08-24 09:37:53 +0100285 //If a conversion one way exists, a conversion the other way must exist.
Lawrence Tang40519cb2022-08-24 15:50:08 +0100286 std::string err =
287 "If a CPER conversion exists one way, there must be an equivalent method in reverse.";
John Chungf8fc7052024-05-03 20:05:29 +0800288 if (section_definitions[i].ToCPER != NULL) {
289 ASSERT_NE(section_definitions[i].ToIR, nullptr) << err;
290 }
291 if (section_definitions[i].ToIR != NULL) {
292 ASSERT_NE(section_definitions[i].ToCPER, nullptr)
293 << err;
294 }
Lawrence Tang580423f2022-08-24 09:37:53 +0100295 }
296}
297
Lawrence Tang40519cb2022-08-24 15:50:08 +0100298TEST(CompileTimeAssertions, ShortcodeNoSpaces)
299{
John Chungf8fc7052024-05-03 20:05:29 +0800300 for (size_t i = 0; i < generator_definitions_len; i++) {
Lawrence Tang40519cb2022-08-24 15:50:08 +0100301 for (int j = 0;
302 generator_definitions[i].ShortName[j + 1] != '\0'; j++) {
303 ASSERT_FALSE(
304 isspace(generator_definitions[i].ShortName[j]))
305 << "Illegal space character detected in shortcode '"
306 << generator_definitions[i].ShortName << "'.";
307 }
308 }
309}
310
Lawrence Tang580423f2022-08-24 09:37:53 +0100311/*
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100312* Single section tests.
313*/
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100314
Lawrence Tangcd505202022-07-19 16:55:11 +0100315//Generic processor tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100316TEST(GenericProcessorTests, IRValid)
317{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100318 cper_log_section_dual_ir_test("generic");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100319}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100320TEST(GenericProcessorTests, BinaryEqual)
321{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100322 cper_log_section_dual_binary_test("generic");
Lawrence Tangcd505202022-07-19 16:55:11 +0100323}
324
325//IA32/x64 tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100326TEST(IA32x64Tests, IRValid)
327{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100328 cper_log_section_dual_ir_test("ia32x64");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100329}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100330TEST(IA32x64Tests, BinaryEqual)
331{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100332 cper_log_section_dual_binary_test("ia32x64");
Lawrence Tangcd505202022-07-19 16:55:11 +0100333}
334
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100335// TEST(IPFTests, IRValid) {
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100336// cper_log_section_dual_ir_test("ipf");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100337// }
Lawrence Tangcd505202022-07-19 16:55:11 +0100338
339//ARM tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100340TEST(ArmTests, IRValid)
341{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100342 cper_log_section_dual_ir_test("arm");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100343}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100344TEST(ArmTests, BinaryEqual)
345{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100346 cper_log_section_dual_binary_test("arm");
Lawrence Tangcd505202022-07-19 16:55:11 +0100347}
348
349//Memory tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100350TEST(MemoryTests, IRValid)
351{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100352 cper_log_section_dual_ir_test("memory");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100353}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100354TEST(MemoryTests, BinaryEqual)
355{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100356 cper_log_section_dual_binary_test("memory");
Lawrence Tangcd505202022-07-19 16:55:11 +0100357}
358
359//Memory 2 tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100360TEST(Memory2Tests, IRValid)
361{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100362 cper_log_section_dual_ir_test("memory2");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100363}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100364TEST(Memory2Tests, BinaryEqual)
365{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100366 cper_log_section_dual_binary_test("memory2");
Lawrence Tangcd505202022-07-19 16:55:11 +0100367}
368
369//PCIe tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100370TEST(PCIeTests, IRValid)
371{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100372 cper_log_section_dual_ir_test("pcie");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100373}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100374TEST(PCIeTests, BinaryEqual)
375{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100376 cper_log_section_dual_binary_test("pcie");
Lawrence Tangcd505202022-07-19 16:55:11 +0100377}
378
379//Firmware tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100380TEST(FirmwareTests, IRValid)
381{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100382 cper_log_section_dual_ir_test("firmware");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100383}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100384TEST(FirmwareTests, BinaryEqual)
385{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100386 cper_log_section_dual_binary_test("firmware");
Lawrence Tangcd505202022-07-19 16:55:11 +0100387}
388
389//PCI Bus tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100390TEST(PCIBusTests, IRValid)
391{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100392 cper_log_section_dual_ir_test("pcibus");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100393}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100394TEST(PCIBusTests, BinaryEqual)
395{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100396 cper_log_section_dual_binary_test("pcibus");
Lawrence Tangcd505202022-07-19 16:55:11 +0100397}
398
399//PCI Device tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100400TEST(PCIDevTests, IRValid)
401{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100402 cper_log_section_dual_ir_test("pcidev");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100403}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100404TEST(PCIDevTests, BinaryEqual)
405{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100406 cper_log_section_dual_binary_test("pcidev");
Lawrence Tangcd505202022-07-19 16:55:11 +0100407}
408
409//Generic DMAr tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100410TEST(DMArGenericTests, IRValid)
411{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100412 cper_log_section_dual_ir_test("dmargeneric");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100413}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100414TEST(DMArGenericTests, BinaryEqual)
415{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100416 cper_log_section_dual_binary_test("dmargeneric");
Lawrence Tangcd505202022-07-19 16:55:11 +0100417}
418
419//VT-d DMAr tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100420TEST(DMArVtdTests, IRValid)
421{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100422 cper_log_section_dual_ir_test("dmarvtd");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100423}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100424TEST(DMArVtdTests, BinaryEqual)
425{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100426 cper_log_section_dual_binary_test("dmarvtd");
Lawrence Tangcd505202022-07-19 16:55:11 +0100427}
428
429//IOMMU DMAr tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100430TEST(DMArIOMMUTests, IRValid)
431{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100432 cper_log_section_dual_ir_test("dmariommu");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100433}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100434TEST(DMArIOMMUTests, BinaryEqual)
435{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100436 cper_log_section_dual_binary_test("dmariommu");
Lawrence Tangcd505202022-07-19 16:55:11 +0100437}
438
439//CCIX PER tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100440TEST(CCIXPERTests, IRValid)
441{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100442 cper_log_section_dual_ir_test("ccixper");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100443}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100444TEST(CCIXPERTests, BinaryEqual)
445{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100446 cper_log_section_dual_binary_test("ccixper");
Lawrence Tangcd505202022-07-19 16:55:11 +0100447}
448
449//CXL Protocol tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100450TEST(CXLProtocolTests, IRValid)
451{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100452 cper_log_section_dual_ir_test("cxlprotocol");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100453}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100454TEST(CXLProtocolTests, BinaryEqual)
455{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100456 cper_log_section_dual_binary_test("cxlprotocol");
Lawrence Tangcd505202022-07-19 16:55:11 +0100457}
458
459//CXL Component tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100460TEST(CXLComponentTests, IRValid)
461{
Lawrence Tang8f977452022-08-24 14:55:07 +0100462 cper_log_section_dual_ir_test("cxlcomponent-media");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100463}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100464TEST(CXLComponentTests, BinaryEqual)
465{
Lawrence Tang8f977452022-08-24 14:55:07 +0100466 cper_log_section_dual_binary_test("cxlcomponent-media");
Lawrence Tangcd505202022-07-19 16:55:11 +0100467}
468
Ed Tanous2d17ace2024-08-27 14:45:38 -0700469//NVIDIA section tests.
470TEST(NVIDIASectionTests, IRValid)
471{
472 cper_log_section_dual_ir_test("nvidia");
473}
474TEST(NVIDIASectionTests, BinaryEqual)
475{
476 cper_log_section_dual_binary_test("nvidia");
477}
478
Lawrence Tangcd505202022-07-19 16:55:11 +0100479//Unknown section tests.
Lawrence Tange407b4c2022-07-21 13:54:01 +0100480TEST(UnknownSectionTests, IRValid)
481{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100482 cper_log_section_dual_ir_test("unknown");
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100483}
Lawrence Tange407b4c2022-07-21 13:54:01 +0100484TEST(UnknownSectionTests, BinaryEqual)
485{
Lawrence Tanga4f662f2022-08-08 14:37:36 +0100486 cper_log_section_dual_binary_test("unknown");
Lawrence Tangcd505202022-07-19 16:55:11 +0100487}
Lawrence Tangd34f2b12022-07-19 15:36:31 +0100488
489//Entrypoint for the testing program.
490int main()
491{
Aushim Nagarkattiae8f6d92025-01-29 17:34:44 -0800492 if (GEN_EXAMPLES) {
493 cper_create_examples("arm");
494 cper_create_examples("ia32x64");
495 cper_create_examples("memory");
496 cper_create_examples("memory2");
497 cper_create_examples("pcie");
498 cper_create_examples("firmware");
499 cper_create_examples("pcibus");
500 cper_create_examples("pcidev");
501 cper_create_examples("dmargeneric");
502 cper_create_examples("dmarvtd");
503 cper_create_examples("dmariommu");
504 cper_create_examples("ccixper");
505 cper_create_examples("cxlprotocol");
506 cper_create_examples("cxlcomponent-media");
507 cper_create_examples("nvidia");
508 cper_create_examples("unknown");
509 }
Lawrence Tange407b4c2022-07-21 13:54:01 +0100510 testing::InitGoogleTest();
511 return RUN_ALL_TESTS();
John Chungf8fc7052024-05-03 20:05:29 +0800512}