1*71db0c75SAndroid Build Coastguard Worker //===-- Unittests for bsearch ---------------------------------------------===//
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/stdlib/bsearch.h"
10*71db0c75SAndroid Build Coastguard Worker
11*71db0c75SAndroid Build Coastguard Worker #include "test/UnitTest/Test.h"
12*71db0c75SAndroid Build Coastguard Worker
13*71db0c75SAndroid Build Coastguard Worker #include "hdr/types/size_t.h"
14*71db0c75SAndroid Build Coastguard Worker
int_compare(const void * l,const void * r)15*71db0c75SAndroid Build Coastguard Worker static int int_compare(const void *l, const void *r) {
16*71db0c75SAndroid Build Coastguard Worker int li = *reinterpret_cast<const int *>(l);
17*71db0c75SAndroid Build Coastguard Worker int ri = *reinterpret_cast<const int *>(r);
18*71db0c75SAndroid Build Coastguard Worker if (li == ri)
19*71db0c75SAndroid Build Coastguard Worker return 0;
20*71db0c75SAndroid Build Coastguard Worker else if (li > ri)
21*71db0c75SAndroid Build Coastguard Worker return 1;
22*71db0c75SAndroid Build Coastguard Worker else
23*71db0c75SAndroid Build Coastguard Worker return -1;
24*71db0c75SAndroid Build Coastguard Worker }
25*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcBsearchTest,ErrorInputs)26*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcBsearchTest, ErrorInputs) {
27*71db0c75SAndroid Build Coastguard Worker int val = 123;
28*71db0c75SAndroid Build Coastguard Worker EXPECT_TRUE(LIBC_NAMESPACE::bsearch(nullptr, &val, 1, sizeof(int),
29*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
30*71db0c75SAndroid Build Coastguard Worker EXPECT_TRUE(LIBC_NAMESPACE::bsearch(&val, nullptr, 1, sizeof(int),
31*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
32*71db0c75SAndroid Build Coastguard Worker EXPECT_TRUE(LIBC_NAMESPACE::bsearch(&val, &val, 0, sizeof(int),
33*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
34*71db0c75SAndroid Build Coastguard Worker EXPECT_TRUE(LIBC_NAMESPACE::bsearch(&val, &val, 1, 0, int_compare) ==
35*71db0c75SAndroid Build Coastguard Worker nullptr);
36*71db0c75SAndroid Build Coastguard Worker }
37*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcBsearchTest,IntegerArray)38*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcBsearchTest, IntegerArray) {
39*71db0c75SAndroid Build Coastguard Worker constexpr int ARRAY[25] = {10, 23, 33, 35, 55, 70, 71,
40*71db0c75SAndroid Build Coastguard Worker 100, 110, 123, 133, 135, 155, 170,
41*71db0c75SAndroid Build Coastguard Worker 171, 1100, 1110, 1123, 1133, 1135, 1155,
42*71db0c75SAndroid Build Coastguard Worker 1170, 1171, 11100, 12310};
43*71db0c75SAndroid Build Coastguard Worker constexpr size_t ARRAY_SIZE = sizeof(ARRAY) / sizeof(int);
44*71db0c75SAndroid Build Coastguard Worker
45*71db0c75SAndroid Build Coastguard Worker for (size_t s = 1; s <= ARRAY_SIZE; ++s) {
46*71db0c75SAndroid Build Coastguard Worker for (size_t i = 0; i < s; ++i) {
47*71db0c75SAndroid Build Coastguard Worker int key = ARRAY[i];
48*71db0c75SAndroid Build Coastguard Worker void *elem =
49*71db0c75SAndroid Build Coastguard Worker LIBC_NAMESPACE::bsearch(&key, ARRAY, s, sizeof(int), int_compare);
50*71db0c75SAndroid Build Coastguard Worker ASSERT_EQ(*reinterpret_cast<int *>(elem), key);
51*71db0c75SAndroid Build Coastguard Worker }
52*71db0c75SAndroid Build Coastguard Worker }
53*71db0c75SAndroid Build Coastguard Worker
54*71db0c75SAndroid Build Coastguard Worker // Non existent keys
55*71db0c75SAndroid Build Coastguard Worker for (size_t s = 1; s <= ARRAY_SIZE; ++s) {
56*71db0c75SAndroid Build Coastguard Worker int key = 5;
57*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(LIBC_NAMESPACE::bsearch(&key, &ARRAY, s, sizeof(int),
58*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
59*71db0c75SAndroid Build Coastguard Worker
60*71db0c75SAndroid Build Coastguard Worker key = 125;
61*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(LIBC_NAMESPACE::bsearch(&key, &ARRAY, s, sizeof(int),
62*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
63*71db0c75SAndroid Build Coastguard Worker
64*71db0c75SAndroid Build Coastguard Worker key = 136;
65*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(LIBC_NAMESPACE::bsearch(&key, &ARRAY, s, sizeof(int),
66*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
67*71db0c75SAndroid Build Coastguard Worker key = 12345;
68*71db0c75SAndroid Build Coastguard Worker ASSERT_TRUE(LIBC_NAMESPACE::bsearch(&key, &ARRAY, s, sizeof(int),
69*71db0c75SAndroid Build Coastguard Worker int_compare) == nullptr);
70*71db0c75SAndroid Build Coastguard Worker }
71*71db0c75SAndroid Build Coastguard Worker }
72*71db0c75SAndroid Build Coastguard Worker
TEST(LlvmLibcBsearchTest,SameKeyAndArray)73*71db0c75SAndroid Build Coastguard Worker TEST(LlvmLibcBsearchTest, SameKeyAndArray) {
74*71db0c75SAndroid Build Coastguard Worker constexpr int ARRAY[5] = {1, 2, 3, 4, 5};
75*71db0c75SAndroid Build Coastguard Worker constexpr size_t ARRAY_SIZE = sizeof(ARRAY) / sizeof(int);
76*71db0c75SAndroid Build Coastguard Worker void *elem = LIBC_NAMESPACE::bsearch(ARRAY, ARRAY, ARRAY_SIZE, sizeof(int),
77*71db0c75SAndroid Build Coastguard Worker int_compare);
78*71db0c75SAndroid Build Coastguard Worker EXPECT_EQ(*reinterpret_cast<int *>(elem), ARRAY[0]);
79*71db0c75SAndroid Build Coastguard Worker }
80