1 /**
2 * Copyright © 2019 IBM Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16 #include "extensions/openpower-pels/severity.hpp"
17
18 #include <gtest/gtest.h>
19
20 using namespace openpower::pels;
21 using LogSeverity = phosphor::logging::Entry::Level;
22
TEST(SeverityTest,SeverityMapTest)23 TEST(SeverityTest, SeverityMapTest)
24 {
25 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Informational), 0x00);
26 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Notice), 0x00);
27 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Debug), 0x00);
28 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Warning), 0x20);
29 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Critical), 0x50);
30 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Emergency), 0x40);
31 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Alert), 0x40);
32 ASSERT_EQ(convertOBMCSeverityToPEL(LogSeverity::Error), 0x40);
33 }
34
TEST(SeverityTest,fixupLogSeverityTest)35 TEST(SeverityTest, fixupLogSeverityTest)
36 {
37 struct TestParams
38 {
39 LogSeverity sevIn;
40 SeverityType pelSevIn;
41 std::optional<LogSeverity> sevOut;
42 };
43
44 const std::vector<TestParams> testParams{
45 // Convert nonInfo sevs to info
46 {LogSeverity::Error, SeverityType::nonError,
47 LogSeverity::Informational},
48 {LogSeverity::Critical, SeverityType::recovered,
49 LogSeverity::Informational},
50 {LogSeverity::Warning, SeverityType::nonError,
51 LogSeverity::Informational},
52
53 // Convert info sevs to nonInfo
54 {LogSeverity::Informational, SeverityType::predictive,
55 LogSeverity::Warning},
56 {LogSeverity::Notice, SeverityType::unrecoverable, LogSeverity::Error},
57 {LogSeverity::Debug, SeverityType::critical, LogSeverity::Critical},
58
59 // Convert non-critical to critical
60 {LogSeverity::Warning, SeverityType::critical, LogSeverity::Critical},
61
62 // No change
63 {LogSeverity::Informational, SeverityType::nonError, std::nullopt},
64 {LogSeverity::Debug, SeverityType::recovered, std::nullopt},
65 {LogSeverity::Notice, SeverityType::nonError, std::nullopt},
66 {LogSeverity::Error, SeverityType::unrecoverable, std::nullopt},
67 {LogSeverity::Critical, SeverityType::unrecoverable, std::nullopt}};
68
69 for (const auto& test : testParams)
70 {
71 EXPECT_EQ(fixupLogSeverity(test.sevIn, test.pelSevIn), test.sevOut);
72 }
73 }
74