3 a5feed5f 2022-12-26 stsp # Copyright (c) 2022 Mikhail Pchelin <misha@freebsd.org>
5 a5feed5f 2022-12-26 stsp # Permission to use, copy, modify, and distribute this software for any
6 a5feed5f 2022-12-26 stsp # purpose with or without fee is hereby granted, provided that the above
7 a5feed5f 2022-12-26 stsp # copyright notice and this permission notice appear in all copies.
9 a5feed5f 2022-12-26 stsp # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 a5feed5f 2022-12-26 stsp # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 a5feed5f 2022-12-26 stsp # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 a5feed5f 2022-12-26 stsp # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 a5feed5f 2022-12-26 stsp # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 a5feed5f 2022-12-26 stsp # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 a5feed5f 2022-12-26 stsp # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 a5feed5f 2022-12-26 stsp . ../cmdline/common.sh
18 a5feed5f 2022-12-26 stsp . ./common.sh
20 9bd4acdb 2022-12-27 op dummy_commit="aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
22 a5feed5f 2022-12-26 stsp # Non-existent commit
23 a5feed5f 2022-12-26 stsp test_request_bad_commit() {
24 a5feed5f 2022-12-26 stsp local testroot=`test_init request_bad_commit`
26 9bd4acdb 2022-12-27 op echo "0054want $dummy_commit multi_ack side-band-64k ofs-delta" \
27 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/test-repo' \
28 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
30 9bd4acdb 2022-12-27 op echo -n "0041ERR object $dummy_commit not found" \
31 9bd4acdb 2022-12-27 op > $testroot/stdout.expected
33 9bd4acdb 2022-12-27 op echo "gotsh: object $dummy_commit not found" \
34 9bd4acdb 2022-12-27 op > $testroot/stderr.expected
36 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout 0 112
38 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
39 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
40 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
44 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
46 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
47 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
48 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
49 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
52 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
55 a5feed5f 2022-12-26 stsp # Zero pkt-len (as flush packet with payload)
56 a5feed5f 2022-12-26 stsp test_request_bad_length_zero() {
57 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_length_zero`
59 9bd4acdb 2022-12-27 op echo "0000want $dummy_commit multi_ack side-band-64k ofs-delta" \
60 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/test-repo' \
61 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
63 a5feed5f 2022-12-26 stsp echo -n "00000028ERR unexpected flush packet received" \
64 a5feed5f 2022-12-26 stsp > $testroot/stdout.expected
66 a5feed5f 2022-12-26 stsp echo "gotsh: unexpected flush packet received" \
67 a5feed5f 2022-12-26 stsp > $testroot/stderr.expected
69 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout 0 108
71 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
72 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
73 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
77 a5feed5f 2022-12-26 stsp cmp -s $testroot/stderr $testroot/stderr.expected
79 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
80 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
81 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
82 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
85 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
88 a5feed5f 2022-12-26 stsp # 0004 (empty)
89 a5feed5f 2022-12-26 stsp test_request_bad_length_empty() {
90 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_length_empty`
92 9bd4acdb 2022-12-27 op echo "0004want $dummy_commit multi_ack side-band-64k ofs-delta" \
93 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/test-repo' \
94 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
96 9bd4acdb 2022-12-27 op printf "00000008NAK\n0021ERR read: Bad file descriptor" \
97 a5feed5f 2022-12-26 stsp > $testroot/stdout.expected
99 a5feed5f 2022-12-26 stsp echo "gotsh: read: Bad file descriptor" > $testroot/stderr.expected
101 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout 0 108
103 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
104 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
105 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
109 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
111 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
112 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
113 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
114 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
117 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
120 a5feed5f 2022-12-26 stsp # Pkt-len too small
121 a5feed5f 2022-12-26 stsp test_request_bad_length_small() {
122 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_length_small`
124 9bd4acdb 2022-12-27 op echo "0002want $dummy_commit multi_ack side-band-64k ofs-delta" \
125 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/test-repo' \
126 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
128 9bd4acdb 2022-12-27 op printf "00000008NAK\n0021ERR read: Bad file descriptor" \
129 a5feed5f 2022-12-26 stsp > $testroot/stdout.expected
131 a5feed5f 2022-12-26 stsp echo "gotsh: read: Bad file descriptor" > $testroot/stderr.expected
133 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout 0 108
135 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
136 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
137 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
141 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
143 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
144 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
145 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
146 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
149 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
152 a5feed5f 2022-12-26 stsp # Pkt-len too large
153 a5feed5f 2022-12-26 stsp test_request_bad_length_large() {
154 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_length_large`
156 9bd4acdb 2022-12-27 op echo "ffffwant $dummy_commit multi_ack side-band-64k ofs-delta" \
157 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/test-repo' \
158 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
160 9bd4acdb 2022-12-27 op printf "00000008NAK\n0021ERR read: Bad file descriptor" \
161 a5feed5f 2022-12-26 stsp > $testroot/stdout.expected
163 a5feed5f 2022-12-26 stsp echo "gotsh: read: Bad file descriptor" > $testroot/stderr.expected
165 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout 0 108
167 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
168 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
169 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
173 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
175 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
176 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
177 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
178 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
181 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
184 a5feed5f 2022-12-26 stsp # Unknown feature
185 a5feed5f 2022-12-26 stsp test_request_bad_capabilities() {
186 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_capabilities`
188 9bd4acdb 2022-12-27 op echo "0054want $dummy_commit aaaaaaaaa bbbbbbbbbbbbb ccccccccc" \
189 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/test-repo' \
190 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
192 a5feed5f 2022-12-26 stsp echo -n "00000025ERR unexpected want-line received" \
193 a5feed5f 2022-12-26 stsp > $testroot/stdout.expected
195 a5feed5f 2022-12-26 stsp echo "gotsh: unexpected want-line received" > $testroot/stderr.expected
197 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout 0 108
199 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
200 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
201 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
205 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
207 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
208 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
209 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
210 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
213 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
216 a5feed5f 2022-12-26 stsp # Unknown repository
217 a5feed5f 2022-12-26 stsp test_request_bad_repository() {
218 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_repository`
220 9bd4acdb 2022-12-27 op echo "0054want $dummy_commit aaaaaaaaa bbbbbbbbbbbbb ccccccccc" \
221 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack '/XXXX-XXXX' \
222 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
224 a5feed5f 2022-12-26 stsp echo -n "001fERR no git repository found" > $testroot/stdout.expected
226 a5feed5f 2022-12-26 stsp echo "gotsh: no git repository found" > $testroot/stderr.expected
228 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout
230 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
231 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
232 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
236 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
238 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
239 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
240 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
241 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
244 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
248 a5feed5f 2022-12-26 stsp # Repository with name of 255 symbols
249 a5feed5f 2022-12-26 stsp test_request_bad_large_repo_name() {
250 a5feed5f 2022-12-26 stsp local testroot=`test_init test_request_bad_large_repo_name`
252 9bd4acdb 2022-12-27 op # build a string of 255 "A": 63 "A" four times plus tree more "A"
253 9bd4acdb 2022-12-27 op local a=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
254 9bd4acdb 2022-12-27 op local repo_name="AAA$a$a$a$a"
256 9bd4acdb 2022-12-27 op echo "0054want $dummy_commit aaaaaaaaa bbbbbbbbbbbbb ccccccccc" \
257 9bd4acdb 2022-12-27 op | ssh ${GOTD_DEVUSER}@127.0.0.1 git-upload-pack "/$repo_name" \
258 9bd4acdb 2022-12-27 op > $testroot/stdout 2>$testroot/stderr
260 a5feed5f 2022-12-26 stsp echo -n "0018ERR buffer too small" > $testroot/stdout.expected
262 a5feed5f 2022-12-26 stsp echo "gotsh: buffer too small" > $testroot/stderr.expected
264 9bd4acdb 2022-12-27 op cmp -s $testroot/stdout.expected $testroot/stdout
266 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
267 a5feed5f 2022-12-26 stsp echo "unexpected stdout" >&2
268 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
272 9bd4acdb 2022-12-27 op cmp -s $testroot/stderr.expected $testroot/stderr
274 a5feed5f 2022-12-26 stsp if [ $ret -ne 0 ]; then
275 a5feed5f 2022-12-26 stsp echo "unexpected stderr" >&2
276 9bd4acdb 2022-12-27 op diff -u $testroot/stderr.expected $testroot/stderr
277 a5feed5f 2022-12-26 stsp test_done "$testroot" "1"
280 a5feed5f 2022-12-26 stsp test_done "$testroot" "$ret"
283 a5feed5f 2022-12-26 stsp test_parseargs "$@"
284 a5feed5f 2022-12-26 stsp run_test test_request_bad_commit
285 a5feed5f 2022-12-26 stsp run_test test_request_bad_length_zero
286 a5feed5f 2022-12-26 stsp run_test test_request_bad_length_empty
287 a5feed5f 2022-12-26 stsp run_test test_request_bad_length_small
288 a5feed5f 2022-12-26 stsp run_test test_request_bad_length_large
289 a5feed5f 2022-12-26 stsp run_test test_request_bad_capabilities
290 a5feed5f 2022-12-26 stsp run_test test_request_bad_repository
291 a5feed5f 2022-12-26 stsp run_test test_request_bad_large_repo_name