1*71db0c75SAndroid Build Coastguard Worker //===-- Unittests for lfind -----------------------------------------------===//
2*71db0c75SAndroid Build Coastguard Worker //
3*71db0c75SAndroid Build Coastguard Worker // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*71db0c75SAndroid Build Coastguard Worker // See https://llvm.org/LICENSE.txt for license information.
5*71db0c75SAndroid Build Coastguard Worker // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*71db0c75SAndroid Build Coastguard Worker //
7*71db0c75SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
8*71db0c75SAndroid Build Coastguard Worker
9*71db0c75SAndroid Build Coastguard Worker #include "src/search/lfind.h"
10*71db0c75SAndroid Build Coastguard Worker #include "test/UnitTest/Test.h"
11*71db0c75SAndroid Build Coastguard Worker
compar(const void * a,const void * b)12*71db0c75SAndroid Build Coastguard Worker int compar(const void *a, const void *b) {
13*71db0c75SAndroid Build Coastguard Worker return *reinterpret_cast<const int *>(a) != *reinterpret_cast<const int *>(b);
14*71db0c75SAndroid Build Coastguard Worker }
15*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcLfindTest,SearchHead)16*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcLfindTest, SearchHead) {
17*71db0c75SAndroid Build Coastguard Worker int list[3] = {1, 2, 3};
18*71db0c75SAndroid Build Coastguard Worker size_t len = 3;
19*71db0c75SAndroid Build Coastguard Worker int key = 1;
20*71db0c75SAndroid Build Coastguard Worker void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
21*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(ret == &list[0]);
22*71db0c75SAndroid Build Coastguard Worker }
23*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcLfindTest,SearchMiddle)24*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcLfindTest, SearchMiddle) {
25*71db0c75SAndroid Build Coastguard Worker int list[3] = {1, 2, 3};
26*71db0c75SAndroid Build Coastguard Worker size_t len = 3;
27*71db0c75SAndroid Build Coastguard Worker int key = 2;
28*71db0c75SAndroid Build Coastguard Worker void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
29*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(ret == &list[1]);
30*71db0c75SAndroid Build Coastguard Worker }
31*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcLfindTest,SearchTail)32*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcLfindTest, SearchTail) {
33*71db0c75SAndroid Build Coastguard Worker int list[3] = {1, 2, 3};
34*71db0c75SAndroid Build Coastguard Worker size_t len = 3;
35*71db0c75SAndroid Build Coastguard Worker int key = 3;
36*71db0c75SAndroid Build Coastguard Worker void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
37*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(ret == &list[2]);
38*71db0c75SAndroid Build Coastguard Worker }
39*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcLfindTest,SearchNonExistent)40*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcLfindTest, SearchNonExistent) {
41*71db0c75SAndroid Build Coastguard Worker int list[3] = {1, 2, 3};
42*71db0c75SAndroid Build Coastguard Worker size_t len = 3;
43*71db0c75SAndroid Build Coastguard Worker int key = 5;
44*71db0c75SAndroid Build Coastguard Worker void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
45*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(ret == nullptr);
46*71db0c75SAndroid Build Coastguard Worker }
47