Merge branch 'jc/conflict-marker-size' into maint
[tgit.git] / t / t5530-upload-pack-error.sh
bloba696b8791b7caa44ae2bd16d6970a791f3a28d3d
1 #!/bin/sh
3 test_description='errors in upload-pack'
5 . ./test-lib.sh
7 D=`pwd`
9 corrupt_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"
16 test_expect_success 'setup and corrupt repository' '
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
29 test_expect_success 'fsck fails' '
30 test_must_fail git fsck
33 test_expect_success 'upload-pack fails due to error in pack-objects packing' '
35 ! echo "0032want $(git rev-parse HEAD)
36 00000009done
37 0000" | git upload-pack . > /dev/null 2> output.err &&
38 grep "unable to read" output.err &&
39 grep "pack-objects died" output.err
42 test_expect_success 'corrupt repo differently' '
44 git hash-object -w file &&
45 corrupt_repo HEAD^^{tree}
49 test_expect_success 'fsck fails' '
50 test_must_fail git fsck
52 test_expect_success 'upload-pack fails due to error in rev-list' '
54 ! echo "0032want $(git rev-parse HEAD)
55 0034shallow $(git rev-parse HEAD^)00000009done
56 0000" | git upload-pack . > /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
63 test_expect_success 'upload-pack fails due to error in pack-objects enumeration' '
65 ! echo "0032want $(git rev-parse HEAD)
66 00000009done
67 0000" | git upload-pack . > /dev/null 2> output.err &&
68 grep "bad tree object" output.err &&
69 grep "pack-objects died" output.err
72 test_expect_success 'create empty repository' '
74 mkdir foo &&
75 cd foo &&
76 git init
80 test_expect_success 'fetch fails' '
82 test_must_fail git fetch .. master
86 test_done