diff options
author | Edward Thomson <ethomson@edwardthomson.com> | 2015-04-23 17:54:08 +0300 |
---|---|---|
committer | Edward Thomson <ethomson@edwardthomson.com> | 2015-04-23 17:54:08 +0300 |
commit | 27fa7477b008bff27c5aaecb1b2b908540a5798a (patch) | |
tree | 2e99d688a25f8c11db89323b3f2174495019e848 /tests/checkout | |
parent | f564017d964e97c067baf98d2a332873bb641ffc (diff) | |
parent | d3282680ed3c2311aad0f3b9bd256255bbc09ce2 (diff) |
Merge pull request #3032 from jfultz/index-file-modes
Fix git_checkout_tree() to do index filemodes correctly on Windows.
Diffstat (limited to 'tests/checkout')
-rw-r--r-- | tests/checkout/tree.c | 29 |
1 files changed, 27 insertions, 2 deletions
diff --git a/tests/checkout/tree.c b/tests/checkout/tree.c index 7d4c784a1..3973d9320 100644 --- a/tests/checkout/tree.c +++ b/tests/checkout/tree.c @@ -925,18 +925,43 @@ void test_checkout_tree__filemode_preserved_in_index(void) git_index *index; const git_index_entry *entry; + opts.checkout_strategy = GIT_CHECKOUT_FORCE; + cl_git_pass(git_repository_index(&index, g_repo)); + /* test a freshly added executable */ cl_git_pass(git_oid_fromstr(&executable_oid, "afe4393b2b2a965f06acf2ca9658eaa01e0cd6b6")); cl_git_pass(git_commit_lookup(&commit, g_repo, &executable_oid)); - opts.checkout_strategy = GIT_CHECKOUT_FORCE; - cl_git_pass(git_checkout_tree(g_repo, (const git_object *)commit, &opts)); cl_assert(entry = git_index_get_bypath(index, "executable.txt", 0)); cl_assert_equal_i(0100755, entry->mode); git_commit_free(commit); + + + /* Now start with a commit which has a text file */ + cl_git_pass(git_oid_fromstr(&executable_oid, "cf80f8de9f1185bf3a05f993f6121880dd0cfbc9")); + cl_git_pass(git_commit_lookup(&commit, g_repo, &executable_oid)); + + cl_git_pass(git_checkout_tree(g_repo, (const git_object *)commit, &opts)); + cl_assert(entry = git_index_get_bypath(index, "a/b.txt", 0)); + cl_assert_equal_i(0100644, entry->mode); + + git_commit_free(commit); + + + /* And then check out to a commit which converts the text file to an executable */ + cl_git_pass(git_oid_fromstr(&executable_oid, "144344043ba4d4a405da03de3844aa829ae8be0e")); + cl_git_pass(git_commit_lookup(&commit, g_repo, &executable_oid)); + + cl_git_pass(git_checkout_tree(g_repo, (const git_object *)commit, &opts)); + cl_assert(entry = git_index_get_bypath(index, "a/b.txt", 0)); + cl_assert_equal_i(0100755, entry->mode); + + git_commit_free(commit); + + git_index_free(index); } |