summaryrefslogtreecommitdiffstats
path: root/t/t1450-fsck.sh
blob: 759cf12e16bcddc3dab9d6b3ad8abd5590245a94 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
#!/bin/sh

test_description='git fsck random collection of tests'

. ./test-lib.sh

test_expect_success setup '
	git config i18n.commitencoding ISO-8859-1 &&
	test_commit A fileA one &&
	git config --unset i18n.commitencoding &&
	git checkout HEAD^0 &&
	test_commit B fileB two &&
	git tag -d A B &&
	git reflog expire --expire=now --all
'

test_expect_success 'HEAD is part of refs' '
	test 0 = $(git fsck | wc -l)
'

test_expect_success 'loose objects borrowed from alternate are not missing' '
	mkdir another &&
	(
		cd another &&
		git init &&
		echo ../../../.git/objects >.git/objects/info/alternates &&
		test_commit C fileC one &&
		git fsck >out &&
		! grep "missing blob" out
	)
'

test_expect_success 'valid objects appear valid' '
	{ git fsck 2>out; true; } &&
	! grep error out &&
	! grep fatal out
'

# Corruption tests follow.  Make sure to remove all traces of the
# specific corruption you test afterwards, lest a later test trip over
# it.

test_expect_success 'object with bad sha1' '
	sha=$(echo blob | git hash-object -w --stdin) &&
	echo $sha &&
	old=$(echo $sha | sed "s+^..+&/+") &&
	new=$(dirname $old)/ffffffffffffffffffffffffffffffffffffff &&
	sha="$(dirname $new)$(basename $new)"
	mv .git/objects/$old .git/objects/$new &&
	git update-index --add --cacheinfo 100644 $sha foo &&
	tree=$(git write-tree) &&
	cmt=$(echo bogus | git commit-tree $tree) &&
	git update-ref refs/heads/bogus $cmt &&
	(git fsck 2>out; true) &&
	grep "$sha.*corrupt" out &&
	rm -f .git/objects/$new &&
	git update-ref -d refs/heads/bogus &&
	git read-tree -u --reset HEAD
'

test_expect_success 'branch pointing to non-commit' '
	git rev-parse HEAD^{tree} > .git/refs/heads/invalid &&
	git fsck 2>out &&
	grep "not a commit" out &&
	git update-ref -d refs/heads/invalid
'

new=nothing
test_expect_success 'email without @ is okay' '
	git cat-file commit HEAD >basis &&
	sed "s/@/AT/" basis >okay &&
	new=$(git hash-object -t commit -w --stdin <okay) &&
	echo "$new" &&
	git update-ref refs/heads/bogus "$new" &&
	git fsck 2>out &&
	cat out &&
	! grep "error in commit $new" out
'
git update-ref -d refs/heads/bogus
rm -f ".git/objects/$new"

new=nothing
test_expect_success 'email with embedded > is not okay' '
	git cat-file commit HEAD >basis &&
	sed "s/@[a-z]/&>/" basis >bad-email &&
	new=$(git hash-object -t commit -w --stdin <bad-email) &&
	echo "$new" &&
	git update-ref refs/heads/bogus "$new" &&
	git fsck 2>out &&
	cat out &&
	grep "error in commit $new" out
'
git update-ref -d refs/heads/bogus
rm -f ".git/objects/$new"

cat > invalid-tag <<EOF
object ffffffffffffffffffffffffffffffffffffffff
type commit
tag invalid
tagger T A Gger <tagger@example.com> 1234567890 -0000

This is an invalid tag.
EOF

test_expect_success 'tag pointing to nonexistent' '
	tag=$(git hash-object -t tag -w --stdin < invalid-tag) &&
	echo $tag > .git/refs/tags/invalid &&
	test_must_fail git fsck --tags >out &&
	cat out &&
	grep "broken link" out &&
	rm .git/refs/tags/invalid
'

cat > wrong-tag <<EOF
object $(echo blob | git hash-object -w --stdin)
type commit
tag wrong
tagger T A Gger <tagger@example.com> 1234567890 -0000

This is an invalid tag.
EOF

test_expect_success 'tag pointing to something else than its type' '
	tag=$(git hash-object -t tag -w --stdin < wrong-tag) &&
	echo $tag > .git/refs/tags/wrong &&
	test_must_fail git fsck --tags 2>out &&
	cat out &&
	grep "error in tag.*broken links" out &&
	rm .git/refs/tags/wrong
'



test_done