REGTESTS: test http-reuse if no server target
Add two new regtests which check the behavior of http-reuse when the connection target is not a server. More specifically check the dispatch and transparent backend. In these cases, the behavior should be similar to http-reuse never mode.
This commit is contained in:
parent
8ede3db080
commit
a47dfab673
81
reg-tests/connection/http_reuse_be_transparent.vtc
Normal file
81
reg-tests/connection/http_reuse_be_transparent.vtc
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
varnishtest "Test the proper interaction between http-reuse and backend in transparent mode"
|
||||||
|
|
||||||
|
# If backend is used with the transparent mode, the connection are considered
|
||||||
|
# as private and should only be reused for requests of the same session.
|
||||||
|
# This is similar to the http-reuse never mode
|
||||||
|
|
||||||
|
#REQUIRE_VERSION=2.4
|
||||||
|
|
||||||
|
feature ignore_unknown_macro
|
||||||
|
|
||||||
|
haproxy h1 -conf {
|
||||||
|
defaults
|
||||||
|
mode http
|
||||||
|
|
||||||
|
listen sender
|
||||||
|
bind "fd@${feS}"
|
||||||
|
http-request set-header client-id %[req.hdr(client-id)] if { req.hdr(client-id) -m found }
|
||||||
|
option transparent
|
||||||
|
http-request set-dst-port int(${h1_feR_port})
|
||||||
|
|
||||||
|
listen receiver
|
||||||
|
bind "fd@${feR}"
|
||||||
|
http-request set-var(sess.client_id) req.hdr(client-id)
|
||||||
|
http-request return status 200
|
||||||
|
http-after-response set-header http_first_request %[http_first_req]
|
||||||
|
http-after-response set-header client-id %[var(sess.client_id)]
|
||||||
|
} -start
|
||||||
|
|
||||||
|
client c1 -connect ${h1_feS_sock} {
|
||||||
|
txreq \
|
||||||
|
-hdr "client-id: c1"
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "1"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c1"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c1"
|
||||||
|
} -run
|
||||||
|
|
||||||
|
client c2 -connect ${h1_feS_sock} {
|
||||||
|
txreq \
|
||||||
|
-hdr "client-id: c2"
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "1"
|
||||||
|
expect resp.http.client-id == "c2"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c2"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c2"
|
||||||
|
} -run
|
||||||
|
|
||||||
|
client c3 -connect ${h1_feS_sock} {
|
||||||
|
txreq \
|
||||||
|
-hdr "client-id: c3"
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "1"
|
||||||
|
expect resp.http.client-id == "c3"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c3"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c3"
|
||||||
|
} -run
|
||||||
|
|
79
reg-tests/connection/http_reuse_dispatch.vtc
Normal file
79
reg-tests/connection/http_reuse_dispatch.vtc
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
varnishtest "Test the proper interaction between http-reuse and dispatch mode"
|
||||||
|
|
||||||
|
# With dispatch, the connection are considered as private and should only be
|
||||||
|
# reused for requests of the same session
|
||||||
|
# This is similar to the http-reuse never mode
|
||||||
|
|
||||||
|
#REQUIRE_VERSION=2.4
|
||||||
|
|
||||||
|
feature ignore_unknown_macro
|
||||||
|
|
||||||
|
haproxy h1 -conf {
|
||||||
|
defaults
|
||||||
|
mode http
|
||||||
|
|
||||||
|
listen sender
|
||||||
|
bind "fd@${feS}"
|
||||||
|
http-request set-header client-id %[req.hdr(client-id)] if { req.hdr(client-id) -m found }
|
||||||
|
dispatch ${h1_feR_addr}:${h1_feR_port}
|
||||||
|
|
||||||
|
listen receiver
|
||||||
|
bind "fd@${feR}"
|
||||||
|
http-request set-var(sess.client_id) req.hdr(client-id)
|
||||||
|
http-request return status 200
|
||||||
|
http-after-response set-header http_first_request %[http_first_req]
|
||||||
|
http-after-response set-header client-id %[var(sess.client_id)]
|
||||||
|
} -start
|
||||||
|
|
||||||
|
client c1 -connect ${h1_feS_sock} {
|
||||||
|
txreq \
|
||||||
|
-hdr "client-id: c1"
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "1"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c1"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c1"
|
||||||
|
} -run
|
||||||
|
|
||||||
|
client c2 -connect ${h1_feS_sock} {
|
||||||
|
txreq \
|
||||||
|
-hdr "client-id: c2"
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "1"
|
||||||
|
expect resp.http.client-id == "c2"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c2"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c2"
|
||||||
|
} -run
|
||||||
|
|
||||||
|
client c3 -connect ${h1_feS_sock} {
|
||||||
|
txreq \
|
||||||
|
-hdr "client-id: c3"
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "1"
|
||||||
|
expect resp.http.client-id == "c3"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c3"
|
||||||
|
|
||||||
|
txreq
|
||||||
|
rxresp
|
||||||
|
expect resp.http.http_first_request == "0"
|
||||||
|
expect resp.http.client-id == "c3"
|
||||||
|
} -run
|
Loading…
x
Reference in New Issue
Block a user