t0001: fix on case-insensitive filesystems
On a case-insensitive filesystem, such as HFS+ or NTFS, it is possible that the idea Bash has of the current directory differs in case from what Git thinks it is. That's totally okay, though, and we should not expect otherwise. On Windows, for example, when you call cd C:\GIT-SDK-64 in a PowerShell and there exists a directory called `C:\git-sdk-64`, the current directory will be reported in all upper-case. Even in a Bash that you might call from that PowerShell. Git, however, will have normalized this via `GetFinalPathByHandle()`, and the expectation in t0001 that the recorded gitdir will match what `pwd` says will be violated. Let's address this by comparing these paths in a case-insensitive manner when `core.ignoreCase` is `true`. Reported by Jameson Miller. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
b697d92f56
commit
ed33bd8f30
@ -311,8 +311,8 @@ test_expect_success 'init prefers command line to GIT_DIR' '
|
||||
test_expect_success 'init with separate gitdir' '
|
||||
rm -rf newdir &&
|
||||
git init --separate-git-dir realgitdir newdir &&
|
||||
echo "gitdir: $(pwd)/realgitdir" >expected &&
|
||||
test_cmp expected newdir/.git &&
|
||||
newdir_git="$(cat newdir/.git)" &&
|
||||
test_cmp_fspath "$(pwd)/realgitdir" "${newdir_git#gitdir: }" &&
|
||||
test_path_is_dir realgitdir/refs
|
||||
'
|
||||
|
||||
@ -361,12 +361,9 @@ test_expect_success 're-init on .git file' '
|
||||
'
|
||||
|
||||
test_expect_success 're-init to update git link' '
|
||||
(
|
||||
cd newdir &&
|
||||
git init --separate-git-dir ../surrealgitdir
|
||||
) &&
|
||||
echo "gitdir: $(pwd)/surrealgitdir" >expected &&
|
||||
test_cmp expected newdir/.git &&
|
||||
git -C newdir init --separate-git-dir ../surrealgitdir &&
|
||||
newdir_git="$(cat newdir/.git)" &&
|
||||
test_cmp_fspath "$(pwd)/surrealgitdir" "${newdir_git#gitdir: }" &&
|
||||
test_path_is_dir surrealgitdir/refs &&
|
||||
test_path_is_missing realgitdir/refs
|
||||
'
|
||||
@ -374,12 +371,9 @@ test_expect_success 're-init to update git link' '
|
||||
test_expect_success 're-init to move gitdir' '
|
||||
rm -rf newdir realgitdir surrealgitdir &&
|
||||
git init newdir &&
|
||||
(
|
||||
cd newdir &&
|
||||
git init --separate-git-dir ../realgitdir
|
||||
) &&
|
||||
echo "gitdir: $(pwd)/realgitdir" >expected &&
|
||||
test_cmp expected newdir/.git &&
|
||||
git -C newdir init --separate-git-dir ../realgitdir &&
|
||||
newdir_git="$(cat newdir/.git)" &&
|
||||
test_cmp_fspath "$(pwd)/realgitdir" "${newdir_git#gitdir: }" &&
|
||||
test_path_is_dir realgitdir/refs
|
||||
'
|
||||
|
||||
|
@ -888,6 +888,21 @@ test_cmp_rev () {
|
||||
fi
|
||||
}
|
||||
|
||||
# Compare paths respecting core.ignoreCase
|
||||
test_cmp_fspath () {
|
||||
if test "x$1" = "x$2"
|
||||
then
|
||||
return 0
|
||||
fi
|
||||
|
||||
if test true != "$(git config --get --type=bool core.ignorecase)"
|
||||
then
|
||||
return 1
|
||||
fi
|
||||
|
||||
test "x$(echo "$1" | tr A-Z a-z)" = "x$(echo "$2" | tr A-Z a-z)"
|
||||
}
|
||||
|
||||
# Print a sequence of integers in increasing order, either with
|
||||
# two arguments (start and end):
|
||||
#
|
||||
|
Loading…
Reference in New Issue
Block a user