aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/src/main.c1
-rw-r--r--test/src/runner/test_runner_vec.c7
-rw-r--r--test/src/vec/test_ft_vecremove.c64
3 files changed, 71 insertions, 1 deletions
diff --git a/test/src/main.c b/test/src/main.c
index 83e8d5f..8884f81 100644
--- a/test/src/main.c
+++ b/test/src/main.c
@@ -76,6 +76,7 @@ static void run_all_test(void)
RUN_TEST_GROUP(ft_vecnew);
RUN_TEST_GROUP(ft_vecpop);
RUN_TEST_GROUP(ft_vecpush);
+ RUN_TEST_GROUP(ft_vecremove);
}
int main(int argc, const char **argv)
diff --git a/test/src/runner/test_runner_vec.c b/test/src/runner/test_runner_vec.c
index af91360..e0d3008 100644
--- a/test/src/runner/test_runner_vec.c
+++ b/test/src/runner/test_runner_vec.c
@@ -6,7 +6,7 @@
/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/04/01 19:55:53 by charles #+# #+# */
-/* Updated: 2020/04/01 19:58:25 by charles ### ########.fr */
+/* Updated: 2020/04/01 22:49:28 by charles ### ########.fr */
/* */
/* ************************************************************************** */
@@ -43,3 +43,8 @@ TEST_GROUP_RUNNER(ft_vecpush)
RUN_TEST_CASE(ft_vecpush, basic);
}
+TEST_GROUP_RUNNER(ft_vecremove)
+{
+ RUN_TEST_CASE(ft_vecremove, basic);
+}
+
diff --git a/test/src/vec/test_ft_vecremove.c b/test/src/vec/test_ft_vecremove.c
new file mode 100644
index 0000000..8cecc19
--- /dev/null
+++ b/test/src/vec/test_ft_vecremove.c
@@ -0,0 +1,64 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* test_ft_vecremove.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/04/01 22:48:58 by charles #+# #+# */
+/* Updated: 2020/04/01 22:56:37 by charles ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "libft_test.h"
+
+TEST_GROUP(ft_vecremove);
+
+TEST_SETUP(ft_vecremove)
+{}
+
+TEST_TEAR_DOWN(ft_vecremove)
+{}
+
+TEST(ft_vecremove, basic)
+{
+ t_ftvec *vec;
+
+ vec = ft_vecnew(4);
+ for (size_t i = 0; i < 4; i++)
+ vec->data[i] = (void*)(i + 1);
+ vec->size = 4;
+
+ ft_vecremove(vec, 0, NULL);
+ TEST_ASSERT_EQUAL(3, vec->size);
+ TEST_ASSERT_EQUAL(4, vec->capacity);
+ TEST_ASSERT_EQUAL_UINT64(2, (size_t)vec->data[0]);
+ TEST_ASSERT_EQUAL_UINT64(3, (size_t)vec->data[1]);
+ TEST_ASSERT_EQUAL_UINT64(4, (size_t)vec->data[2]);
+
+ ft_vecremove(vec, 1, NULL);
+ TEST_ASSERT_EQUAL(2, vec->size);
+ TEST_ASSERT_EQUAL(4, vec->capacity);
+ TEST_ASSERT_EQUAL_UINT64(2, (size_t)vec->data[0]);
+ TEST_ASSERT_EQUAL_UINT64(4, (size_t)vec->data[1]);
+
+ ft_vecremove(vec, 1, NULL);
+ TEST_ASSERT_EQUAL(1, vec->size);
+ TEST_ASSERT_EQUAL(4, vec->capacity);
+ TEST_ASSERT_EQUAL_UINT64(2, (size_t)vec->data[0]);
+
+ ft_vecremove(vec, 1, NULL);
+ TEST_ASSERT_EQUAL(1, vec->size);
+ TEST_ASSERT_EQUAL(4, vec->capacity);
+ TEST_ASSERT_EQUAL_UINT64(2, (size_t)vec->data[0]);
+
+ ft_vecremove(vec, 0, NULL);
+ TEST_ASSERT_EQUAL(0, vec->size);
+ TEST_ASSERT_EQUAL(4, vec->capacity);
+
+ ft_vecremove(vec, 0, NULL);
+ TEST_ASSERT_EQUAL(0, vec->size);
+ TEST_ASSERT_EQUAL(4, vec->capacity);
+
+ ft_vecdestroy(vec, NULL);
+}