git-commit-vandalism/t/t9819-git-p4-case-folding.sh
Denton Liu 546f352638 t9819: don't use test_must_fail with p4
We were using `test_must_fail p4` to test that the p4 command failed as
expected. However, test_must_fail() is used to ensure that commands fail
in an expected way, not due to something like a segv. Since we are not
in the business of verifying the sanity of the external world, replace
`test_must_fail p4` with `! p4` and assume that the `p4` command does
not die unexpectedly.

Signed-off-by: Denton Liu <liu.denton@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2020-04-20 13:30:55 -07:00

57 lines
1.3 KiB
Bash
Executable File

#!/bin/sh
test_description='interaction with P4 case-folding'
. ./lib-git-p4.sh
if test_have_prereq CASE_INSENSITIVE_FS
then
skip_all='skipping P4 case-folding tests; case insensitive file system detected'
test_done
fi
test_expect_success 'start p4d with case folding enabled' '
start_p4d -C1
'
test_expect_success 'Create a repo, name is lowercase' '
(
client_view "//depot/... //client/..." &&
cd "$cli" &&
mkdir -p lc UC &&
>lc/file.txt && >UC/file.txt &&
p4 add lc/file.txt UC/file.txt &&
p4 submit -d "Add initial lc and UC repos"
)
'
test_expect_success 'Check p4 is in case-folding mode' '
(
cd "$cli" &&
>lc/FILE.TXT &&
p4 add lc/FILE.TXT &&
! p4 submit -d "Cannot add file differing only in case" lc/FILE.TXT
)
'
# Check we created the repo properly
test_expect_success 'Clone lc repo using lc name' '
git p4 clone //depot/lc/... &&
test_path_is_file lc/file.txt &&
git p4 clone //depot/UC/... &&
test_path_is_file UC/file.txt
'
# The clone should fail, since there is no repo called LC, but because
# we have case-insensitive p4d enabled, it appears to go ahead and work,
# but leaves an empty git repo in place.
test_expect_failure 'Clone lc repo using uc name' '
test_must_fail git p4 clone //depot/LC/...
'
test_expect_failure 'Clone UC repo with lc name' '
test_must_fail git p4 clone //depot/uc/...
'
test_done