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.
104 lines
2.3 KiB
104 lines
2.3 KiB
#!/bin/sh |
|
|
|
test_description='merge: handle file mode' |
|
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main |
|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME |
|
|
|
TEST_PASSES_SANITIZE_LEAK=true |
|
. ./test-lib.sh |
|
|
|
test_expect_success 'set up mode change in one branch' ' |
|
: >file1 && |
|
git add file1 && |
|
git commit -m initial && |
|
git checkout -b a1 main && |
|
: >dummy && |
|
git add dummy && |
|
git commit -m a && |
|
git checkout -b b1 main && |
|
test_chmod +x file1 && |
|
git add file1 && |
|
git commit -m b1 |
|
' |
|
|
|
do_one_mode () { |
|
strategy=$1 |
|
us=$2 |
|
them=$3 |
|
test_expect_success "resolve single mode change ($strategy, $us)" ' |
|
git checkout -f $us && |
|
git merge -s $strategy $them && |
|
git ls-files -s file1 | grep ^100755 |
|
' |
|
|
|
test_expect_success FILEMODE "verify executable bit on file ($strategy, $us)" ' |
|
test -x file1 |
|
' |
|
} |
|
|
|
do_one_mode recursive a1 b1 |
|
do_one_mode recursive b1 a1 |
|
do_one_mode resolve a1 b1 |
|
do_one_mode resolve b1 a1 |
|
|
|
test_expect_success 'set up mode change in both branches' ' |
|
git reset --hard HEAD && |
|
git checkout -b a2 main && |
|
: >file2 && |
|
H=$(git hash-object file2) && |
|
test_chmod +x file2 && |
|
git commit -m a2 && |
|
git checkout -b b2 main && |
|
: >file2 && |
|
git add file2 && |
|
git commit -m b2 && |
|
cat >expect <<-EOF |
|
100755 $H 2 file2 |
|
100644 $H 3 file2 |
|
EOF |
|
' |
|
|
|
do_both_modes () { |
|
strategy=$1 |
|
test_expect_success "detect conflict on double mode change ($strategy)" ' |
|
git reset --hard && |
|
git checkout -f a2 && |
|
test_must_fail git merge -s $strategy b2 && |
|
git ls-files -u >actual && |
|
test_cmp expect actual && |
|
git ls-files -s file2 | grep ^100755 |
|
' |
|
|
|
test_expect_success FILEMODE "verify executable bit on file ($strategy)" ' |
|
test -x file2 |
|
' |
|
} |
|
|
|
# both sides are equivalent, so no need to run both ways |
|
do_both_modes recursive |
|
do_both_modes resolve |
|
|
|
test_expect_success 'set up delete/modechange scenario' ' |
|
git reset --hard && |
|
git checkout -b deletion main && |
|
git rm file1 && |
|
git commit -m deletion |
|
' |
|
|
|
do_delete_modechange () { |
|
strategy=$1 |
|
us=$2 |
|
them=$3 |
|
test_expect_success "detect delete/modechange conflict ($strategy, $us)" ' |
|
git reset --hard && |
|
git checkout $us && |
|
test_must_fail git merge -s $strategy $them |
|
' |
|
} |
|
|
|
do_delete_modechange recursive b1 deletion |
|
do_delete_modechange recursive deletion b1 |
|
do_delete_modechange resolve b1 deletion |
|
do_delete_modechange resolve deletion b1 |
|
|
|
test_done
|
|
|