Skip to content

Commit dd72cd0

Browse files
committed
t5605: special-case hardlink test for BusyBox-w32
When t5605 tries to verify that files are hardlinked (or that they are not), it uses the `-links` option of the `find` utility. BusyBox' implementation does not support that option, and BusyBox-w32's lstat() does not even report the number of hard links correctly (for performance reasons). So let's just switch to a different method that actually works on Windows. Signed-off-by: Johannes Schindelin <[email protected]>
1 parent 8d49e17 commit dd72cd0

File tree

1 file changed

+15
-0
lines changed

1 file changed

+15
-0
lines changed

t/t5605-clone-local.sh

+15
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,21 @@ repo_is_hardlinked() {
1111
test_line_count = 0 output
1212
}
1313

14+
if test_have_prereq MINGW,BUSYBOX
15+
then
16+
# BusyBox' `find` does not support `-links`. Besides, BusyBox-w32's
17+
# lstat() does not report hard links, just like Git's mingw_lstat()
18+
# (from where BusyBox-w32 got its initial implementation).
19+
repo_is_hardlinked() {
20+
for f in $(find "$1/objects" -type f)
21+
do
22+
"$SYSTEMROOT"/system32/fsutil.exe \
23+
hardlink list $f >links &&
24+
test_line_count -gt 1 links || return 1
25+
done
26+
}
27+
fi
28+
1429
test_expect_success 'preparing origin repository' '
1530
: >file && git add . && git commit -m1 &&
1631
git clone --bare . a.git &&

0 commit comments

Comments
 (0)