t1400: add some more tests of "update-ref --stdin"'s verify command
Two of the tests fail because verify refs/heads/foo with no argument (not even zeros) actually *deletes* refs/heads/foo. This problem will be fixed in the next commit. Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
8213d87a83
commit
a46e41fca3
@ -619,6 +619,52 @@ test_expect_success 'stdin update/create/verify combination works' '
|
||||
test_must_fail git rev-parse --verify -q $c
|
||||
'
|
||||
|
||||
test_expect_success 'stdin verify succeeds for correct value' '
|
||||
git rev-parse $m >expect &&
|
||||
echo "verify $m $m" >stdin &&
|
||||
git update-ref --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'stdin verify succeeds for missing reference' '
|
||||
echo "verify refs/heads/missing $Z" >stdin &&
|
||||
git update-ref --stdin <stdin &&
|
||||
test_must_fail git rev-parse --verify -q refs/heads/missing
|
||||
'
|
||||
|
||||
test_expect_success 'stdin verify treats no value as missing' '
|
||||
echo "verify refs/heads/missing" >stdin &&
|
||||
git update-ref --stdin <stdin &&
|
||||
test_must_fail git rev-parse --verify -q refs/heads/missing
|
||||
'
|
||||
|
||||
test_expect_success 'stdin verify fails for wrong value' '
|
||||
git rev-parse $m >expect &&
|
||||
echo "verify $m $m~1" >stdin &&
|
||||
test_must_fail git update-ref --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'stdin verify fails for mistaken null value' '
|
||||
git rev-parse $m >expect &&
|
||||
echo "verify $m $Z" >stdin &&
|
||||
test_must_fail git update-ref --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_failure 'stdin verify fails for mistaken empty value' '
|
||||
M=$(git rev-parse $m) &&
|
||||
test_when_finished "git update-ref $m $M" &&
|
||||
git rev-parse $m >expect &&
|
||||
echo "verify $m" >stdin &&
|
||||
test_must_fail git update-ref --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'stdin update refs works with identity updates' '
|
||||
cat >stdin <<-EOF &&
|
||||
update $a $m $m
|
||||
@ -938,6 +984,52 @@ test_expect_success 'stdin -z update/create/verify combination works' '
|
||||
test_must_fail git rev-parse --verify -q $c
|
||||
'
|
||||
|
||||
test_expect_success 'stdin -z verify succeeds for correct value' '
|
||||
git rev-parse $m >expect &&
|
||||
printf $F "verify $m" "$m" >stdin &&
|
||||
git update-ref -z --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'stdin -z verify succeeds for missing reference' '
|
||||
printf $F "verify refs/heads/missing" "$Z" >stdin &&
|
||||
git update-ref -z --stdin <stdin &&
|
||||
test_must_fail git rev-parse --verify -q refs/heads/missing
|
||||
'
|
||||
|
||||
test_expect_success 'stdin -z verify treats no value as missing' '
|
||||
printf $F "verify refs/heads/missing" "" >stdin &&
|
||||
git update-ref -z --stdin <stdin &&
|
||||
test_must_fail git rev-parse --verify -q refs/heads/missing
|
||||
'
|
||||
|
||||
test_expect_success 'stdin -z verify fails for wrong value' '
|
||||
git rev-parse $m >expect &&
|
||||
printf $F "verify $m" "$m~1" >stdin &&
|
||||
test_must_fail git update-ref -z --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'stdin -z verify fails for mistaken null value' '
|
||||
git rev-parse $m >expect &&
|
||||
printf $F "verify $m" "$Z" >stdin &&
|
||||
test_must_fail git update-ref -z --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_failure 'stdin -z verify fails for mistaken empty value' '
|
||||
M=$(git rev-parse $m) &&
|
||||
test_when_finished "git update-ref $m $M" &&
|
||||
git rev-parse $m >expect &&
|
||||
printf $F "verify $m" "" >stdin &&
|
||||
test_must_fail git update-ref -z --stdin <stdin &&
|
||||
git rev-parse $m >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'stdin -z update refs works with identity updates' '
|
||||
printf $F "update $a" "$m" "$m" "update $b" "$m" "$m" "update $c" "$Z" "" >stdin &&
|
||||
git update-ref -z --stdin <stdin &&
|
||||
|
Loading…
Reference in New Issue
Block a user