blob: f769c93a225d449510cd4ad45ad0c00e45da8f58 [file] [log] [blame]
Deepak Kodihalli707a3e12017-06-14 03:56:12 -05001#include "elog_entry.hpp"
2#include "elog_serialize.hpp"
Patrick Venturef18bf832018-10-26 18:14:00 -07003#include "serialization_tests.hpp"
Deepak Kodihalli707a3e12017-06-14 03:56:12 -05004
5namespace phosphor
6{
7namespace logging
8{
9namespace test
10{
11
12TEST_F(TestSerialization, testProperties)
13{
14 auto id = 99;
15 phosphor::logging::AssociationList assocations{};
Patrick Williamsea21d992024-11-22 17:06:35 -050016 std::map<std::string, std::string> testData = {{"additional", "1"},
17 {"data", "yes"}};
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050018 uint64_t timestamp{100};
19 std::string message{"test error"};
Matt Spinler375ac9b2018-05-01 15:20:55 -050020 std::string fwLevel{"level42"};
Matt Spinlerfb978da2022-01-21 08:42:24 -060021 std::string inputPath = getEntrySerializePath(id, TestSerialization::dir);
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050022 auto input = std::make_unique<Entry>(
Patrick Venturef18bf832018-10-26 18:14:00 -070023 bus, std::string(OBJ_ENTRY) + '/' + std::to_string(id), id, timestamp,
24 Entry::Level::Informational, std::move(message), std::move(testData),
Matt Spinlerfb978da2022-01-21 08:42:24 -060025 std::move(assocations), fwLevel, inputPath, manager);
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050026 auto path = serialize(*input, TestSerialization::dir);
Matt Spinlerfb978da2022-01-21 08:42:24 -060027 EXPECT_EQ(path, inputPath);
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050028
Patrick Williams7ba65442021-04-22 09:17:18 -050029 auto idStr = path.filename();
30 id = std::stol(idStr.c_str());
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050031 auto output = std::make_unique<Entry>(
Patrick Williams7ba65442021-04-22 09:17:18 -050032 bus, std::filesystem::path(OBJ_ENTRY) / idStr, id, manager);
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050033 deserialize(path, *output);
34
35 EXPECT_EQ(input->id(), output->id());
36 EXPECT_EQ(input->severity(), output->severity());
37 EXPECT_EQ(input->timestamp(), output->timestamp());
38 EXPECT_EQ(input->message(), output->message());
39 EXPECT_EQ(input->additionalData(), output->additionalData());
Patrick Williamse7e741e2024-11-21 16:21:56 -050040 EXPECT_EQ(input->additionalData2(), output->additionalData2());
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050041 EXPECT_EQ(input->resolved(), output->resolved());
42 EXPECT_EQ(input->associations(), output->associations());
Matt Spinler375ac9b2018-05-01 15:20:55 -050043 EXPECT_EQ(input->version(), output->version());
44 EXPECT_EQ(input->purpose(), output->purpose());
Matt Spinler1e71a4d2020-03-04 13:40:22 -060045 EXPECT_EQ(input->updateTimestamp(), output->updateTimestamp());
Deepak Kodihalli707a3e12017-06-14 03:56:12 -050046}
47
48} // namespace test
49} // namespace logging
50} // namespace phosphor