diff --git a/test/test_arraylist.c b/test/test_arraylist.c index 0ef6a15..ad9997f 100644 --- a/test/test_arraylist.c +++ b/test/test_arraylist.c @@ -1651,6 +1651,45 @@ static void test_slice_next_until_invalid(void **state) { arraylist_destroy(&arr); } +//Slice reset +static void test_slice_reset_valid_slice(void **state) { + (void) state; + + ArrayList *arr = arraylist_init(64, sizeof(int)); + assert_non_null(arr); + + for (int i = 0; i < 10; i++) { + assert_uint_equal(arraylist_push_back(arr, &i), ARRLIST_OK); + } + + ArraySlice *slice = arraylist_slice(arr, 0, arraylist_size(arr)); + assert_non_null(slice); + + int m; + for (int i = 0; i < 10; i++) { + assert_uint_equal(arrayslice_next(slice, &m), ARRLIST_OK); + assert_uint_equal(m, i); + } + + assert_uint_equal(arrayslice_reset(slice), ARRLIST_OK); + + for (int i = 0; i < 10; i++) { + assert_uint_equal(arrayslice_next(slice, &m), ARRLIST_OK); + assert_uint_equal(m, i); + } + + arrayslice_destroy(&slice); + arraylist_destroy(&arr); +} + +static void test_slice_reset_null_slice(void **state) { + (void) state; + + ArraySlice *slice = NULL; + + assert_uint_equal(arrayslice_reset(slice), ARRLIST_NULL_ARG); +} + int main(void) { const struct CMUnitTest init[] = { cmocka_unit_test(test_init_valid_parameters), @@ -1813,6 +1852,11 @@ int main(void) { cmocka_unit_test(test_slice_next_until_invalid), }; + const struct CMUnitTest slice_reset[] = { + cmocka_unit_test(test_slice_reset_valid_slice), + cmocka_unit_test(test_slice_reset_null_slice), + }; + int rc = 0; rc += cmocka_run_group_tests(init, NULL, NULL); @@ -1835,6 +1879,7 @@ int main(void) { rc += cmocka_run_group_tests(slice_destroy, NULL, NULL); rc += cmocka_run_group_tests(slice_peek, NULL, NULL); rc += cmocka_run_group_tests(slice_next, NULL, NULL); + rc += cmocka_run_group_tests(slice_reset, NULL, NULL); return rc; }