Sync with 2.29.3
* maint-2.29: Git 2.29.3 Git 2.28.1 Git 2.27.1 Git 2.26.3 Git 2.25.5 Git 2.24.4 Git 2.23.4 Git 2.22.5 Git 2.21.4 Git 2.20.5 Git 2.19.6 Git 2.18.5 Git 2.17.6 unpack_trees(): start with a fresh lstat cache run-command: invalidate lstat cache after a command finished checkout: fix bug that makes checkout follow symlinks in leading path
This commit is contained in:
@ -31,5 +31,50 @@ test_expect_success 'checkout-index reports errors (stdin)' '
|
||||
test_must_fail git checkout-index --stdin 2>stderr &&
|
||||
test_i18ngrep not.in.the.cache stderr
|
||||
'
|
||||
for mode in 'case' 'utf-8'
|
||||
do
|
||||
case "$mode" in
|
||||
case) dir='A' symlink='a' mode_prereq='CASE_INSENSITIVE_FS' ;;
|
||||
utf-8)
|
||||
dir=$(printf "\141\314\210") symlink=$(printf "\303\244")
|
||||
mode_prereq='UTF8_NFD_TO_NFC' ;;
|
||||
esac
|
||||
|
||||
test_expect_success SYMLINKS,$mode_prereq \
|
||||
"checkout-index with $mode-collision don't write to the wrong place" '
|
||||
git init $mode-collision &&
|
||||
(
|
||||
cd $mode-collision &&
|
||||
mkdir target-dir &&
|
||||
|
||||
empty_obj_hex=$(git hash-object -w --stdin </dev/null) &&
|
||||
symlink_hex=$(printf "%s" "$PWD/target-dir" | git hash-object -w --stdin) &&
|
||||
|
||||
cat >objs <<-EOF &&
|
||||
100644 blob ${empty_obj_hex} ${dir}/x
|
||||
100644 blob ${empty_obj_hex} ${dir}/y
|
||||
100644 blob ${empty_obj_hex} ${dir}/z
|
||||
120000 blob ${symlink_hex} ${symlink}
|
||||
EOF
|
||||
|
||||
git update-index --index-info <objs &&
|
||||
|
||||
# Note: the order is important here to exercise the
|
||||
# case where the file at ${dir} has its type changed by
|
||||
# the time Git tries to check out ${dir}/z.
|
||||
#
|
||||
# Also, we use core.precomposeUnicode=false because we
|
||||
# want Git to treat the UTF-8 paths transparently on
|
||||
# Mac OS, matching what is in the index.
|
||||
#
|
||||
git -c core.precomposeUnicode=false checkout-index -f \
|
||||
${dir}/x ${dir}/y ${symlink} ${dir}/z &&
|
||||
|
||||
# Should not create ${dir}/z at ${symlink}/z
|
||||
test_path_is_missing target-dir/z
|
||||
|
||||
)
|
||||
'
|
||||
done
|
||||
|
||||
test_done
|
||||
|
Reference in New Issue
Block a user