blob: ab8b7d6310512297a45fe5d3f861434c56e4cd15 [file] [log] [blame]
Matt Spinlerfdb6a202019-09-20 14:09:20 -05001#include "elog_entry.hpp"
2#include "extensions/openpower-pels/pel_types.hpp"
Matt Spinler03c1d912019-07-10 14:12:15 -05003#include "extensions/openpower-pels/private_header.hpp"
4#include "extensions/openpower-pels/user_header.hpp"
5#include "pel_utils.hpp"
6
7#include <gtest/gtest.h>
8
9using namespace openpower::pels;
10
11TEST(UserHeaderTest, SizeTest)
12{
13 EXPECT_EQ(UserHeader::flattenedSize(), 24);
14}
15
16TEST(UserHeaderTest, UnflattenFlattenTest)
17{
Matt Spinler42828bd2019-10-11 10:39:30 -050018 auto data = pelDataFactory(TestPELType::userHeaderSection);
Matt Spinler03c1d912019-07-10 14:12:15 -050019
Matt Spinler42828bd2019-10-11 10:39:30 -050020 Stream stream(data);
Matt Spinler03c1d912019-07-10 14:12:15 -050021 UserHeader uh(stream);
22 EXPECT_EQ(uh.valid(), true);
23
24 EXPECT_EQ(uh.header().id, 0x5548);
25 EXPECT_EQ(uh.header().size, UserHeader::flattenedSize());
26 EXPECT_EQ(uh.header().version, 0x01);
27 EXPECT_EQ(uh.header().subType, 0x0A);
28 EXPECT_EQ(uh.header().componentID, 0x0B0C);
29
30 EXPECT_EQ(uh.subsystem(), 0x10);
31 EXPECT_EQ(uh.scope(), 0x04);
32 EXPECT_EQ(uh.severity(), 0x20);
33 EXPECT_EQ(uh.eventType(), 0x00);
34 EXPECT_EQ(uh.problemDomain(), 0x03);
35 EXPECT_EQ(uh.problemVector(), 0x04);
36 EXPECT_EQ(uh.actionFlags(), 0x80C0);
37
38 // Now flatten into a vector and check that this vector
39 // matches the original one.
40 std::vector<uint8_t> newData;
41 Stream newStream(newData);
42
Matt Spinlercf5a8d02019-09-05 12:58:53 -050043 uh.flatten(newStream);
Matt Spinler42828bd2019-10-11 10:39:30 -050044 EXPECT_EQ(data, newData);
Matt Spinler03c1d912019-07-10 14:12:15 -050045}
46
47TEST(UserHeaderTest, ShortDataTest)
48{
Matt Spinler42828bd2019-10-11 10:39:30 -050049 auto data = pelDataFactory(TestPELType::userHeaderSection);
50 data.resize(data.size() - 1);
Matt Spinler03c1d912019-07-10 14:12:15 -050051
Matt Spinler42828bd2019-10-11 10:39:30 -050052 Stream stream(data);
Matt Spinler03c1d912019-07-10 14:12:15 -050053 UserHeader uh(stream);
54
55 EXPECT_EQ(uh.valid(), false);
56}
57
58TEST(UserHeaderTest, CorruptDataTest1)
59{
Matt Spinler42828bd2019-10-11 10:39:30 -050060 auto data = pelDataFactory(TestPELType::userHeaderSection);
61 data.resize(data.size() - 1);
Matt Spinler03c1d912019-07-10 14:12:15 -050062
Matt Spinler42828bd2019-10-11 10:39:30 -050063 data.at(0) = 0; // corrupt the section ID
Matt Spinler03c1d912019-07-10 14:12:15 -050064
Matt Spinler42828bd2019-10-11 10:39:30 -050065 Stream stream(data);
Matt Spinler03c1d912019-07-10 14:12:15 -050066 UserHeader uh(stream);
67
68 EXPECT_EQ(uh.valid(), false);
69}
70
71TEST(UserHeaderTest, CorruptDataTest2)
72{
Matt Spinler42828bd2019-10-11 10:39:30 -050073 auto data = pelDataFactory(TestPELType::userHeaderSection);
Matt Spinler03c1d912019-07-10 14:12:15 -050074
Matt Spinler42828bd2019-10-11 10:39:30 -050075 data.at(4) = 0x22; // corrupt the version
Matt Spinler03c1d912019-07-10 14:12:15 -050076
Matt Spinler42828bd2019-10-11 10:39:30 -050077 Stream stream(data);
Matt Spinler03c1d912019-07-10 14:12:15 -050078 UserHeader uh(stream);
79
80 EXPECT_EQ(uh.valid(), false);
81}
Matt Spinlerfdb6a202019-09-20 14:09:20 -050082
83// Construct the User Header from the message registry
84TEST(UserHeaderTest, ConstructionTest)
85{
86 using namespace openpower::pels::message;
87 Entry regEntry;
88
89 regEntry.name = "test";
90 regEntry.subsystem = 5;
91 regEntry.severity = 0x40;
92 regEntry.actionFlags = 0xC000;
93 regEntry.eventType = 1;
94 regEntry.eventScope = 2;
95
96 UserHeader uh(regEntry, phosphor::logging::Entry::Level::Error);
97
98 ASSERT_TRUE(uh.valid());
99 EXPECT_EQ(uh.header().id, 0x5548);
100 EXPECT_EQ(uh.header().size, UserHeader::flattenedSize());
101 EXPECT_EQ(uh.header().version, 0x01);
102 EXPECT_EQ(uh.header().subType, 0x00);
103 EXPECT_EQ(uh.header().componentID,
104 static_cast<uint16_t>(ComponentID::phosphorLogging));
105
106 ASSERT_EQ(uh.subsystem(), 5);
107 ASSERT_EQ(uh.severity(), 0x40);
108 ASSERT_EQ(uh.eventType(), 1);
109 ASSERT_EQ(uh.scope(), 2);
110 ASSERT_EQ(uh.problemDomain(), 0);
111 ASSERT_EQ(uh.problemVector(), 0);
112 ASSERT_EQ(uh.actionFlags(), 0xC000);
113}
114
115// Test that the severity comes from the event log if not
116// in the message registry
117TEST(UserHeaderTest, UseEventLogSevTest)
118{
119 using namespace openpower::pels::message;
120 Entry regEntry;
121
122 regEntry.name = "test";
123 regEntry.subsystem = 5;
124 regEntry.actionFlags = 0xC000;
125 regEntry.eventType = 1;
126 regEntry.eventScope = 2;
127 // Leave off severity
128
129 UserHeader uh(regEntry, phosphor::logging::Entry::Level::Error);
130 ASSERT_EQ(uh.severity(), 0x40);
131}
132
133// Test that the optional event type & scope fields work
134TEST(UserHeaderTest, DefaultEventTypeScopeTest)
135{
136 using namespace openpower::pels::message;
137 Entry regEntry;
138
139 regEntry.name = "test";
140 regEntry.subsystem = 5;
141 regEntry.severity = 0x40;
142 regEntry.actionFlags = 0xC000;
143
144 UserHeader uh(regEntry, phosphor::logging::Entry::Level::Error);
145
146 ASSERT_EQ(uh.eventType(), 0);
147 ASSERT_EQ(uh.scope(), 0x03);
148}