diff options
author | Alex Riesen <raa.lkml@gmail.com> | 2009-05-11 11:31:42 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-07-29 10:26:10 -0700 |
commit | 1c9b2d3aa12ea4e34c1d04cc2af4e07a1eecb964 (patch) | |
tree | 68cd07352fb9ca73fa3f8338331324b6125ee131 | |
parent | 6641575963388b61f408f177d91cdacad25d2e26 (diff) | |
download | git-1c9b2d3aa12ea4e34c1d04cc2af4e07a1eecb964.tar.gz |
Add a reminder test case for a merge with F/D transition
The problem is that if a file was replaced with a directory containing
another file with the same content and mode, an attempt to merge it
with a branch descended from a commit before this F->D transition will
cause merge-recursive to break. It breaks even if there were no
conflicting changes on that other branch.
Originally reported by Anders Melchiorsen.
Signed-off-by: Alex Riesen <raa.lkml@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rwxr-xr-x | t/t6020-merge-df.sh | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/t/t6020-merge-df.sh b/t/t6020-merge-df.sh index a19d49de28..e71c687f2b 100755 --- a/t/t6020-merge-df.sh +++ b/t/t6020-merge-df.sh @@ -22,4 +22,27 @@ git commit -m "File: dir"' test_expect_code 1 'Merge with d/f conflicts' 'git merge "merge msg" B master' +test_expect_failure 'F/D conflict' ' + git reset --hard && + git checkout master && + rm .git/index && + + mkdir before && + echo FILE >before/one && + echo FILE >after && + git add . && + git commit -m first && + + rm -f after && + git mv before after && + git commit -m move && + + git checkout -b para HEAD^ && + echo COMPLETELY ANOTHER FILE >another && + git add . && + git commit -m para && + + git merge master +' + test_done |