Merge branch 'jk/path-name-safety-2.6' into jk/path-name-safety-2.7
[git] / t / t6039-merge-ignorecase.sh
1 #!/bin/sh
2
3 test_description='git-merge with case-changing rename on case-insensitive file system'
4
5 . ./test-lib.sh
6
7 if ! test_have_prereq CASE_INSENSITIVE_FS
8 then
9         skip_all='skipping case insensitive tests - case sensitive file system'
10         test_done
11 fi
12
13 test_expect_success 'merge with case-changing rename' '
14         test $(git config core.ignorecase) = true &&
15         >TestCase &&
16         git add TestCase &&
17         git commit -m "add TestCase" &&
18         git tag baseline &&
19         git checkout -b with-camel &&
20         >foo &&
21         git add foo &&
22         git commit -m "intervening commit" &&
23         git checkout master &&
24         git rm TestCase &&
25         >testcase &&
26         git add testcase &&
27         git commit -m "rename to testcase" &&
28         git checkout with-camel &&
29         git merge master -m "merge" &&
30         test_path_is_file testcase
31 '
32
33 test_expect_success 'merge with case-changing rename on both sides' '
34         git checkout master &&
35         git reset --hard baseline &&
36         git branch -D with-camel &&
37         git checkout -b with-camel &&
38         git mv TestCase testcase &&
39         git commit -m "recase on branch" &&
40         >foo &&
41         git add foo &&
42         git commit -m "intervening commit" &&
43         git checkout master &&
44         git rm TestCase &&
45         >testcase &&
46         git add testcase &&
47         git commit -m "rename to testcase" &&
48         git checkout with-camel &&
49         git merge master -m "merge" &&
50         test_path_is_file testcase
51 '
52
53 test_done