remote-curl: use post_rpc() for protocol v2 also
When transmitting and receiving POSTs for protocol v0 and v1, remote-curl uses post_rpc() (and associated functions), but when doing the same for protocol v2, it uses a separate set of functions (proxy_rpc() and others). Besides duplication of code, this has caused at least one bug: the auth retry mechanism that was implemented in v0/v1 was not implemented in v2. To fix this issue and avoid it in the future, make remote-curl also use post_rpc() when handling protocol v2. Because line lengths are written to the HTTP request in protocol v2 (unlike in protocol v0/v1), this necessitates changes in post_rpc() and some of the functions it uses; perform these changes too. A test has been included to ensure that the code for both the unchunked and chunked variants of the HTTP request is exercised. Note: stateless_connect() has been updated to use the lower-level packet reading functions instead of struct packet_reader. The low-level control is necessary here because we cannot change the destination buffer of struct packet_reader while it is being used; struct packet_buffer has a peeking mechanism which relies on the destination buffer being present in between a peek and a read. Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
78ad91728d
commit
a97d00799a
@ -542,7 +542,38 @@ test_expect_success 'clone with http:// using protocol v2' '
|
||||
# Client requested to use protocol v2
|
||||
grep "Git-Protocol: version=2" log &&
|
||||
# Server responded using protocol v2
|
||||
grep "git< version 2" log
|
||||
grep "git< version 2" log &&
|
||||
# Verify that the chunked encoding sending codepath is NOT exercised
|
||||
! grep "Send header: Transfer-Encoding: chunked" log
|
||||
'
|
||||
|
||||
test_expect_success 'clone big repository with http:// using protocol v2' '
|
||||
test_when_finished "rm -f log" &&
|
||||
|
||||
git init "$HTTPD_DOCUMENT_ROOT_PATH/big" &&
|
||||
# Ensure that the list of wants is greater than http.postbuffer below
|
||||
for i in $(test_seq 1 1500)
|
||||
do
|
||||
# do not use here-doc, because it requires a process
|
||||
# per loop iteration
|
||||
echo "commit refs/heads/too-many-refs-$i" &&
|
||||
echo "committer git <git@example.com> $i +0000" &&
|
||||
echo "data 0" &&
|
||||
echo "M 644 inline bla.txt" &&
|
||||
echo "data 4" &&
|
||||
echo "bla"
|
||||
done | git -C "$HTTPD_DOCUMENT_ROOT_PATH/big" fast-import &&
|
||||
|
||||
GIT_TRACE_PACKET="$(pwd)/log" GIT_TRACE_CURL="$(pwd)/log" git \
|
||||
-c protocol.version=2 -c http.postbuffer=65536 \
|
||||
clone "$HTTPD_URL/smart/big" big_child &&
|
||||
|
||||
# Client requested to use protocol v2
|
||||
grep "Git-Protocol: version=2" log &&
|
||||
# Server responded using protocol v2
|
||||
grep "git< version 2" log &&
|
||||
# Verify that the chunked encoding sending codepath is exercised
|
||||
grep "Send header: Transfer-Encoding: chunked" log
|
||||
'
|
||||
|
||||
test_expect_success 'fetch with http:// using protocol v2' '
|
||||
|
Reference in New Issue
Block a user