diff options
| author | nulltoken <emeric.fermas@gmail.com> | 2012-07-15 11:06:15 +0200 | 
|---|---|---|
| committer | nulltoken <emeric.fermas@gmail.com> | 2012-07-17 20:32:40 +0200 | 
| commit | db9be9457d74a683916f107b39cad05a347b4c2c (patch) | |
| tree | e315b7dd7b7c629c8a651a588ea8aec9543ed3bb /tests-clar/object/peel.c | |
| parent | b8748c1217445a95d3b29b361b467eb66992f8a7 (diff) | |
| download | libgit2-db9be9457d74a683916f107b39cad05a347b4c2c.tar.gz | |
object: introduce git_object_peel()
Partially fix #530
Diffstat (limited to 'tests-clar/object/peel.c')
| -rw-r--r-- | tests-clar/object/peel.c | 79 | 
1 files changed, 79 insertions, 0 deletions
diff --git a/tests-clar/object/peel.c b/tests-clar/object/peel.c new file mode 100644 index 000000000..f6d2a776f --- /dev/null +++ b/tests-clar/object/peel.c @@ -0,0 +1,79 @@ +#include "clar_libgit2.h" + +static git_repository *g_repo; + +void test_object_peel__initialize(void) +{ +	cl_git_pass(git_repository_open(&g_repo, cl_fixture("testrepo.git"))); +} + +void test_object_peel__cleanup(void) +{ +	git_repository_free(g_repo); +} + +static void assert_peel(const char* expected_sha, const char *sha, git_otype requested_type) +{ +	git_oid oid, expected_oid; +	git_object *obj; +	git_object *peeled; + +	cl_git_pass(git_oid_fromstr(&oid, sha)); +	cl_git_pass(git_object_lookup(&obj, g_repo, &oid, GIT_OBJ_ANY)); +	 +	cl_git_pass(git_object_peel(&peeled, obj, requested_type)); + +	cl_git_pass(git_oid_fromstr(&expected_oid, expected_sha)); +	cl_assert_equal_i(0, git_oid_cmp(&expected_oid, git_object_id(peeled))); + +	git_object_free(peeled); +	git_object_free(obj); +} + +static void assert_peel_error(int error, const char *sha, git_otype requested_type) +{ +	git_oid oid; +	git_object *obj; +	git_object *peeled; + +	cl_git_pass(git_oid_fromstr(&oid, sha)); +	cl_git_pass(git_object_lookup(&obj, g_repo, &oid, GIT_OBJ_ANY)); +	 +	cl_assert_equal_i(error, git_object_peel(&peeled, obj, requested_type)); + +	git_object_free(obj); +} + +void test_object_peel__peeling_an_object_into_its_own_type_returns_another_instance_of_it(void) +{ +	assert_peel("e90810b8df3e80c413d903f631643c716887138d", "e90810b8df3e80c413d903f631643c716887138d", GIT_OBJ_COMMIT); +	assert_peel("7b4384978d2493e851f9cca7858815fac9b10980", "7b4384978d2493e851f9cca7858815fac9b10980", GIT_OBJ_TAG); +	assert_peel("53fc32d17276939fc79ed05badaef2db09990016", "53fc32d17276939fc79ed05badaef2db09990016", GIT_OBJ_TREE); +	assert_peel("0266163a49e280c4f5ed1e08facd36a2bd716bcf", "0266163a49e280c4f5ed1e08facd36a2bd716bcf", GIT_OBJ_BLOB); +} + +void test_object_peel__can_peel_a_tag(void) +{ +	assert_peel("e90810b8df3e80c413d903f631643c716887138d", "7b4384978d2493e851f9cca7858815fac9b10980", GIT_OBJ_COMMIT); +	assert_peel("53fc32d17276939fc79ed05badaef2db09990016", "7b4384978d2493e851f9cca7858815fac9b10980", GIT_OBJ_TREE); +} + +void test_object_peel__can_peel_a_commit(void) +{ +	assert_peel("53fc32d17276939fc79ed05badaef2db09990016", "e90810b8df3e80c413d903f631643c716887138d", GIT_OBJ_TREE); +} + +void test_object_peel__cannot_peel_a_tree(void) +{ +	assert_peel_error(GIT_EAMBIGUOUS, "53fc32d17276939fc79ed05badaef2db09990016", GIT_OBJ_BLOB); +} + +void test_object_peel__cannot_peel_a_blob(void) +{ +	assert_peel_error(GIT_ERROR, "0266163a49e280c4f5ed1e08facd36a2bd716bcf", GIT_OBJ_COMMIT); +} + +void test_object_peel__cannot_target_any_object(void) +{ +	assert_peel_error(GIT_EAMBIGUOUS, "e90810b8df3e80c413d903f631643c716887138d", GIT_OBJ_ANY); +}  | 
