blob: 21f810a8a3acc642ed3169595c16f7dc2e43f32c [file] [log] [blame] [edit]
//===-- Unittests for lfind -----------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "src/search/lfind.h"
#include "test/UnitTest/Test.h"
namespace {
int compar(const void *a, const void *b) {
return *reinterpret_cast<const int *>(a) != *reinterpret_cast<const int *>(b);
}
} // namespace
TEST(LlvmLibcLfindTest, SearchHead) {
int list[3] = {1, 2, 3};
size_t len = 3;
int key = 1;
void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
ASSERT_TRUE(ret == &list[0]);
}
TEST(LlvmLibcLfindTest, SearchMiddle) {
int list[3] = {1, 2, 3};
size_t len = 3;
int key = 2;
void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
ASSERT_TRUE(ret == &list[1]);
}
TEST(LlvmLibcLfindTest, SearchTail) {
int list[3] = {1, 2, 3};
size_t len = 3;
int key = 3;
void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
ASSERT_TRUE(ret == &list[2]);
}
TEST(LlvmLibcLfindTest, SearchNonExistent) {
int list[3] = {1, 2, 3};
size_t len = 3;
int key = 5;
void *ret = LIBC_NAMESPACE::lfind(&key, list, &len, sizeof(int), compar);
ASSERT_TRUE(ret == nullptr);
}