diff options
| author | David Calavera <david.calavera@gmail.com> | 2014-11-13 11:26:02 -0800 |
|---|---|---|
| committer | Carlos MartÃn Nieto <cmn@dwim.me> | 2014-12-14 17:04:02 +0100 |
| commit | 5e0c3d2d1a57f0a3764bdb1dc0ddb07e96f4b127 (patch) | |
| tree | 32fbe79ffde1c62a45f17ebbe43dbf4a2755d7f8 /tests/network | |
| parent | b91194e8426899980b9af5be42c48ba0d89eff96 (diff) | |
| download | libgit2-5e0c3d2d1a57f0a3764bdb1dc0ddb07e96f4b127.tar.gz | |
Make sure that `fetch --prune --tags` doesn't remove tags.
Diffstat (limited to 'tests/network')
| -rw-r--r-- | tests/network/fetchlocal.c | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/tests/network/fetchlocal.c b/tests/network/fetchlocal.c index 1996a7078..49a14db29 100644 --- a/tests/network/fetchlocal.c +++ b/tests/network/fetchlocal.c @@ -4,6 +4,10 @@ #include "path.h" #include "remote.h" +static const char* tagger_name = "Vicent Marti"; +static const char* tagger_email = "vicent@github.com"; +static const char* tagger_message = "This is my tag.\n\nThere are many tags, but this one is mine\n"; + static int transfer_cb(const git_transfer_progress *stats, void *payload) { int *callcount = (int*)payload; @@ -238,6 +242,61 @@ void test_network_fetchlocal__fetchprune(void) git_repository_free(repo); } +void test_network_fetchlocal__prune_tag(void) +{ + git_repository *repo; + git_remote *origin; + int callcount = 0; + git_reference *ref; + git_config *config; + git_oid tag_id; + git_signature *tagger; + git_object *obj; + + git_repository *remote_repo = cl_git_sandbox_init("testrepo.git"); + const char *url = cl_git_path_url(git_repository_path(remote_repo)); + git_remote_callbacks callbacks = GIT_REMOTE_CALLBACKS_INIT; + + callbacks.transfer_progress = transfer_cb; + callbacks.payload = &callcount; + + cl_set_cleanup(&cleanup_local_repo, "foo"); + cl_git_pass(git_repository_init(&repo, "foo", true)); + + cl_git_pass(git_remote_create(&origin, repo, GIT_REMOTE_ORIGIN, url)); + git_remote_set_callbacks(origin, &callbacks); + cl_git_pass(git_remote_fetch(origin, NULL, NULL, NULL)); + + cl_git_pass(git_revparse_single(&obj, repo, "origin/master")); + + cl_git_pass(git_reference_create(&ref, repo, "refs/remotes/origin/fake-remote", git_object_id(obj), 1, NULL, NULL)); + + /* create signature */ + cl_git_pass(git_signature_new(&tagger, tagger_name, tagger_email, 123456789, 60)); + + cl_git_pass( + git_tag_create(&tag_id, repo, + "some-tag", obj, tagger, tagger_message, 0) + ); + + cl_git_pass(git_repository_config(&config, repo)); + cl_git_pass(git_config_set_bool(config, "remote.origin.prune", 1)); + git_config_free(config); + cl_git_pass(git_remote_lookup(&origin, repo, GIT_REMOTE_ORIGIN)); + cl_assert_equal_i(1, git_remote_prune_refs(origin)); + git_remote_set_callbacks(origin, &callbacks); + cl_git_pass(git_remote_fetch(origin, NULL, NULL, NULL)); + + cl_git_pass(git_revparse_single(&obj, repo, "some-tag")); + cl_git_fail(git_revparse_single(&obj, repo, "refs/remotes/origin/fake-remote")); + + git_object_free(obj); + git_remote_free(origin); + + git_repository_free(remote_repo); + git_repository_free(repo); +} + static void cleanup_sandbox(void *unused) { GIT_UNUSED(unused); |
