t3200: clean up checks for file existence

This patch uses test_path_is_file and test_path_is_missing
instead of "test -f / ! test -f" checks. The former are more
verbose in case of failure and more precise (e.g., is_missing
will check that the entry is actually missing, not just not
a regular file).

As a bonus, this also fixes a few buggy tests that used
"test foo" instead of "test -f foo", and consequently always
reported success.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2011-09-13 12:13:58 -04:00 committed by Junio C Hamano
parent 7b787599e4
commit 376eb14a05

View File

@ -23,7 +23,7 @@ test_expect_success \
test_expect_success \ test_expect_success \
'git branch --help should not have created a bogus branch' ' 'git branch --help should not have created a bogus branch' '
git branch --help </dev/null >/dev/null 2>/dev/null; git branch --help </dev/null >/dev/null 2>/dev/null;
! test -f .git/refs/heads/--help test_path_is_missing .git/refs/heads/--help
' '
test_expect_success 'branch -h in broken repository' ' test_expect_success 'branch -h in broken repository' '
@ -39,11 +39,11 @@ test_expect_success 'branch -h in broken repository' '
test_expect_success \ test_expect_success \
'git branch abc should create a branch' \ 'git branch abc should create a branch' \
'git branch abc && test -f .git/refs/heads/abc' 'git branch abc && test_path_is_file .git/refs/heads/abc'
test_expect_success \ test_expect_success \
'git branch a/b/c should create a branch' \ 'git branch a/b/c should create a branch' \
'git branch a/b/c && test -f .git/refs/heads/a/b/c' 'git branch a/b/c && test_path_is_file .git/refs/heads/a/b/c'
cat >expect <<EOF cat >expect <<EOF
$_z40 $HEAD $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> 1117150200 +0000 branch: Created from master $_z40 $HEAD $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> 1117150200 +0000 branch: Created from master
@ -52,15 +52,15 @@ test_expect_success \
'git branch -l d/e/f should create a branch and a log' \ 'git branch -l d/e/f should create a branch and a log' \
'GIT_COMMITTER_DATE="2005-05-26 23:30" \ 'GIT_COMMITTER_DATE="2005-05-26 23:30" \
git branch -l d/e/f && git branch -l d/e/f &&
test -f .git/refs/heads/d/e/f && test_path_is_file .git/refs/heads/d/e/f &&
test -f .git/logs/refs/heads/d/e/f && test_path_is_file .git/logs/refs/heads/d/e/f &&
test_cmp expect .git/logs/refs/heads/d/e/f' test_cmp expect .git/logs/refs/heads/d/e/f'
test_expect_success \ test_expect_success \
'git branch -d d/e/f should delete a branch and a log' \ 'git branch -d d/e/f should delete a branch and a log' \
'git branch -d d/e/f && 'git branch -d d/e/f &&
test ! -f .git/refs/heads/d/e/f && test_path_is_missing .git/refs/heads/d/e/f &&
test ! -f .git/logs/refs/heads/d/e/f' test_path_is_missing .git/logs/refs/heads/d/e/f'
test_expect_success \ test_expect_success \
'git branch j/k should work after branch j has been deleted' \ 'git branch j/k should work after branch j has been deleted' \
@ -78,13 +78,13 @@ test_expect_success \
'git branch -m m m/m should work' \ 'git branch -m m m/m should work' \
'git branch -l m && 'git branch -l m &&
git branch -m m m/m && git branch -m m m/m &&
test -f .git/logs/refs/heads/m/m' test_path_is_file .git/logs/refs/heads/m/m'
test_expect_success \ test_expect_success \
'git branch -m n/n n should work' \ 'git branch -m n/n n should work' \
'git branch -l n/n && 'git branch -l n/n &&
git branch -m n/n n git branch -m n/n n
test -f .git/logs/refs/heads/n' test_path_is_file .git/logs/refs/heads/n'
test_expect_success 'git branch -m o/o o should fail when o/p exists' ' test_expect_success 'git branch -m o/o o should fail when o/p exists' '
git branch o/o && git branch o/o &&
@ -100,34 +100,34 @@ test_expect_success 'git branch -m q r/q should fail when r exists' '
test_expect_success 'git branch -v -d t should work' ' test_expect_success 'git branch -v -d t should work' '
git branch t && git branch t &&
test .git/refs/heads/t && test_path_is_file .git/refs/heads/t &&
git branch -v -d t && git branch -v -d t &&
test ! -f .git/refs/heads/t test_path_is_missing .git/refs/heads/t
' '
test_expect_success 'git branch -v -m t s should work' ' test_expect_success 'git branch -v -m t s should work' '
git branch t && git branch t &&
test .git/refs/heads/t && test_path_is_file .git/refs/heads/t &&
git branch -v -m t s && git branch -v -m t s &&
test ! -f .git/refs/heads/t && test_path_is_missing .git/refs/heads/t &&
test -f .git/refs/heads/s && test_path_is_file .git/refs/heads/s &&
git branch -d s git branch -d s
' '
test_expect_success 'git branch -m -d t s should fail' ' test_expect_success 'git branch -m -d t s should fail' '
git branch t && git branch t &&
test .git/refs/heads/t && test_path_is_file .git/refs/heads/t &&
test_must_fail git branch -m -d t s && test_must_fail git branch -m -d t s &&
git branch -d t && git branch -d t &&
test ! -f .git/refs/heads/t test_path_is_missing .git/refs/heads/t
' '
test_expect_success 'git branch --list -d t should fail' ' test_expect_success 'git branch --list -d t should fail' '
git branch t && git branch t &&
test .git/refs/heads/t && test_path_is_file .git/refs/heads/t &&
test_must_fail git branch --list -d t && test_must_fail git branch --list -d t &&
git branch -d t && git branch -d t &&
test ! -f .git/refs/heads/t test_path_is_missing .git/refs/heads/t
' '
mv .git/config .git/config-saved mv .git/config .git/config-saved
@ -144,12 +144,12 @@ git config branch.s/s.dummy Hello
test_expect_success \ test_expect_success \
'git branch -m s/s s should work when s/t is deleted' \ 'git branch -m s/s s should work when s/t is deleted' \
'git branch -l s/s && 'git branch -l s/s &&
test -f .git/logs/refs/heads/s/s && test_path_is_file .git/logs/refs/heads/s/s &&
git branch -l s/t && git branch -l s/t &&
test -f .git/logs/refs/heads/s/t && test_path_is_file .git/logs/refs/heads/s/t &&
git branch -d s/t && git branch -d s/t &&
git branch -m s/s s && git branch -m s/s s &&
test -f .git/logs/refs/heads/s' test_path_is_file .git/logs/refs/heads/s'
test_expect_success 'config information was renamed, too' \ test_expect_success 'config information was renamed, too' \
"test $(git config branch.s.dummy) = Hello && "test $(git config branch.s.dummy) = Hello &&
@ -160,8 +160,8 @@ test_expect_success 'renaming a symref is not allowed' \
git symbolic-ref refs/heads/master2 refs/heads/master && git symbolic-ref refs/heads/master2 refs/heads/master &&
test_must_fail git branch -m master2 master3 && test_must_fail git branch -m master2 master3 &&
git symbolic-ref refs/heads/master2 && git symbolic-ref refs/heads/master2 &&
test -f .git/refs/heads/master && test_path_is_file .git/refs/heads/master &&
! test -f .git/refs/heads/master3 test_path_is_missing .git/refs/heads/master3
' '
test_expect_success SYMLINKS \ test_expect_success SYMLINKS \
@ -270,8 +270,8 @@ test_expect_success \
'git checkout -b g/h/i -l should create a branch and a log' \ 'git checkout -b g/h/i -l should create a branch and a log' \
'GIT_COMMITTER_DATE="2005-05-26 23:30" \ 'GIT_COMMITTER_DATE="2005-05-26 23:30" \
git checkout -b g/h/i -l master && git checkout -b g/h/i -l master &&
test -f .git/refs/heads/g/h/i && test_path_is_file .git/refs/heads/g/h/i &&
test -f .git/logs/refs/heads/g/h/i && test_path_is_file .git/logs/refs/heads/g/h/i &&
test_cmp expect .git/logs/refs/heads/g/h/i' test_cmp expect .git/logs/refs/heads/g/h/i'
test_expect_success 'checkout -b makes reflog by default' ' test_expect_success 'checkout -b makes reflog by default' '