Commit 26b71d60 by Patrick Steinhardt

tests: iterator: fix iterator expecting too few items

The testcase iterator::workdir::filesystem_gunk sets up quite a lot of
directories, which is why it only runs in case GITTEST_INVASIVE_SPEED is
set in the environment. Because we do not run our default CI with this
variable, we didn't notice commit 852c83ee (refs: refuse to delete
HEAD, 2020-01-15) breaking the test as it introduced a new reference to
the "testrepo" repository.

Fix the oversight by increasing the number of expected iterator items.
parent 03ac24b1
...@@ -637,13 +637,14 @@ void test_iterator_workdir__filesystem2(void) ...@@ -637,13 +637,14 @@ void test_iterator_workdir__filesystem2(void)
git_iterator_free(i); git_iterator_free(i);
} }
/* Lots of empty dirs, or nearly empty ones, make the old workdir /*
* Lots of empty dirs, or nearly empty ones, make the old workdir
* iterator cry. Also, segfault. * iterator cry. Also, segfault.
*/ */
void test_iterator_workdir__filesystem_gunk(void) void test_iterator_workdir__filesystem_gunk(void)
{ {
git_iterator *i;
git_buf parent = GIT_BUF_INIT; git_buf parent = GIT_BUF_INIT;
git_iterator *i;
int n; int n;
if (!cl_is_env_set("GITTEST_INVASIVE_SPEED")) if (!cl_is_env_set("GITTEST_INVASIVE_SPEED"))
...@@ -653,19 +654,18 @@ void test_iterator_workdir__filesystem_gunk(void) ...@@ -653,19 +654,18 @@ void test_iterator_workdir__filesystem_gunk(void)
for (n = 0; n < 100000; n++) { for (n = 0; n < 100000; n++) {
git_buf_clear(&parent); git_buf_clear(&parent);
git_buf_printf(&parent, "%s/refs/heads/foo/%d/subdir", cl_git_pass(git_buf_printf(&parent, "%s/refs/heads/foo/%d/subdir", git_repository_path(g_repo), n));
git_repository_path(g_repo), n);
cl_assert(!git_buf_oom(&parent));
cl_git_pass(git_futils_mkdir(parent.ptr, 0775, GIT_MKDIR_PATH)); cl_git_pass(git_futils_mkdir(parent.ptr, 0775, GIT_MKDIR_PATH));
} }
cl_git_pass(git_iterator_for_filesystem(&i, "testrepo/.git/refs", NULL)); cl_git_pass(git_iterator_for_filesystem(&i, "testrepo/.git/refs", NULL));
/* should only have 16 items, since we're not asking for trees to be /*
* Should only have 17 items, since we're not asking for trees to be
* returned. the goal of this test is simply to not crash. * returned. the goal of this test is simply to not crash.
*/ */
expect_iterator_items(i, 16, NULL, 15, NULL); expect_iterator_items(i, 17, NULL, 16, NULL);
git_iterator_free(i); git_iterator_free(i);
git_buf_dispose(&parent); git_buf_dispose(&parent);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment