test_main.cpp revision 96e9de049f4dd2ee7d02eaf9a662e286964c2039
1/*
2 * Copyright (C) 2016 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#define LOG_TAG "LibHidlTest"
18
19#include <android-base/logging.h>
20#include <condition_variable>
21#include <gmock/gmock.h>
22#include <gtest/gtest.h>
23#include <hidl/HidlSupport.h>
24#include <hidl/Status.h>
25#include <hidl/TaskRunner.h>
26#include <vector>
27
28#define EXPECT_ARRAYEQ(__a1__, __a2__, __size__) EXPECT_TRUE(isArrayEqual(__a1__, __a2__, __size__))
29#define EXPECT_2DARRAYEQ(__a1__, __a2__, __size1__, __size2__) \
30        EXPECT_TRUE(is2dArrayEqual(__a1__, __a2__, __size1__, __size2__))
31
32template<typename T, typename S>
33static inline bool isArrayEqual(const T arr1, const S arr2, size_t size) {
34    for(size_t i = 0; i < size; i++)
35        if(arr1[i] != arr2[i])
36            return false;
37    return true;
38}
39
40template<typename T, typename S>
41static inline bool is2dArrayEqual(const T arr1, const S arr2, size_t size1, size_t size2) {
42    for(size_t i = 0; i < size1; i++)
43        for (size_t j = 0; j < size2; j++)
44            if(arr1[i][j] != arr2[i][j])
45                return false;
46    return true;
47}
48
49class LibHidlTest : public ::testing::Test {
50public:
51    virtual void SetUp() override {
52    }
53    virtual void TearDown() override {
54    }
55};
56
57TEST_F(LibHidlTest, StringTest) {
58    using android::hardware::hidl_string;
59    hidl_string s; // empty constructor
60    EXPECT_STREQ(s.c_str(), "");
61    hidl_string s1 = "s1"; // copy = from cstr
62    EXPECT_STREQ(s1.c_str(), "s1");
63    hidl_string s2("s2"); // copy constructor from cstr
64    EXPECT_STREQ(s2.c_str(), "s2");
65    hidl_string s2a(nullptr); // copy constructor from null cstr
66    EXPECT_STREQ("", s2a.c_str());
67    s2a = nullptr; // = from nullptr cstr
68    EXPECT_STREQ(s2a.c_str(), "");
69    hidl_string s3 = hidl_string("s3"); // move =
70    EXPECT_STREQ(s3.c_str(), "s3");
71    hidl_string s4 = hidl_string("12345", 3); // copy constructor from cstr w/ length
72    EXPECT_STREQ(s4.c_str(), "123");
73    hidl_string s5(hidl_string(hidl_string("s5"))); // move constructor
74    EXPECT_STREQ(s5.c_str(), "s5");
75    hidl_string s6(std::string("s6")); // copy constructor from std::string
76    EXPECT_STREQ(s6.c_str(), "s6");
77    hidl_string s7 = std::string("s7"); // copy = from std::string
78    EXPECT_STREQ(s7.c_str(), "s7");
79    hidl_string s8(s7); // copy constructor // NOLINT, test the copy constructor
80    EXPECT_STREQ(s8.c_str(), "s7");
81    hidl_string s9 = s8; // copy =  // NOLINT, test the copy operator
82    EXPECT_STREQ(s9.c_str(), "s7");
83    char myCString[20] = "myCString";
84    s.setToExternal(&myCString[0], strlen(myCString));
85    EXPECT_STREQ(s.c_str(), "myCString");
86    myCString[2] = 'D';
87    EXPECT_STREQ(s.c_str(), "myDString");
88    s.clear(); // should not affect myCString
89    EXPECT_STREQ(myCString, "myDString");
90
91    // casts
92    s = "great";
93    std::string myString = s;
94    const char *anotherCString = s.c_str();
95    EXPECT_EQ(myString, "great");
96    EXPECT_STREQ(anotherCString, "great");
97
98    const hidl_string t = "not so great";
99    std::string myTString = t;
100    const char * anotherTCString = t.c_str();
101    EXPECT_EQ(myTString, "not so great");
102    EXPECT_STREQ(anotherTCString, "not so great");
103
104    // Assignment from hidl_string to std::string
105    std::string tgt;
106    hidl_string src("some stuff");
107    tgt = src;
108    EXPECT_STREQ(tgt.c_str(), "some stuff");
109
110    // Stream output operator
111    hidl_string msg("hidl_string works with operator<<");
112    std::cout << msg;
113
114    // Comparisons
115    const char * cstr1 = "abc";
116    std::string string1(cstr1);
117    hidl_string hs1(cstr1);
118    const char * cstrE = "abc";
119    std::string stringE(cstrE);
120    hidl_string hsE(cstrE);
121    const char * cstrNE = "ABC";
122    std::string stringNE(cstrNE);
123    hidl_string hsNE(cstrNE);
124    const char * cstr2 = "def";
125    std::string string2(cstr2);
126    hidl_string hs2(cstr2);
127
128    EXPECT_TRUE(hs1  == hsE);
129    EXPECT_FALSE(hs1 == hsNE);
130    EXPECT_TRUE(hs1  == cstrE);
131    EXPECT_FALSE(hs1 == cstrNE);
132    EXPECT_TRUE(hs1  == stringE);
133    EXPECT_FALSE(hs1 == stringNE);
134    EXPECT_FALSE(hs1 != hsE);
135    EXPECT_TRUE(hs1  != hsNE);
136    EXPECT_FALSE(hs1 != cstrE);
137    EXPECT_TRUE(hs1  != cstrNE);
138    EXPECT_FALSE(hs1 != stringE);
139    EXPECT_TRUE(hs1  != stringNE);
140
141    EXPECT_TRUE(hs1 < hs2);
142    EXPECT_FALSE(hs2 < hs1);
143    EXPECT_TRUE(hs2 > hs1);
144    EXPECT_FALSE(hs1 > hs2);
145    EXPECT_TRUE(hs1 <= hs1);
146    EXPECT_TRUE(hs1 <= hs2);
147    EXPECT_FALSE(hs2 <= hs1);
148    EXPECT_TRUE(hs1 >= hs1);
149    EXPECT_TRUE(hs2 >= hs1);
150    EXPECT_FALSE(hs2 <= hs1);
151}
152
153TEST_F(LibHidlTest, MemoryTest) {
154    using android::hardware::hidl_memory;
155
156    hidl_memory mem1 = hidl_memory(); // default constructor
157    hidl_memory mem2 = mem1; // copy constructor (nullptr), NOLINT
158
159    EXPECT_EQ(nullptr, mem2.handle());
160
161    native_handle_t* testHandle = native_handle_create(0 /* numInts */, 0 /* numFds */);
162
163    hidl_memory mem3 = hidl_memory("foo", testHandle, 42 /* size */); // owns testHandle
164    hidl_memory mem4 = mem3; // copy constructor (regular handle), NOLINT
165
166    EXPECT_EQ(mem3.name(), mem4.name());
167    EXPECT_EQ(mem3.size(), mem4.size());
168    EXPECT_NE(nullptr, mem4.handle());
169    EXPECT_NE(mem3.handle(), mem4.handle()); // check handle cloned
170
171    hidl_memory mem5 = hidl_memory("foo", nullptr, 0); // hidl memory works with nullptr handle
172    hidl_memory mem6 = mem5; // NOLINT, test copying
173    EXPECT_EQ(nullptr, mem5.handle());
174    EXPECT_EQ(nullptr, mem6.handle());
175}
176
177TEST_F(LibHidlTest, VecInitTest) {
178    using android::hardware::hidl_vec;
179    using std::vector;
180    int32_t empty[3] = {0};
181    int32_t array[] = {5, 6, 7};
182    vector<int32_t> v(array, array + 3);
183
184    hidl_vec<int32_t> hv0(3);  // size
185    EXPECT_EQ(hv0.size(), 3ul);
186    EXPECT_ARRAYEQ(hv0, empty, 3);
187
188    hidl_vec<int32_t> hv1 = v; // copy =
189    EXPECT_ARRAYEQ(hv1, array, 3);
190    EXPECT_ARRAYEQ(hv1, v, 3);
191    hidl_vec<int32_t> hv2(v); // copy constructor
192    EXPECT_ARRAYEQ(hv2, v, 3);
193
194    vector<int32_t> v2 = hv1; // cast
195    EXPECT_ARRAYEQ(v2, v, 3);
196
197    hidl_vec<int32_t> v3 = {5, 6, 7}; // initializer_list
198    EXPECT_EQ(v3.size(), 3ul);
199    EXPECT_ARRAYEQ(v3, array, v3.size());
200}
201
202TEST_F(LibHidlTest, VecIterTest) {
203    int32_t array[] = {5, 6, 7};
204    android::hardware::hidl_vec<int32_t> hv1 = std::vector<int32_t>(array, array + 3);
205
206    auto iter = hv1.begin();    // iterator begin()
207    EXPECT_EQ(*iter++, 5);
208    EXPECT_EQ(*iter, 6);
209    EXPECT_EQ(*++iter, 7);
210    EXPECT_EQ(*iter--, 7);
211    EXPECT_EQ(*iter, 6);
212    EXPECT_EQ(*--iter, 5);
213
214    iter += 2;
215    EXPECT_EQ(*iter, 7);
216    iter -= 2;
217    EXPECT_EQ(*iter, 5);
218
219    iter++;
220    EXPECT_EQ(*(iter + 1), 7);
221    EXPECT_EQ(*(1 + iter), 7);
222    EXPECT_EQ(*(iter - 1), 5);
223    EXPECT_EQ(*iter, 6);
224
225    auto five = iter - 1;
226    auto seven = iter + 1;
227    EXPECT_EQ(seven - five, 2);
228    EXPECT_EQ(five - seven, -2);
229
230    EXPECT_LT(five, seven);
231    EXPECT_LE(five, seven);
232    EXPECT_GT(seven, five);
233    EXPECT_GE(seven, five);
234
235    EXPECT_EQ(seven[0], 7);
236    EXPECT_EQ(five[1], 6);
237}
238
239TEST_F(LibHidlTest, VecIterForTest) {
240    using android::hardware::hidl_vec;
241    int32_t array[] = {5, 6, 7};
242    hidl_vec<int32_t> hv1 = std::vector<int32_t>(array, array + 3);
243
244    int32_t sum = 0;            // range based for loop interoperability
245    for (auto &&i: hv1) {
246        sum += i;
247    }
248    EXPECT_EQ(sum, 5+6+7);
249
250    for (auto iter = hv1.begin(); iter < hv1.end(); ++iter) {
251        *iter += 10;
252    }
253    const hidl_vec<int32_t> &v4 = hv1;
254    sum = 0;
255    for (const auto &i : v4) {
256        sum += i;
257    }
258    EXPECT_EQ(sum, 15+16+17);
259}
260
261TEST_F(LibHidlTest, VecEqTest) {
262    android::hardware::hidl_vec<int32_t> hv1{5, 6, 7};
263    android::hardware::hidl_vec<int32_t> hv2{5, 6, 7};
264    android::hardware::hidl_vec<int32_t> hv3{5, 6, 8};
265
266    // use the == and != operator intentionally here
267    EXPECT_TRUE(hv1 == hv2);
268    EXPECT_TRUE(hv1 != hv3);
269}
270
271TEST_F(LibHidlTest, VecRangeCtorTest) {
272    struct ConvertibleType {
273        int val;
274
275        explicit ConvertibleType(int val) : val(val) {}
276        explicit operator int() const { return val; }
277        bool operator==(const int& other) const { return val == other; }
278    };
279
280    std::vector<ConvertibleType> input{
281        ConvertibleType(1), ConvertibleType(2), ConvertibleType(3),
282    };
283
284    android::hardware::hidl_vec<int> hv(input.begin(), input.end());
285
286    EXPECT_EQ(input.size(), hv.size());
287    int sum = 0;
288    for (unsigned i = 0; i < input.size(); i++) {
289        EXPECT_EQ(input[i], hv[i]);
290        sum += hv[i];
291    }
292    EXPECT_EQ(sum, 1 + 2 + 3);
293}
294
295TEST_F(LibHidlTest, ArrayTest) {
296    using android::hardware::hidl_array;
297    int32_t array[] = {5, 6, 7};
298
299    hidl_array<int32_t, 3> ha(array);
300    EXPECT_ARRAYEQ(ha, array, 3);
301}
302
303TEST_F(LibHidlTest, TaskRunnerTest) {
304    using android::hardware::details::TaskRunner;
305    using namespace std::chrono_literals;
306
307    std::condition_variable cv;
308    std::mutex m;
309
310    TaskRunner tr;
311    tr.start(1 /* limit */);
312    bool flag = false;
313    tr.push([&] {
314        flag = true;
315        cv.notify_all();
316    });
317
318    std::unique_lock<std::mutex> lock(m);
319
320    // 1s so this doesn't deadlock. This isn't a performance test.
321    EXPECT_TRUE(cv.wait_for(lock, 1s, [&]{return flag;}));
322    EXPECT_TRUE(flag);
323}
324
325TEST_F(LibHidlTest, StringCmpTest) {
326    using android::hardware::hidl_string;
327    const char * s = "good";
328    hidl_string hs(s);
329    EXPECT_NE(hs.c_str(), s);
330
331    EXPECT_TRUE(hs == s); // operator ==
332    EXPECT_TRUE(s == hs);
333
334    EXPECT_FALSE(hs != s); // operator ==
335    EXPECT_FALSE(s != hs);
336}
337
338template <typename T>
339void great(android::hardware::hidl_vec<T>) {}
340
341TEST_F(LibHidlTest, VecCopyTest) {
342    android::hardware::hidl_vec<int32_t> v;
343    great(v);
344}
345
346TEST_F(LibHidlTest, StdArrayTest) {
347    using android::hardware::hidl_array;
348    hidl_array<int32_t, 5> array{(int32_t[5]){1, 2, 3, 4, 5}};
349    std::array<int32_t, 5> stdArray = array;
350    EXPECT_ARRAYEQ(array.data(), stdArray.data(), 5);
351    hidl_array<int32_t, 5> array2 = stdArray;
352    EXPECT_ARRAYEQ(array.data(), array2.data(), 5);
353}
354
355TEST_F(LibHidlTest, MultiDimStdArrayTest) {
356    using android::hardware::hidl_array;
357    hidl_array<int32_t, 2, 3> array;
358    for (size_t i = 0; i < 2; i++) {
359        for (size_t j = 0; j < 3; j++) {
360            array[i][j] = i + j + i * j;
361        }
362    }
363    std::array<std::array<int32_t, 3>, 2> stdArray = array;
364    EXPECT_2DARRAYEQ(array, stdArray, 2, 3);
365    hidl_array<int32_t, 2, 3> array2 = stdArray;
366    EXPECT_2DARRAYEQ(array, array2, 2, 3);
367}
368
369TEST_F(LibHidlTest, HidlVersionTest) {
370    using android::hardware::hidl_version;
371    hidl_version v1_0{1, 0};
372    EXPECT_EQ(1, v1_0.get_major());
373    EXPECT_EQ(0, v1_0.get_minor());
374    hidl_version v2_0{2, 0};
375    hidl_version v2_1{2, 1};
376    hidl_version v2_2{2, 2};
377    hidl_version v3_0{3, 0};
378    hidl_version v3_0b{3,0};
379
380    EXPECT_TRUE(v1_0 < v2_0);
381    EXPECT_TRUE(v2_0 < v2_1);
382    EXPECT_TRUE(v2_1 < v3_0);
383    EXPECT_TRUE(v2_0 > v1_0);
384    EXPECT_TRUE(v2_1 > v2_0);
385    EXPECT_TRUE(v3_0 > v2_1);
386    EXPECT_TRUE(v3_0 == v3_0b);
387    EXPECT_TRUE(v3_0 <= v3_0b);
388    EXPECT_TRUE(v2_2 <= v3_0);
389    EXPECT_TRUE(v3_0 >= v3_0b);
390    EXPECT_TRUE(v3_0 >= v2_2);
391}
392
393TEST_F(LibHidlTest, ReturnMoveTest) {
394    using namespace ::android;
395    using ::android::hardware::Return;
396    using ::android::hardware::Status;
397    Return<void> ret{Status::fromStatusT(DEAD_OBJECT)};
398    ret.isOk();
399    ret = {Status::fromStatusT(DEAD_OBJECT)};
400    ret.isOk();
401}
402
403TEST_F(LibHidlTest, ReturnTest) {
404    using ::android::DEAD_OBJECT;
405    using ::android::hardware::Return;
406    using ::android::hardware::Status;
407    using ::android::hardware::hidl_string;
408
409    EXPECT_FALSE(Return<void>(Status::fromStatusT(DEAD_OBJECT)).isOk());
410    EXPECT_TRUE(Return<void>(Status::ok()).isOk());
411
412    hidl_string one = "1";
413    hidl_string two = "2";
414    Return<hidl_string> ret = Return<hidl_string>(Status::fromStatusT(DEAD_OBJECT));
415
416    EXPECT_EQ(one, Return<hidl_string>(one).withDefault(two));
417    EXPECT_EQ(two, ret.withDefault(two));
418
419    hidl_string&& moved = ret.withDefault(std::move(two));
420    EXPECT_EQ("2", moved);
421
422    const hidl_string three = "3";
423    EXPECT_EQ(three, ret.withDefault(three));
424}
425
426std::string toString(const ::android::hardware::Status &s) {
427    using ::android::hardware::operator<<;
428    std::ostringstream oss;
429    oss << s;
430    return oss.str();
431}
432
433TEST_F(LibHidlTest, StatusStringTest) {
434    using namespace ::android;
435    using ::android::hardware::Status;
436    using ::testing::HasSubstr;
437
438    EXPECT_EQ(toString(Status::ok()), "No error");
439
440    EXPECT_THAT(toString(Status::fromStatusT(DEAD_OBJECT)), HasSubstr("DEAD_OBJECT"));
441
442    EXPECT_THAT(toString(Status::fromStatusT(-EBUSY)), HasSubstr("busy"));
443
444    EXPECT_THAT(toString(Status::fromExceptionCode(Status::EX_NULL_POINTER)),
445            HasSubstr("EX_NULL_POINTER"));
446
447}
448
449int main(int argc, char **argv) {
450    ::testing::InitGoogleTest(&argc, argv);
451    return RUN_ALL_TESTS();
452}
453