1 #include "data_types.hpp" 2 3 #include <array> 4 #include <string> 5 6 #include <gtest/gtest.h> 7 8 using namespace std::string_literals; 9 using namespace phosphor::dbus::monitoring; 10 using PathMeta = TupleOfRefs<const std::string, const std::string>; 11 12 #include "pathgentest.hpp" 13 14 const std::array<std::string, 3> expectedMeta = { 15 "PATH1"s, 16 "PATH3"s, 17 "PATH2"s, 18 }; 19 20 const std::array<std::string, 6> expectedPaths = { 21 "/xyz/openbmc_project/testing/inst1"s, 22 "/xyz/openbmc_project/testing/inst2"s, 23 "/xyz/openbmc_project/testing/inst3"s, 24 "/xyz/openbmc_project/testing/inst4"s, 25 "/xyz/openbmc_project/testing/inst5"s, 26 "/xyz/openbmc_project/testing/inst6"s, 27 }; 28 29 const std::array<PathMeta, 14> expectedPathMeta = {{ 30 PathMeta{paths[0], meta[0]}, 31 PathMeta{paths[1], meta[0]}, 32 PathMeta{paths[2], meta[0]}, 33 PathMeta{paths[3], meta[0]}, 34 PathMeta{paths[0], meta[1]}, 35 PathMeta{paths[1], meta[1]}, 36 PathMeta{paths[2], meta[1]}, 37 PathMeta{paths[3], meta[1]}, 38 PathMeta{paths[4], meta[0]}, 39 PathMeta{paths[5], meta[0]}, 40 PathMeta{paths[3], meta[2]}, 41 PathMeta{paths[2], meta[2]}, 42 PathMeta{paths[1], meta[2]}, 43 PathMeta{paths[0], meta[2]}, 44 }}; 45 46 const std::array<RefVector<const std::string>, 4> expectedGroups = {{ 47 { 48 paths[0], 49 paths[1], 50 paths[2], 51 paths[3], 52 }, 53 { 54 paths[0], 55 paths[1], 56 paths[2], 57 paths[3], 58 }, 59 { 60 paths[0], 61 paths[1], 62 paths[4], 63 paths[5], 64 }, 65 { 66 paths[3], 67 paths[2], 68 paths[1], 69 paths[0], 70 }, 71 }}; 72 73 TEST(PathGenTest, MetaSameSize) 74 { 75 ASSERT_EQ(sizeof(expectedMeta), sizeof(meta)); 76 } 77 78 TEST(PathGenTest, PathsSameSize) 79 { 80 ASSERT_EQ(sizeof(expectedPaths), sizeof(paths)); 81 } 82 83 TEST(PathGenTest, PathMetaSameSize) 84 { 85 ASSERT_EQ(sizeof(expectedPathMeta), sizeof(pathMeta)); 86 } 87 88 TEST(PathGenTest, GroupsSameSize) 89 { 90 ASSERT_EQ(sizeof(expectedGroups), sizeof(groups)); 91 } 92 93 TEST(PathGenTest, MetaSameContent) 94 { 95 size_t i; 96 for (i = 0; i < expectedMeta.size(); ++i) 97 { 98 ASSERT_EQ(meta[i], expectedMeta[i]); 99 } 100 } 101 102 TEST(PathGenTest, PathsSameContent) 103 { 104 size_t i; 105 for (i = 0; i < expectedPaths.size(); ++i) 106 { 107 ASSERT_EQ(paths[i], expectedPaths[i]); 108 } 109 } 110 111 TEST(PathGenTest, PathMetaSameContent) 112 { 113 size_t i; 114 for (i = 0; i < expectedPathMeta.size(); ++i) 115 { 116 const auto& path = std::get<0>(pathMeta[i]).get(); 117 const auto& expPath = std::get<0>(expectedPathMeta[i]).get(); 118 const auto& meta = std::get<1>(pathMeta[i]).get(); 119 const auto& expMeta = std::get<1>(expectedPathMeta[i]).get(); 120 121 ASSERT_EQ(path, expPath); 122 ASSERT_EQ(meta, expMeta); 123 } 124 } 125 126 TEST(PathGenTest, GroupsSameContent) 127 { 128 size_t i; 129 for (i = 0; i < expectedGroups.size(); ++i) 130 { 131 size_t j; 132 for (j = 0; j < groups[i].size(); ++j) 133 { 134 ASSERT_EQ(groups[i][j].get(), expectedGroups[i][j].get()); 135 } 136 } 137 } 138