|
|
|
@ -1180,4 +1180,340 @@ test_expect_failure '5d-check: Directory/file/file conflict due to directory ren
@@ -1180,4 +1180,340 @@ test_expect_failure '5d-check: Directory/file/file conflict due to directory ren
|
|
|
|
|
# back to old handling. But, sadly, see testcases 8a and 8b. |
|
|
|
|
########################################################################### |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
########################################################################### |
|
|
|
|
# SECTION 6: Same side of the merge was the one that did the rename |
|
|
|
|
# |
|
|
|
|
# It may sound obvious that you only want to apply implicit directory |
|
|
|
|
# renames to directories if the _other_ side of history did the renaming. |
|
|
|
|
# If you did make an implementation that didn't explicitly enforce this |
|
|
|
|
# rule, the majority of cases that would fall under this section would |
|
|
|
|
# also be solved by following the rules from the above sections. But |
|
|
|
|
# there are still a few that stick out, so this section covers them just |
|
|
|
|
# to make sure we also get them right. |
|
|
|
|
########################################################################### |
|
|
|
|
|
|
|
|
|
# Testcase 6a, Tricky rename/delete |
|
|
|
|
# Commit O: z/{b,c,d} |
|
|
|
|
# Commit A: z/b |
|
|
|
|
# Commit B: y/{b,c}, z/d |
|
|
|
|
# Expected: y/b, CONFLICT(rename/delete, z/c -> y/c vs. NULL) |
|
|
|
|
# Note: We're just checking here that the rename of z/b and z/c to put |
|
|
|
|
# them under y/ doesn't accidentally catch z/d and make it look like |
|
|
|
|
# it is also involved in a rename/delete conflict. |
|
|
|
|
|
|
|
|
|
test_expect_success '6a-setup: Tricky rename/delete' ' |
|
|
|
|
test_create_repo 6a && |
|
|
|
|
( |
|
|
|
|
cd 6a && |
|
|
|
|
|
|
|
|
|
mkdir z && |
|
|
|
|
echo b >z/b && |
|
|
|
|
echo c >z/c && |
|
|
|
|
echo d >z/d && |
|
|
|
|
git add z && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "O" && |
|
|
|
|
|
|
|
|
|
git branch O && |
|
|
|
|
git branch A && |
|
|
|
|
git branch B && |
|
|
|
|
|
|
|
|
|
git checkout A && |
|
|
|
|
git rm z/c && |
|
|
|
|
git rm z/d && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "A" && |
|
|
|
|
|
|
|
|
|
git checkout B && |
|
|
|
|
mkdir y && |
|
|
|
|
git mv z/b y/ && |
|
|
|
|
git mv z/c y/ && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "B" |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_expect_success '6a-check: Tricky rename/delete' ' |
|
|
|
|
( |
|
|
|
|
cd 6a && |
|
|
|
|
|
|
|
|
|
git checkout A^0 && |
|
|
|
|
|
|
|
|
|
test_must_fail git merge -s recursive B^0 >out && |
|
|
|
|
test_i18ngrep "CONFLICT (rename/delete).*z/c.*y/c" out && |
|
|
|
|
|
|
|
|
|
git ls-files -s >out && |
|
|
|
|
test_line_count = 2 out && |
|
|
|
|
git ls-files -u >out && |
|
|
|
|
test_line_count = 1 out && |
|
|
|
|
git ls-files -o >out && |
|
|
|
|
test_line_count = 1 out && |
|
|
|
|
|
|
|
|
|
git rev-parse >actual \ |
|
|
|
|
:0:y/b :3:y/c && |
|
|
|
|
git rev-parse >expect \ |
|
|
|
|
O:z/b O:z/c && |
|
|
|
|
test_cmp expect actual |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
# Testcase 6b, Same rename done on both sides |
|
|
|
|
# (Related to testcases 6c and 8e) |
|
|
|
|
# Commit O: z/{b,c} |
|
|
|
|
# Commit A: y/{b,c} |
|
|
|
|
# Commit B: y/{b,c}, z/d |
|
|
|
|
# Expected: y/{b,c}, z/d |
|
|
|
|
# Note: If we did directory rename detection here, we'd move z/d into y/, |
|
|
|
|
# but B did that rename and still decided to put the file into z/, |
|
|
|
|
# so we probably shouldn't apply directory rename detection for it. |
|
|
|
|
|
|
|
|
|
test_expect_success '6b-setup: Same rename done on both sides' ' |
|
|
|
|
test_create_repo 6b && |
|
|
|
|
( |
|
|
|
|
cd 6b && |
|
|
|
|
|
|
|
|
|
mkdir z && |
|
|
|
|
echo b >z/b && |
|
|
|
|
echo c >z/c && |
|
|
|
|
git add z && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "O" && |
|
|
|
|
|
|
|
|
|
git branch O && |
|
|
|
|
git branch A && |
|
|
|
|
git branch B && |
|
|
|
|
|
|
|
|
|
git checkout A && |
|
|
|
|
git mv z y && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "A" && |
|
|
|
|
|
|
|
|
|
git checkout B && |
|
|
|
|
git mv z y && |
|
|
|
|
mkdir z && |
|
|
|
|
echo d >z/d && |
|
|
|
|
git add z/d && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "B" |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_expect_success '6b-check: Same rename done on both sides' ' |
|
|
|
|
( |
|
|
|
|
cd 6b && |
|
|
|
|
|
|
|
|
|
git checkout A^0 && |
|
|
|
|
|
|
|
|
|
git merge -s recursive B^0 && |
|
|
|
|
|
|
|
|
|
git ls-files -s >out && |
|
|
|
|
test_line_count = 3 out && |
|
|
|
|
git ls-files -u >out && |
|
|
|
|
test_line_count = 0 out && |
|
|
|
|
git ls-files -o >out && |
|
|
|
|
test_line_count = 1 out && |
|
|
|
|
|
|
|
|
|
git rev-parse >actual \ |
|
|
|
|
HEAD:y/b HEAD:y/c HEAD:z/d && |
|
|
|
|
git rev-parse >expect \ |
|
|
|
|
O:z/b O:z/c B:z/d && |
|
|
|
|
test_cmp expect actual |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
# Testcase 6c, Rename only done on same side |
|
|
|
|
# (Related to testcases 6b and 8e) |
|
|
|
|
# Commit O: z/{b,c} |
|
|
|
|
# Commit A: z/{b,c} (no change) |
|
|
|
|
# Commit B: y/{b,c}, z/d |
|
|
|
|
# Expected: y/{b,c}, z/d |
|
|
|
|
# NOTE: Seems obvious, but just checking that the implementation doesn't |
|
|
|
|
# "accidentally detect a rename" and give us y/{b,c,d}. |
|
|
|
|
|
|
|
|
|
test_expect_success '6c-setup: Rename only done on same side' ' |
|
|
|
|
test_create_repo 6c && |
|
|
|
|
( |
|
|
|
|
cd 6c && |
|
|
|
|
|
|
|
|
|
mkdir z && |
|
|
|
|
echo b >z/b && |
|
|
|
|
echo c >z/c && |
|
|
|
|
git add z && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "O" && |
|
|
|
|
|
|
|
|
|
git branch O && |
|
|
|
|
git branch A && |
|
|
|
|
git branch B && |
|
|
|
|
|
|
|
|
|
git checkout A && |
|
|
|
|
test_tick && |
|
|
|
|
git commit --allow-empty -m "A" && |
|
|
|
|
|
|
|
|
|
git checkout B && |
|
|
|
|
git mv z y && |
|
|
|
|
mkdir z && |
|
|
|
|
echo d >z/d && |
|
|
|
|
git add z/d && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "B" |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_expect_success '6c-check: Rename only done on same side' ' |
|
|
|
|
( |
|
|
|
|
cd 6c && |
|
|
|
|
|
|
|
|
|
git checkout A^0 && |
|
|
|
|
|
|
|
|
|
git merge -s recursive B^0 && |
|
|
|
|
|
|
|
|
|
git ls-files -s >out && |
|
|
|
|
test_line_count = 3 out && |
|
|
|
|
git ls-files -u >out && |
|
|
|
|
test_line_count = 0 out && |
|
|
|
|
git ls-files -o >out && |
|
|
|
|
test_line_count = 1 out && |
|
|
|
|
|
|
|
|
|
git rev-parse >actual \ |
|
|
|
|
HEAD:y/b HEAD:y/c HEAD:z/d && |
|
|
|
|
git rev-parse >expect \ |
|
|
|
|
O:z/b O:z/c B:z/d && |
|
|
|
|
test_cmp expect actual |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
# Testcase 6d, We don't always want transitive renaming |
|
|
|
|
# (Related to testcase 1c) |
|
|
|
|
# Commit O: z/{b,c}, x/d |
|
|
|
|
# Commit A: z/{b,c}, x/d (no change) |
|
|
|
|
# Commit B: y/{b,c}, z/d |
|
|
|
|
# Expected: y/{b,c}, z/d |
|
|
|
|
# NOTE: Again, this seems obvious but just checking that the implementation |
|
|
|
|
# doesn't "accidentally detect a rename" and give us y/{b,c,d}. |
|
|
|
|
|
|
|
|
|
test_expect_success '6d-setup: We do not always want transitive renaming' ' |
|
|
|
|
test_create_repo 6d && |
|
|
|
|
( |
|
|
|
|
cd 6d && |
|
|
|
|
|
|
|
|
|
mkdir z && |
|
|
|
|
echo b >z/b && |
|
|
|
|
echo c >z/c && |
|
|
|
|
mkdir x && |
|
|
|
|
echo d >x/d && |
|
|
|
|
git add z x && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "O" && |
|
|
|
|
|
|
|
|
|
git branch O && |
|
|
|
|
git branch A && |
|
|
|
|
git branch B && |
|
|
|
|
|
|
|
|
|
git checkout A && |
|
|
|
|
test_tick && |
|
|
|
|
git commit --allow-empty -m "A" && |
|
|
|
|
|
|
|
|
|
git checkout B && |
|
|
|
|
git mv z y && |
|
|
|
|
git mv x z && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "B" |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_expect_success '6d-check: We do not always want transitive renaming' ' |
|
|
|
|
( |
|
|
|
|
cd 6d && |
|
|
|
|
|
|
|
|
|
git checkout A^0 && |
|
|
|
|
|
|
|
|
|
git merge -s recursive B^0 && |
|
|
|
|
|
|
|
|
|
git ls-files -s >out && |
|
|
|
|
test_line_count = 3 out && |
|
|
|
|
git ls-files -u >out && |
|
|
|
|
test_line_count = 0 out && |
|
|
|
|
git ls-files -o >out && |
|
|
|
|
test_line_count = 1 out && |
|
|
|
|
|
|
|
|
|
git rev-parse >actual \ |
|
|
|
|
HEAD:y/b HEAD:y/c HEAD:z/d && |
|
|
|
|
git rev-parse >expect \ |
|
|
|
|
O:z/b O:z/c O:x/d && |
|
|
|
|
test_cmp expect actual |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
# Testcase 6e, Add/add from one-side |
|
|
|
|
# Commit O: z/{b,c} |
|
|
|
|
# Commit A: z/{b,c} (no change) |
|
|
|
|
# Commit B: y/{b,c,d_1}, z/d_2 |
|
|
|
|
# Expected: y/{b,c,d_1}, z/d_2 |
|
|
|
|
# NOTE: Again, this seems obvious but just checking that the implementation |
|
|
|
|
# doesn't "accidentally detect a rename" and give us y/{b,c} + |
|
|
|
|
# add/add conflict on y/d_1 vs y/d_2. |
|
|
|
|
|
|
|
|
|
test_expect_success '6e-setup: Add/add from one side' ' |
|
|
|
|
test_create_repo 6e && |
|
|
|
|
( |
|
|
|
|
cd 6e && |
|
|
|
|
|
|
|
|
|
mkdir z && |
|
|
|
|
echo b >z/b && |
|
|
|
|
echo c >z/c && |
|
|
|
|
git add z && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "O" && |
|
|
|
|
|
|
|
|
|
git branch O && |
|
|
|
|
git branch A && |
|
|
|
|
git branch B && |
|
|
|
|
|
|
|
|
|
git checkout A && |
|
|
|
|
test_tick && |
|
|
|
|
git commit --allow-empty -m "A" && |
|
|
|
|
|
|
|
|
|
git checkout B && |
|
|
|
|
git mv z y && |
|
|
|
|
echo d1 > y/d && |
|
|
|
|
mkdir z && |
|
|
|
|
echo d2 > z/d && |
|
|
|
|
git add y/d z/d && |
|
|
|
|
test_tick && |
|
|
|
|
git commit -m "B" |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
test_expect_success '6e-check: Add/add from one side' ' |
|
|
|
|
( |
|
|
|
|
cd 6e && |
|
|
|
|
|
|
|
|
|
git checkout A^0 && |
|
|
|
|
|
|
|
|
|
git merge -s recursive B^0 && |
|
|
|
|
|
|
|
|
|
git ls-files -s >out && |
|
|
|
|
test_line_count = 4 out && |
|
|
|
|
git ls-files -u >out && |
|
|
|
|
test_line_count = 0 out && |
|
|
|
|
git ls-files -o >out && |
|
|
|
|
test_line_count = 1 out && |
|
|
|
|
|
|
|
|
|
git rev-parse >actual \ |
|
|
|
|
HEAD:y/b HEAD:y/c HEAD:y/d HEAD:z/d && |
|
|
|
|
git rev-parse >expect \ |
|
|
|
|
O:z/b O:z/c B:y/d B:z/d && |
|
|
|
|
test_cmp expect actual |
|
|
|
|
) |
|
|
|
|
' |
|
|
|
|
|
|
|
|
|
########################################################################### |
|
|
|
|
# Rules suggested by section 6: |
|
|
|
|
# |
|
|
|
|
# Only apply implicit directory renames to directories if the other |
|
|
|
|
# side of history is the one doing the renaming. |
|
|
|
|
########################################################################### |
|
|
|
|
|
|
|
|
|
test_done |
|
|
|
|