blob: b5cc3d9ce1e6bb8a5d56507ecdd9de272aea0db5 [file] [log] [blame]
Patrick Williams4690d882020-10-08 11:09:58 -05001#include <sdbusplus/utility/dedup_variant.hpp>
Paul Fertser5770f512022-01-10 11:05:41 +00002#include <sdbusplus/utility/merge_variants.hpp>
Patrick Williams0c841a12016-07-20 12:34:24 -05003#include <sdbusplus/utility/type_traits.hpp>
Patrick Williams127b8ab2020-05-21 15:24:19 -05004
William A. Kennington III977d4d42018-06-23 00:33:08 -07005#include <type_traits>
Patrick Williams0c841a12016-07-20 12:34:24 -05006
Krzysztof Grobelny09b88f22020-09-02 14:49:01 +02007#include <gmock/gmock.h>
Patrick Venture95269db2018-08-31 09:19:17 -07008
William A. Kennington III977d4d42018-06-23 00:33:08 -07009namespace
Patrick Williams0c841a12016-07-20 12:34:24 -050010{
Patrick Williams0c841a12016-07-20 12:34:24 -050011
William A. Kennington III977d4d42018-06-23 00:33:08 -070012using sdbusplus::utility::array_to_ptr_t;
Patrick Williams64f01222021-07-14 10:14:51 -050013using std::is_same_v;
William A. Kennington III977d4d42018-06-23 00:33:08 -070014
15TEST(TypeTraits, Basic)
16{
Patrick Williams64f01222021-07-14 10:14:51 -050017 static_assert(is_same_v<char, array_to_ptr_t<char, char>>,
Andrew Geissler072da3e2018-01-18 07:21:42 -080018 "array_to_ptr_t<char, char> != char");
Patrick Williams0c841a12016-07-20 12:34:24 -050019
Patrick Williams64f01222021-07-14 10:14:51 -050020 static_assert(is_same_v<char*, array_to_ptr_t<char, char*>>,
Andrew Geissler072da3e2018-01-18 07:21:42 -080021 "array_to_ptr_t<char, char*> != char*");
Patrick Williams0c841a12016-07-20 12:34:24 -050022
Patrick Williams64f01222021-07-14 10:14:51 -050023 static_assert(is_same_v<char*, array_to_ptr_t<char, char[100]>>,
Andrew Geissler072da3e2018-01-18 07:21:42 -080024 "array_to_ptr_t<char, char[100]> != char*");
Patrick Williams0c841a12016-07-20 12:34:24 -050025
Patrick Williams64f01222021-07-14 10:14:51 -050026 static_assert(is_same_v<char[100], array_to_ptr_t<int, char[100]>>,
William A. Kennington III977d4d42018-06-23 00:33:08 -070027 "array_to_ptr_t<int, char[100]> != char[100]");
Patrick Williams0c841a12016-07-20 12:34:24 -050028}
William A. Kennington III977d4d42018-06-23 00:33:08 -070029
Krzysztof Grobelny09b88f22020-09-02 14:49:01 +020030TEST(TypeTraits, HasMemberFind)
31{
32 using sdbusplus::utility::has_member_find_v;
33 using namespace testing;
34
35 ASSERT_THAT((has_member_find_v<std::map<std::string, int>>), Eq(true));
36 ASSERT_THAT((has_member_find_v<std::vector<std::pair<std::string, int>>>),
37 Eq(false));
38
39 struct Foo
40 {
41 using value_type = std::pair<int, int>;
42
Patrick Williamsf289c652022-08-26 10:43:10 -050043 void find(std::tuple_element_t<0, value_type>) {}
Krzysztof Grobelny09b88f22020-09-02 14:49:01 +020044 };
45
46 struct Bar
47 {};
48
49 ASSERT_THAT(has_member_find_v<Foo>, Eq(true));
50 ASSERT_THAT(has_member_find_v<Foo&>, Eq(true));
51 ASSERT_THAT(has_member_find_v<const Foo&>, Eq(true));
52
53 ASSERT_THAT(has_member_find_v<Bar>, Eq(false));
54}
55
56TEST(TypeTraits, HasMemberContains)
57{
58 using sdbusplus::utility::has_member_contains_v;
59 using namespace testing;
60
61 // std::map has member_contains from c++20
Patrick Williams2e988612021-04-14 14:49:25 -050062 ASSERT_THAT((has_member_contains_v<std::map<std::string, int>>), Eq(true));
Krzysztof Grobelny09b88f22020-09-02 14:49:01 +020063 ASSERT_THAT(
64 (has_member_contains_v<std::vector<std::pair<std::string, int>>>),
65 Eq(false));
66
67 struct Foo
68 {
69 using value_type = std::pair<int, int>;
70
Patrick Williamsf289c652022-08-26 10:43:10 -050071 void contains(std::tuple_element_t<0, value_type>) {}
Krzysztof Grobelny09b88f22020-09-02 14:49:01 +020072 };
73
74 struct Bar
75 {};
76
77 ASSERT_THAT(has_member_contains_v<Foo>, Eq(true));
78 ASSERT_THAT(has_member_contains_v<Foo&>, Eq(true));
79 ASSERT_THAT(has_member_contains_v<const Foo&>, Eq(true));
80
81 ASSERT_THAT(has_member_contains_v<Bar>, Eq(false));
82}
83
Krzysztof Grobelnyc8447d52022-01-05 13:21:37 +010084TEST(TypeTraits, IsOptional)
85{
86 using sdbusplus::utility::is_optional;
87 using sdbusplus::utility::is_optional_v;
88
89 ASSERT_TRUE(is_optional<std::optional<int>>::value);
90 ASSERT_TRUE(is_optional<std::optional<int>&>::value);
91 ASSERT_FALSE(is_optional<int>::value);
92
93 ASSERT_TRUE(is_optional_v<std::optional<int>>);
94 ASSERT_TRUE(is_optional_v<std::optional<int>&>);
95 ASSERT_FALSE(is_optional_v<int>);
96}
97
Patrick Williams4690d882020-10-08 11:09:58 -050098// Tests for dedup_variant.
99static_assert(std::is_same_v<std::variant<size_t>,
Patrick Williams34cf6932021-07-14 09:46:31 -0500100 sdbusplus::utility::dedup_variant_t<size_t>>);
101static_assert(
102 std::is_same_v<std::variant<char, size_t>,
103 sdbusplus::utility::dedup_variant_t<char, size_t>>);
Patrick Williams4690d882020-10-08 11:09:58 -0500104static_assert(std::is_same_v<
105 std::variant<uint32_t, uint64_t>,
Patrick Williams34cf6932021-07-14 09:46:31 -0500106 sdbusplus::utility::dedup_variant_t<uint32_t, uint64_t, size_t>>);
Patrick Williams4690d882020-10-08 11:09:58 -0500107
Paul Fertser5770f512022-01-10 11:05:41 +0000108// Tests for merge_variants.
109static_assert(
110 std::is_same_v<std::variant<size_t>,
111 sdbusplus::utility::merge_variants_t<std::variant<size_t>>>);
112static_assert(std::is_same_v<std::variant<char, uint32_t, uint64_t>,
113 sdbusplus::utility::merge_variants_t<
114 std::variant<char, uint32_t>,
115 std::variant<uint32_t, uint64_t, size_t>>>);
116
William A. Kennington III977d4d42018-06-23 00:33:08 -0700117} // namespace