Commit eb76e985 by Edward Thomson

apply tests: ensure mode changes occur

Test that a mode change is reflected in the working directory or index.
parent 5c63ce79
...@@ -47,6 +47,11 @@ ...@@ -47,6 +47,11 @@
"+This is a new file!\n" \ "+This is a new file!\n" \
"+Added by a patch.\n" "+Added by a patch.\n"
#define DIFF_EXECUTABLE_FILE \
"diff --git a/beef.txt b/beef.txt\n" \
"old mode 100644\n" \
"new mode 100755\n"
struct iterator_compare_data { struct iterator_compare_data {
struct merge_index_entry *expected; struct merge_index_entry *expected;
size_t cnt; size_t cnt;
......
...@@ -317,3 +317,32 @@ void test_apply_index__can_apply_nonconflicting_file_changes(void) ...@@ -317,3 +317,32 @@ void test_apply_index__can_apply_nonconflicting_file_changes(void)
git_diff_free(diff); git_diff_free(diff);
} }
void test_apply_index__change_mode(void)
{
git_diff *diff;
git_apply_options opts = GIT_APPLY_OPTIONS_INIT;
const char *diff_file = DIFF_EXECUTABLE_FILE;
struct merge_index_entry index_expected[] = {
{ 0100644, "f51658077d85f2264fa179b4d0848268cb3475c3", 0, "asparagus.txt" },
{ 0100755, "68f6182f4c85d39e1309d97c7e456156dc9c0096", 0, "beef.txt" },
{ 0100644, "4b7c5650008b2e747fe1809eeb5a1dde0e80850a", 0, "bouilli.txt" },
{ 0100644, "c4e6cca3ec6ae0148ed231f97257df8c311e015f", 0, "gravy.txt" },
{ 0100644, "68af1fc7407fd9addf1701a87eb1c95c7494c598", 0, "oyster.txt" },
{ 0100644, "94d2c01087f48213bd157222d54edfefd77c9bba", 0, "veal.txt" },
};
size_t index_expected_cnt = sizeof(index_expected) /
sizeof(struct merge_index_entry);
cl_git_pass(git_diff_from_buffer(&diff, diff_file, strlen(diff_file)));
opts.location = GIT_APPLY_LOCATION_INDEX;
cl_git_pass(git_apply(repo, diff, &opts));
validate_apply_index(repo, index_expected, index_expected_cnt);
validate_workdir_unchanged(repo);
git_diff_free(diff);
}
...@@ -277,3 +277,31 @@ void test_apply_workdir__can_apply_nonconflicting_file_changes(void) ...@@ -277,3 +277,31 @@ void test_apply_workdir__can_apply_nonconflicting_file_changes(void)
git_diff_free(diff); git_diff_free(diff);
} }
void test_apply_workdir__change_mode(void)
{
#ifndef GIT_WIN32
git_diff *diff;
const char *diff_file = DIFF_EXECUTABLE_FILE;
struct merge_index_entry workdir_expected[] = {
{ 0100644, "f51658077d85f2264fa179b4d0848268cb3475c3", 0, "asparagus.txt" },
{ 0100755, "68f6182f4c85d39e1309d97c7e456156dc9c0096", 0, "beef.txt" },
{ 0100644, "4b7c5650008b2e747fe1809eeb5a1dde0e80850a", 0, "bouilli.txt" },
{ 0100644, "c4e6cca3ec6ae0148ed231f97257df8c311e015f", 0, "gravy.txt" },
{ 0100644, "68af1fc7407fd9addf1701a87eb1c95c7494c598", 0, "oyster.txt" },
{ 0100644, "94d2c01087f48213bd157222d54edfefd77c9bba", 0, "veal.txt" },
};
size_t workdir_expected_cnt = sizeof(workdir_expected) /
sizeof(struct merge_index_entry);
cl_git_pass(git_diff_from_buffer(&diff, diff_file, strlen(diff_file)));
cl_git_pass(git_apply(repo, diff, NULL));
validate_index_unchanged(repo);
validate_apply_workdir(repo, workdir_expected, workdir_expected_cnt);
git_diff_free(diff);
#endif
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment