summaryrefslogtreecommitdiff
path: root/tests/odb/foreach.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/odb/foreach.c')
-rw-r--r--tests/odb/foreach.c141
1 files changed, 0 insertions, 141 deletions
diff --git a/tests/odb/foreach.c b/tests/odb/foreach.c
deleted file mode 100644
index 02112380b..000000000
--- a/tests/odb/foreach.c
+++ /dev/null
@@ -1,141 +0,0 @@
-#include "clar_libgit2.h"
-#include "odb.h"
-#include "git2/odb_backend.h"
-#include "pack.h"
-#include "buffer.h"
-
-static git_odb *_odb;
-static git_repository *_repo;
-
-void test_odb_foreach__cleanup(void)
-{
- git_odb_free(_odb);
- git_repository_free(_repo);
-
- _odb = NULL;
- _repo = NULL;
-}
-
-static int foreach_cb(const git_oid *oid, void *data)
-{
- int *nobj = data;
- (*nobj)++;
-
- GIT_UNUSED(oid);
-
- return 0;
-}
-
-/*
- * $ git --git-dir tests/resources/testrepo.git count-objects --verbose
- * count: 60
- * size: 240
- * in-pack: 1640
- * packs: 3
- * size-pack: 425
- * prune-packable: 0
- * garbage: 0
- */
-void test_odb_foreach__foreach(void)
-{
- int nobj = 0;
-
- cl_git_pass(git_repository_open(&_repo, cl_fixture("testrepo.git")));
- git_repository_odb(&_odb, _repo);
-
- cl_git_pass(git_odb_foreach(_odb, foreach_cb, &nobj));
- cl_assert_equal_i(60 + 1640, nobj); /* count + in-pack */
-}
-
-void test_odb_foreach__one_pack(void)
-{
- git_odb_backend *backend = NULL;
- int nobj = 0;
-
- cl_git_pass(git_odb_new(&_odb));
- cl_git_pass(git_odb_backend_one_pack(&backend, cl_fixture("testrepo.git/objects/pack/pack-a81e489679b7d3418f9ab594bda8ceb37dd4c695.idx")));
- cl_git_pass(git_odb_add_backend(_odb, backend, 1));
- _repo = NULL;
-
- cl_git_pass(git_odb_foreach(_odb, foreach_cb, &nobj));
- cl_assert(nobj == 1628);
-}
-
-static int foreach_stop_cb(const git_oid *oid, void *data)
-{
- int *nobj = data;
- (*nobj)++;
-
- GIT_UNUSED(oid);
-
- return (*nobj == 1000) ? -321 : 0;
-}
-
-static int foreach_stop_first_cb(const git_oid *oid, void *data)
-{
- int *nobj = data;
- (*nobj)++;
-
- GIT_UNUSED(oid);
-
- return -123;
-}
-
-static int foreach_stop_cb_positive_ret(const git_oid *oid, void *data)
-{
- int *nobj = data;
- (*nobj)++;
-
- GIT_UNUSED(oid);
-
- return (*nobj == 1000) ? 321 : 0;
-}
-
-void test_odb_foreach__interrupt_foreach(void)
-{
- int nobj = 0;
- git_oid id;
-
- cl_git_pass(git_repository_open(&_repo, cl_fixture("testrepo.git")));
- git_repository_odb(&_odb, _repo);
-
- cl_assert_equal_i(-321, git_odb_foreach(_odb, foreach_stop_cb, &nobj));
- cl_assert(nobj == 1000);
-
- nobj = 0;
-
- cl_assert_equal_i(321, git_odb_foreach(_odb, foreach_stop_cb_positive_ret, &nobj));
- cl_assert(nobj == 1000);
-
- git_odb_free(_odb);
- git_repository_free(_repo);
-
- cl_git_pass(git_repository_init(&_repo, "onlyloose.git", true));
- git_repository_odb(&_odb, _repo);
-
- cl_git_pass(git_odb_write(&id, _odb, "", 0, GIT_OBJECT_BLOB));
- cl_assert_equal_i(-123, git_odb_foreach(_odb, foreach_stop_first_cb, &nobj));
-}
-
-void test_odb_foreach__files_in_objects_dir(void)
-{
- git_repository *repo;
- git_odb *odb;
- git_buf buf = GIT_BUF_INIT;
- int nobj = 0;
-
- cl_fixture_sandbox("testrepo.git");
- cl_git_pass(git_repository_open(&repo, "testrepo.git"));
-
- cl_git_pass(git_buf_joinpath(&buf, git_repository_path(repo), "objects/somefile"));
- cl_git_mkfile(buf.ptr, "");
- git_buf_dispose(&buf);
-
- cl_git_pass(git_repository_odb(&odb, repo));
- cl_git_pass(git_odb_foreach(odb, foreach_cb, &nobj));
- cl_assert_equal_i(60 + 1640, nobj); /* count + in-pack */
-
- git_odb_free(odb);
- git_repository_free(repo);
- cl_fixture_cleanup("testrepo.git");
-}