blob: d92204015d8d7e60d9c928d2553967babc50d40a [file] [log] [blame]
Jeff Pu6ccd9562024-02-21 10:46:35 -05001/*
2 * Copyright (C) 2024 The Android Open Source Project
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
17#include <gtest/gtest.h>
18
19#include "config/Config.h"
20
21#define LOG_TAG "ConfigTest"
22#include <android-base/logging.h>
23
24// using namespace ::testing::Eq;
25using namespace testing;
26
27#define SP_DEFAULT_astring "astringSP"
28#define SP_DEFAULT_aint32 32
29#define SP_DEFAULT_aint64 64
30#define SP_DEFAULT_abool false
31#define SP_DEFAULT_avector \
32 { 1, 2, 3 }
33namespace aidl::android::hardware::biometrics {
34namespace TestHalProperties {
35OptString val_astring = SP_DEFAULT_astring;
36OptInt32 val_aint32 = SP_DEFAULT_aint32;
37OptInt64 val_aint64 = SP_DEFAULT_aint64;
38OptBool val_abool = SP_DEFAULT_abool;
39OptIntVec val_avector = SP_DEFAULT_avector;
40
41OptString astring() {
42 return val_astring;
43}
44bool astring(const OptString& v) {
45 val_astring = v;
46 return true;
47}
48OptInt32 aint32() {
49 return val_aint32;
50}
51bool aint32(const OptInt32& v) {
52 val_aint32 = v;
53 return true;
54}
55OptInt64 aint64() {
56 return val_aint64;
57}
58bool aint64(const OptInt64& v) {
59 val_aint64 = v;
60 return true;
61}
62OptBool abool() {
63 return val_abool;
64}
65bool abool(const OptBool& v) {
66 val_abool = v;
67 return true;
68}
69OptIntVec avector() {
70 return val_avector;
71}
72bool avector(const OptIntVec& v) {
73 val_avector = v;
74 return true;
75}
76} // namespace TestHalProperties
77using namespace TestHalProperties;
78#define AIDL_DEFAULT_astring "astringAIDL"
79#define AIDL_DEFAULT_aint32 "320"
80#define AIDL_DEFAULT_aint64 "640"
81#define AIDL_DEFAULT_abool "true"
82#define AIDL_DEFAULT_avector "10,20,30"
83#define CREATE_GETTER_SETTER_WRAPPER(_NAME_, _T_) \
84 ConfigValue _NAME_##Getter() { \
85 return TestHalProperties::_NAME_(); \
86 } \
87 bool _NAME_##Setter(const ConfigValue& v) { \
88 return TestHalProperties::_NAME_(std::get<_T_>(v)); \
89 }
90CREATE_GETTER_SETTER_WRAPPER(astring, OptString)
91CREATE_GETTER_SETTER_WRAPPER(aint32, OptInt32)
92CREATE_GETTER_SETTER_WRAPPER(aint64, OptInt64)
93CREATE_GETTER_SETTER_WRAPPER(abool, OptBool)
94CREATE_GETTER_SETTER_WRAPPER(avector, std::vector<OptInt32>)
95
96// Name,Getter, Setter, Parser and default value
97#define NGS(_NAME_) #_NAME_, _NAME_##Getter, _NAME_##Setter
98static Config::Data configData[] = {
99 {NGS(astring), &Config::parseString, AIDL_DEFAULT_astring},
100 {NGS(aint32), &Config::parseInt32, AIDL_DEFAULT_aint32},
101 {NGS(aint64), &Config::parseInt64, AIDL_DEFAULT_aint64},
102 {NGS(abool), &Config::parseBool, AIDL_DEFAULT_abool},
103 {NGS(avector), &Config::parseIntVec, AIDL_DEFAULT_avector},
104};
105
106class TestConfig : public Config {
107 Config::Data* getConfigData(int* size) {
108 *size = sizeof(configData) / sizeof(configData[0]);
109 return configData;
110 }
111};
112
113class ConfigTest : public ::testing::Test {
114 protected:
115 void SetUp() override { cfg.init(); }
116 void TearDown() override {}
117
118 void switch2aidl() { cfg.setParam("astring", "astring"); }
119
120 TestConfig cfg;
121};
122
123TEST_F(ConfigTest, parseInt32) {
124 std::int32_t defval = 5678;
125 struct {
126 std::string strval;
127 std::int32_t expval;
128 } values[] = {
129 {"1234", 1234},
130 {"0", 0},
131 {"", defval},
132 {"xyz", defval},
133 };
134 for (int i = 0; i < sizeof(values) / sizeof(values[0]); i++) {
135 ASSERT_EQ((std::get<OptInt32>(cfg.parseInt32(values[i].strval))).value_or(defval),
136 values[i].expval);
137 }
138}
139
140TEST_F(ConfigTest, parseInt64) {
141 std::int64_t defval = 5678;
142 struct {
143 std::string strval;
144 std::int64_t expval;
145 } values[] = {
146 {"1234", 1234}, {"12345678909876", 12345678909876}, {"0", 0}, {"", defval},
147 {"xyz", defval},
148 };
149 for (int i = 0; i < sizeof(values) / sizeof(values[0]); i++) {
150 ASSERT_EQ((std::get<OptInt64>(cfg.parseInt64(values[i].strval))).value_or(defval),
151 values[i].expval);
152 }
153}
154
155TEST_F(ConfigTest, parseBool) {
156 bool defval = true;
157 struct {
158 std::string strval;
159 bool expval;
160 } values[] = {
161 {"false", false},
162 {"true", true},
163 {"", defval},
164 {"xyz", defval},
165 };
166 for (int i = 0; i < sizeof(values) / sizeof(values[0]); i++) {
167 ASSERT_EQ((std::get<OptBool>(cfg.parseBool(values[i].strval))).value_or(defval),
168 values[i].expval);
169 }
170}
171
172TEST_F(ConfigTest, parseIntVec) {
173 std::vector<std::optional<int>> defval = {};
174 struct {
175 std::string strval;
176 std::vector<std::optional<int>> expval;
177 } values[] = {
178 {"1", {1}}, {"1,2,3", {1, 2, 3}}, {"1,2,b", defval}, {"", defval}, {"xyz", defval},
179 };
180 for (int i = 0; i < sizeof(values) / sizeof(values[0]); i++) {
181 ASSERT_EQ(std::get<OptIntVec>(cfg.parseIntVec(values[i].strval)), values[i].expval);
182 }
183}
184
185TEST_F(ConfigTest, getters_sp) {
186 ASSERT_EQ(cfg.get<std::string>("astring"), val_astring);
187 ASSERT_EQ(cfg.get<std::int32_t>("aint32"), val_aint32);
188 ASSERT_EQ(cfg.get<std::int64_t>("aint64"), val_aint64);
189 ASSERT_EQ(cfg.get<bool>("abool"), val_abool);
190 OptIntVec exp{val_avector};
191 EXPECT_EQ(cfg.getopt<OptIntVec>("avector"), exp);
192}
193
194TEST_F(ConfigTest, setters_sp) {
195 std::string val_astring_new("astringNew");
196 ASSERT_TRUE(cfg.set<std::string>("astring", val_astring_new));
197 ASSERT_EQ(cfg.get<std::string>("astring"), val_astring_new);
198
199 std::int32_t val_aint32_new = val_aint32.value() + 100;
200 ASSERT_TRUE(cfg.set<std::int32_t>("aint32", val_aint32_new));
201 ASSERT_EQ(cfg.get<std::int32_t>("aint32"), val_aint32_new);
202
203 std::int64_t val_aint64_new = val_aint64.value() + 200;
204 ASSERT_TRUE(cfg.set<std::int64_t>("aint64", val_aint64_new));
205 ASSERT_EQ(cfg.get<std::int64_t>("aint64"), val_aint64_new);
206
207 bool val_abool_new = !val_abool.value();
208 ASSERT_TRUE(cfg.set<bool>("abool", val_abool_new));
209 ASSERT_EQ(cfg.get<bool>("abool"), val_abool_new);
210
211 OptIntVec val_avector_new{100, 200};
212 ASSERT_TRUE(cfg.setopt<OptIntVec>("avector", val_avector_new));
213 EXPECT_EQ(cfg.getopt<OptIntVec>("avector"), val_avector_new);
214}
215
216TEST_F(ConfigTest, setters_sp_null) {
217 val_astring = std::nullopt;
218 ASSERT_EQ(cfg.get<std::string>("astring"),
219 (std::get<OptString>(cfg.parseString(AIDL_DEFAULT_astring))).value());
220}
221
222TEST_F(ConfigTest, getters_aidl) {
223 cfg.setParam("astring", "astringAIDL");
224 ASSERT_EQ(cfg.get<std::string>("astring"),
225 (std::get<OptString>(cfg.parseString(AIDL_DEFAULT_astring))).value());
226 ASSERT_EQ(cfg.get<std::int32_t>("aint32"),
227 (std::get<OptInt32>(cfg.parseInt32(AIDL_DEFAULT_aint32))).value());
228 ASSERT_EQ(cfg.get<std::int64_t>("aint64"),
229 (std::get<OptInt64>(cfg.parseInt64(AIDL_DEFAULT_aint64))).value());
230 ASSERT_EQ(cfg.get<bool>("abool"),
231 (std::get<OptBool>(cfg.parseBool(AIDL_DEFAULT_abool))).value());
232 OptIntVec exp{std::get<OptIntVec>(cfg.parseIntVec(AIDL_DEFAULT_avector))};
233 EXPECT_EQ(cfg.getopt<OptIntVec>("avector"), exp);
234}
235
236TEST_F(ConfigTest, setters_aidl) {
237 std::string val_astring_new("astringNewAidl");
238 ASSERT_TRUE(cfg.set<std::string>("astring", val_astring_new));
239 ASSERT_EQ(cfg.get<std::string>("astring"), val_astring_new);
240
241 std::int32_t val_aint32_new = val_aint32.value() + 1000;
242 ASSERT_TRUE(cfg.set<std::int32_t>("aint32", val_aint32_new));
243 ASSERT_EQ(cfg.get<std::int32_t>("aint32"), val_aint32_new);
244
245 std::int64_t val_aint64_new = val_aint64.value() + 2000;
246 ASSERT_TRUE(cfg.set<std::int64_t>("aint64", val_aint64_new));
247 ASSERT_EQ(cfg.get<std::int64_t>("aint64"), val_aint64_new);
248
249 bool val_abool_new = !val_abool.value();
250 ASSERT_TRUE(cfg.set<bool>("abool", val_abool_new));
251 ASSERT_EQ(cfg.get<bool>("abool"), val_abool_new);
252
253 OptIntVec val_avector_new{1000, 2000};
254 ASSERT_TRUE(cfg.setopt<OptIntVec>("avector", val_avector_new));
255 EXPECT_EQ(cfg.getopt<OptIntVec>("avector"), val_avector_new);
256}
257
258TEST_F(ConfigTest, setParam) {
259 ASSERT_TRUE(cfg.setParam("aint32", "789"));
260 ASSERT_EQ(cfg.get<std::int32_t>("aint32"), 789);
261 ASSERT_TRUE(cfg.setParam("avector", "7,8,9,10"));
262 OptIntVec val_avector_new{7, 8, 9, 10};
263 EXPECT_EQ(cfg.getopt<OptIntVec>("avector"), val_avector_new);
264 ASSERT_FALSE(cfg.setParam("unknown", "any"));
265}
266} // namespace aidl::android::hardware::biometrics