t / t5530-upload-pack-error.shon commit vcs-svn: allow input errors to be detected promptly (efc749b)
   1#!/bin/sh
   2
   3test_description='errors in upload-pack'
   4
   5. ./test-lib.sh
   6
   7D=`pwd`
   8
   9corrupt_repo () {
  10        object_sha1=$(git rev-parse "$1") &&
  11        ob=$(expr "$object_sha1" : "\(..\)") &&
  12        ject=$(expr "$object_sha1" : "..\(..*\)") &&
  13        rm -f ".git/objects/$ob/$ject"
  14}
  15
  16test_expect_success 'setup and corrupt repository' '
  17
  18        echo file >file &&
  19        git add file &&
  20        git rev-parse :file &&
  21        git commit -a -m original &&
  22        test_tick &&
  23        echo changed >file &&
  24        git commit -a -m changed &&
  25        corrupt_repo HEAD:file
  26
  27'
  28
  29test_expect_success 'fsck fails' '
  30        test_must_fail git fsck
  31'
  32
  33test_expect_success 'upload-pack fails due to error in pack-objects packing' '
  34
  35        printf "0032want %s\n00000009done\n0000" \
  36                $(git rev-parse HEAD) >input &&
  37        test_must_fail git upload-pack . <input >/dev/null 2>output.err &&
  38        grep "unable to read" output.err &&
  39        grep "pack-objects died" output.err
  40'
  41
  42test_expect_success 'corrupt repo differently' '
  43
  44        git hash-object -w file &&
  45        corrupt_repo HEAD^^{tree}
  46
  47'
  48
  49test_expect_success 'fsck fails' '
  50        test_must_fail git fsck
  51'
  52test_expect_success 'upload-pack fails due to error in rev-list' '
  53
  54        printf "0032want %s\n0034shallow %s00000009done\n0000" \
  55                $(git rev-parse HEAD) $(git rev-parse HEAD^) >input &&
  56        test_must_fail git upload-pack . <input >/dev/null 2>output.err &&
  57        # pack-objects survived
  58        grep "Total.*, reused" output.err &&
  59        # but there was an error, which must have been in rev-list
  60        grep "bad tree object" output.err
  61'
  62
  63test_expect_success 'upload-pack error message when bad ref requested' '
  64
  65        printf "0045want %s multi_ack_detailed\n00000009done\n0000" \
  66                "deadbeefdeadbeefdeadbeefdeadbeefdeadbeef" >input &&
  67        test_must_fail git upload-pack . <input >output 2>output.err &&
  68        grep -q "not our ref" output.err &&
  69        ! grep -q multi_ack_detailed output.err
  70'
  71
  72test_expect_success 'upload-pack fails due to error in pack-objects enumeration' '
  73
  74        printf "0032want %s\n00000009done\n0000" \
  75                $(git rev-parse HEAD) >input &&
  76        test_must_fail git upload-pack . <input >/dev/null 2>output.err &&
  77        grep "bad tree object" output.err &&
  78        grep "pack-objects died" output.err
  79'
  80
  81test_expect_success 'create empty repository' '
  82
  83        mkdir foo &&
  84        cd foo &&
  85        git init
  86
  87'
  88
  89test_expect_success 'fetch fails' '
  90
  91        test_must_fail git fetch .. master
  92
  93'
  94
  95test_done