mirror of
https://github.com/curl/curl.git
synced 2026-04-13 00:31:41 +08:00
Use `data->progress.now` as the timestamp of proecssing a transfer. Update it on significant events and refrain from calling `curlx_now()` in many places. The problem this addresses is a) calling curlx_now() has costs, depending on platform. Calling it every time results in 25% increase `./runtest` duration on macOS. b) we used to pass a `struct curltime *` around to save on calls, but when some method directly use `curx_now()` and some use the passed pointer, the transfer experienes non-linear time. This results in timeline checks to report events in the wrong order. By keeping a timestamp in the easy handle and updating it there, no longer invoking `curlx_now()` in the "lower" methods, the transfer can observer a steady clock progression. Add documentation in docs/internals/TIME-KEEPING.md Reported-by: Viktor Szakats Fixes #19935 Closes #19961
80 lines
1.3 KiB
XML
80 lines
1.3 KiB
XML
<?xml version="1.0" encoding="US-ASCII"?>
|
|
<testcase>
|
|
<info>
|
|
<keywords>
|
|
HTTP
|
|
HTTP GET
|
|
HTTP/3
|
|
</keywords>
|
|
</info>
|
|
|
|
# Server-side
|
|
<reply>
|
|
<data crlf="headers" nocheck="yes">
|
|
HTTP/1.1 200 OK
|
|
Date: Tue, 09 Nov 2010 14:49:00 GMT
|
|
Last-Modified: Tue, 13 Jun 2000 12:10:00 GMT
|
|
ETag: "21025-dc7-39462498"
|
|
Accept-Ranges: bytes
|
|
Content-Length: 6
|
|
Connection: close
|
|
Content-Type: text/html
|
|
Funny-head: yesyes
|
|
|
|
-foo-
|
|
</data>
|
|
</reply>
|
|
|
|
# Client-side
|
|
<client>
|
|
<features>
|
|
http/3
|
|
nghttpx-h3
|
|
</features>
|
|
<server>
|
|
http/3
|
|
</server>
|
|
<name>
|
|
HTTP/3 GET:
|
|
</name>
|
|
<command>
|
|
--cacert %CERTDIR/certs/test-ca.crt --http3 --resolve localhost:%HTTP3PORT:%HOSTIP https://localhost:%HTTP3PORT/%TESTNUMBER
|
|
</command>
|
|
</client>
|
|
|
|
# Verify data after the test has been "shot"
|
|
<verify>
|
|
<strip>
|
|
^X-Forwarded-Proto:.*
|
|
^Via:.*
|
|
</strip>
|
|
<protocol crlf="headers">
|
|
GET https://localhost:%HTTP3PORT/%TESTNUMBER HTTP/1.1
|
|
Host: localhost:%HTTP3PORT
|
|
User-Agent: curl/%VERSION
|
|
Accept: */*
|
|
|
|
</protocol>
|
|
<stdout crlf="headers">
|
|
HTTP/3 200%SP
|
|
date: Tue, 09 Nov 2010 14:49:00 GMT
|
|
last-modified: Tue, 13 Jun 2000 12:10:00 GMT
|
|
etag: "21025-dc7-39462498"
|
|
accept-ranges: bytes
|
|
content-length: 6
|
|
content-type: text/html
|
|
funny-head: yesyes
|
|
via: 1.1 nghttpx
|
|
|
|
-foo-
|
|
</stdout>
|
|
<stripfile>
|
|
s/^server: nghttpx.*\r?\n//
|
|
</stripfile>
|
|
<limits>
|
|
Allocations: 155
|
|
Maximum allocated: 1800000
|
|
</limits>
|
|
</verify>
|
|
</testcase>
|