commit - abe844e2dfc7056150889993b3568fe400af7358
commit + 6da1c69cd7747c70dfbe29c9fb66fa03fa985459
blob - 2b98e5b861a9809ce19718d8a1895fa536f61c7f
blob + 356daf210a6e33f99485b698040f4993bd37d9d3
--- gotd/session.c
+++ gotd/session.c
err = forward_want(client, &imsg);
break;
case GOTD_IMSG_REF_UPDATE:
- if (client->state != GOTD_STATE_EXPECT_REF_UPDATE) {
+ if (client->state != GOTD_STATE_EXPECT_REF_UPDATE &&
+ client->state !=
+ GOTD_STATE_EXPECT_MORE_REF_UPDATES) {
err = got_error_msg(GOT_ERR_BAD_REQUEST,
"unexpected ref-update-line received");
break;
blob - 2a84d048566d5046d46563c82ea71b7b67015c5c
blob + cb89c0c20a28919ad7363ff1bba5419fdad3c7f1
--- regress/gotd/repo_write.sh
+++ regress/gotd/repo_write.sh
test_send_basic() {
local testroot=`test_init send_basic 1`
- ls -R ${GOTD_TEST_REPO} > $testroot/repo-list.before
+ ls -R ${GOTD_TEST_REPO}/objects/pack > $testroot/repo-list.before
got clone -q ${GOTD_TEST_REPO_URL} $testroot/repo-clone
ret=$?
test_done "$testroot" "1"
return 1
fi
+ # same for Git
+ git clone -q ${GOTD_TEST_REPO_URL} $testroot/repo-clone3 \
+ >$testroot/stdout 2>$testroot/stderr
+ ret=$?
+ if [ $ret -ne 0 ]; then
+ echo "git clone failed unexpectedly" >&2
+ test_done "$testroot" "1"
+ return 1
+ fi
got checkout -q $testroot/repo-clone $testroot/wt >/dev/null
ret=$?
(cd $testroot/wt && got add psi/new > /dev/null)
echo "more alpha" >> $testroot/wt/alpha
(cd $testroot/wt && got commit -m 'make changes' > /dev/null)
+ (cd $testroot/wt && got branch newbranch >/dev/null)
+ echo "even more alpha" >> $testroot/wt/alpha
+ (cd $testroot/wt && got commit -m 'more changes' > /dev/null)
+ got tag -r $testroot/repo-clone -m "tagging 1.0" 1.0 >/dev/null
- got send -q -r $testroot/repo-clone
+ got send -b main -b newbranch -q -r $testroot/repo-clone -t 1.0
ret=$?
if [ $ret -ne 0 ]; then
echo "got send failed unexpectedly" >&2
return 1
fi
+ # Verify that git pull works, too
+ (cd $testroot/repo-clone3 && git pull -q > $testroot/stdout \
+ 2> $testroot/stderr)
+ ret=$?
+ if [ $ret -ne 0 ]; then
+ echo "git pull failed unexpectedly" >&2
+ test_done "$testroot" "1"
+ return 1
+ fi
+
# sending to a repository should result in a new pack file
- ls -R ${GOTD_TEST_REPO} > $testroot/repo-list.after
+ ls -R ${GOTD_TEST_REPO}/objects/pack > $testroot/repo-list.after
diff -u $testroot/repo-list.before $testroot/repo-list.after \
> $testroot/repo-list.diff
grep '^+[^+]' < $testroot/repo-list.diff > $testroot/repo-list.newlines
nplus=`wc -l < $testroot/repo-list.newlines | tr -d ' '`
if [ "$nplus" != "2" ]; then
- echo "$nplus new files created"
+ echo "$nplus new files created:"
+ cat $testroot/repo-list.diff
test_done "$testroot" "$ret"
return 1
fi