aboutsummaryrefslogtreecommitdiff
path: root/test/src/algo/test_ft_lfind.c
diff options
context:
space:
mode:
authorCharles <sircharlesaze@gmail.com>2020-02-13 23:15:16 +0100
committerCharles <sircharlesaze@gmail.com>2020-02-13 23:15:16 +0100
commitadbcf69ed50ea3896d4bbe863ea5d214ae5a0299 (patch)
tree4865b665e44711b7675c78a4152985ea451eca79 /test/src/algo/test_ft_lfind.c
parent7d626e7e9638d7e85c3dacce8a4aee009850a1a2 (diff)
downloadlibft-adbcf69ed50ea3896d4bbe863ea5d214ae5a0299.tar.gz
libft-adbcf69ed50ea3896d4bbe863ea5d214ae5a0299.tar.bz2
libft-adbcf69ed50ea3896d4bbe863ea5d214ae5a0299.zip
Added tests for algo*, fixing ft_bsearch and ft_mergesort
Diffstat (limited to 'test/src/algo/test_ft_lfind.c')
-rw-r--r--test/src/algo/test_ft_lfind.c38
1 files changed, 38 insertions, 0 deletions
diff --git a/test/src/algo/test_ft_lfind.c b/test/src/algo/test_ft_lfind.c
new file mode 100644
index 0000000..0080d55
--- /dev/null
+++ b/test/src/algo/test_ft_lfind.c
@@ -0,0 +1,38 @@
+#include "libft_test.h"
+
+TEST_GROUP(ft_lfind);
+
+TEST_SETUP(ft_lfind)
+{}
+
+TEST_TEAR_DOWN(ft_lfind)
+{}
+
+TEST(ft_lfind, basic)
+{
+ int arr[] = {3, 4, 1, 2, 7, 189, -1, -134, 7, 1, 34};
+ t_ftsearch_const consts;
+
+ int a = 189;
+ consts.key = &a;
+ consts.compar = ft_compar_int;
+
+ size_t nelp = sizeof(arr) / sizeof(int);
+ void *ptr = ft_lfind(arr, &nelp, sizeof(int), &consts);
+ TEST_ASSERT_EQUAL_PTR(arr + 5, ptr);
+
+ int b = 123;
+ consts.key = &b;
+ ptr = ft_lfind(arr, &nelp, sizeof(int), &consts);
+ TEST_ASSERT_NULL(ptr);
+
+ int c = 34;
+ consts.key = &c;
+ ptr = ft_lfind(arr, &nelp, sizeof(int), &consts);
+ TEST_ASSERT_EQUAL_PTR(arr + 10, ptr);
+
+ int d = 3;
+ consts.key = &d;
+ ptr = ft_lfind(arr, &nelp, sizeof(int), &consts);
+ TEST_ASSERT_EQUAL_PTR(arr, ptr);
+}