You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.2 KiB
53 lines
1.2 KiB
#!/bin/sh |
|
|
|
test_description='git-merge with case-changing rename on case-insensitive file system' |
|
|
|
. ./test-lib.sh |
|
|
|
if ! test_have_prereq CASE_INSENSITIVE_FS |
|
then |
|
skip_all='skipping case insensitive tests - case sensitive file system' |
|
test_done |
|
fi |
|
|
|
test_expect_success 'merge with case-changing rename' ' |
|
test $(git config core.ignorecase) = true && |
|
>TestCase && |
|
git add TestCase && |
|
git commit -m "add TestCase" && |
|
git tag baseline |
|
git checkout -b with-camel && |
|
>foo && |
|
git add foo && |
|
git commit -m "intervening commit" && |
|
git checkout master && |
|
git rm TestCase && |
|
>testcase && |
|
git add testcase && |
|
git commit -m "rename to testcase" && |
|
git checkout with-camel && |
|
git merge master -m "merge" && |
|
test_path_is_file testcase |
|
' |
|
|
|
test_expect_success 'merge with case-changing rename on both sides' ' |
|
git checkout master && |
|
git reset --hard baseline && |
|
git branch -D with-camel && |
|
git checkout -b with-camel && |
|
git mv TestCase testcase && |
|
git commit -m "recase on branch" && |
|
>foo && |
|
git add foo && |
|
git commit -m "intervening commit" && |
|
git checkout master && |
|
git rm TestCase && |
|
>testcase && |
|
git add testcase && |
|
git commit -m "rename to testcase" && |
|
git checkout with-camel && |
|
git merge master -m "merge" && |
|
test_path_is_file testcase |
|
' |
|
|
|
test_done
|
|
|