| varnishtest "If-Modified-Since support" |
| |
| #REQUIRE_VERSION=2.3 |
| |
| feature ignore_unknown_macro |
| |
| server s1 { |
| # Response containing a "Last-Modified" field |
| rxreq |
| expect req.url == "/last_modified" |
| txresp -nolen -hdr "Transfer-Encoding: chunked" \ |
| -hdr "Last-Modified: Thu, 15 Oct 2020 22:23:24 GMT" |
| chunkedlen 15 |
| chunkedlen 15 |
| chunkedlen 15 |
| chunkedlen 0 |
| |
| # Response containing a "Date" field |
| rxreq |
| expect req.url == "/date" |
| txresp -nolen -hdr "Transfer-Encoding: chunked" \ |
| -hdr "Date: Thu, 22 Oct 2020 16:51:12 GMT" \ |
| -hdr "Cache-Control: max-age=5" |
| chunkedlen 16 |
| chunkedlen 16 |
| chunkedlen 16 |
| chunkedlen 0 |
| |
| # Response containing both a "Last-Modified" and a "Date" fields |
| # Should behave the same way as if the "Date" field was not here. |
| rxreq |
| expect req.url == "/last_modified_and_date" |
| txresp -nolen -hdr "Transfer-Encoding: chunked" \ |
| -hdr "Last-Modified: Thu, 15 Oct 2020 14:24:38 GMT" \ |
| -hdr "Date: Thu, 22 Oct 2020 16:51:12 GMT" |
| chunkedlen 17 |
| chunkedlen 17 |
| chunkedlen 17 |
| chunkedlen 0 |
| } -start |
| |
| haproxy h1 -conf { |
| global |
| # WT: limit false-positives causing "HTTP header incomplete" due to |
| # idle server connections being randomly used and randomly expiring |
| # under us. |
| tune.idle-pool.shared off |
| |
| defaults |
| mode http |
| timeout connect "${HAPROXY_TEST_TIMEOUT-5s}" |
| timeout client "${HAPROXY_TEST_TIMEOUT-5s}" |
| timeout server "${HAPROXY_TEST_TIMEOUT-5s}" |
| |
| frontend fe |
| bind "fd@${fe}" |
| default_backend test |
| |
| backend test |
| http-request cache-use my_cache |
| server www ${s1_addr}:${s1_port} |
| http-response cache-store my_cache |
| |
| cache my_cache |
| total-max-size 3 |
| max-age 20 |
| max-object-size 3072 |
| } -start |
| |
| |
| client c1 -connect ${h1_fe_sock} { |
| txreq -url "/last_modified" |
| rxresp |
| expect resp.status == 200 |
| expect resp.bodylen == 45 |
| |
| txreq -url "/date" |
| rxresp |
| expect resp.status == 200 |
| expect resp.bodylen == 48 |
| |
| txreq -url "/last_modified_and_date" |
| rxresp |
| expect resp.status == 200 |
| expect resp.bodylen == 51 |
| |
| |
| # Earlier date |
| # "Last-Modified" version |
| txreq -url "/last_modified" \ |
| -hdr "If-Modified-Since: Thu, 15 Oct 2020 00:00:01 GMT" |
| rxresp |
| expect resp.status == 200 |
| expect resp.bodylen == 45 |
| # "Date" version |
| txreq -url "/date" \ |
| -hdr "If-Modified-Since: Thu, 01 Oct 2020 00:00:01 GMT" |
| rxresp |
| expect resp.status == 200 |
| expect resp.bodylen == 48 |
| # "Last-Modified" and "Date" version |
| txreq -url "/last_modified_and_date" \ |
| -hdr "If-Modified-Since: Thu, 15 Oct 2020 00:00:01 GMT" |
| rxresp |
| expect resp.status == 200 |
| expect resp.bodylen == 51 |
| |
| |
| # Same date |
| # "Last-Modified" version |
| txreq -url "/last_modified" \ |
| -hdr "If-Modified-Since: Thu, 15 Oct 2020 22:23:24 GMT" |
| rxresp |
| expect resp.status == 304 |
| expect resp.bodylen == 0 |
| # "Date" version |
| txreq -url "/date" \ |
| -hdr "If-Modified-Since: Thu, 22 Oct 2020 16:51:12 GMT" |
| rxresp |
| expect resp.status == 304 |
| expect resp.bodylen == 0 |
| # "Last-Modified" and "Date" version |
| txreq -url "/last_modified_and_date" \ |
| -hdr "If-Modified-Since: Thu, 15 Oct 2020 16:51:12 GMT" |
| rxresp |
| expect resp.status == 304 |
| expect resp.bodylen == 0 |
| |
| |
| # Later date |
| # "Last-Modified" version |
| txreq -url "/last_modified" \ |
| -hdr "If-Modified-Since: Thu, 22 Oct 2020 23:00:00 GMT" |
| rxresp |
| expect resp.status == 304 |
| expect resp.bodylen == 0 |
| # "Date" version |
| txreq -url "/date" \ |
| -hdr "If-Modified-Since: Thu, 22 Oct 2020 23:00:00 GMT" |
| rxresp |
| expect resp.status == 304 |
| expect resp.bodylen == 0 |
| # "Last-Modified" and "Date" version |
| txreq -url "/last_modified_and_date" \ |
| -hdr "If-Modified-Since: Thu, 22 Oct 2020 23:00:00 GMT" |
| rxresp |
| expect resp.status == 304 |
| expect resp.bodylen == 0 |
| |
| } -run |
| |