diff options
author | Vicent Martà <tanoku@gmail.com> | 2011-06-06 18:24:37 -0700 |
---|---|---|
committer | Vicent Martà <tanoku@gmail.com> | 2011-06-06 18:24:37 -0700 |
commit | 2c9e7fa35e915bc0cb71fe93f9424f3bc5f1b78a (patch) | |
tree | 8edae1d82fe9fe6568dfcd013a7c03881010963d /tests/t10-refs.c | |
parent | 64fe8c62f90c6d887b2787f47ff815c2485e04d2 (diff) | |
parent | 76b15cb18a0c153639bf156482e0a0ad57c0c8c8 (diff) | |
download | libgit2-2c9e7fa35e915bc0cb71fe93f9424f3bc5f1b78a.tar.gz |
Merge pull request #232 from schu/ref-available-cb
reference_rename: respect all references v2
Diffstat (limited to 'tests/t10-refs.c')
-rw-r--r-- | tests/t10-refs.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/tests/t10-refs.c b/tests/t10-refs.c index 3e7b07930..33d284099 100644 --- a/tests/t10-refs.c +++ b/tests/t10-refs.c @@ -654,6 +654,38 @@ BEGIN_TEST(rename5, "can force-rename a reference with the name of an existing r close_temp_repo(repo); END_TEST +static const char *ref_one_name = "refs/heads/one/branch"; +static const char *ref_one_name_new = "refs/heads/two/branch"; +static const char *ref_two_name = "refs/heads/two"; + +BEGIN_TEST(rename6, "can not overwrite name of existing reference") + git_reference *ref, *ref_one, *ref_one_new, *ref_two; + git_repository *repo; + git_oid id; + + must_pass(open_temp_repo(&repo, REPOSITORY_FOLDER)); + + must_pass(git_reference_lookup(&ref, repo, ref_master_name)); + must_be_true(ref->type & GIT_REF_OID); + + git_oid_cpy(&id, git_reference_oid(ref)); + + /* Create loose references */ + must_pass(git_reference_create_oid(&ref_one, repo, ref_one_name, &id)); + must_pass(git_reference_create_oid(&ref_two, repo, ref_two_name, &id)); + + /* Pack everything */ + must_pass(git_reference_packall(repo)); + + /* Attempt to create illegal reference */ + must_fail(git_reference_create_oid(&ref_one_new, repo, ref_one_name_new, &id)); + + /* Illegal reference couldn't be created so this is supposed to fail */ + must_fail(git_reference_lookup(&ref_one_new, repo, ref_one_name_new)); + + close_temp_repo(repo); +END_TEST + BEGIN_TEST(delete0, "deleting a ref which is both packed and loose should remove both tracks in the filesystem") git_reference *looked_up_ref, *another_looked_up_ref; git_repository *repo; @@ -950,6 +982,7 @@ BEGIN_SUITE(refs) ADD_TEST(rename3); ADD_TEST(rename4); ADD_TEST(rename5); + ADD_TEST(rename6); ADD_TEST(delete0); ADD_TEST(list0); |