mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2024-12-12 14:35:14 +00:00
3a1b8ad1b5
http_reuse_be_transparent.vtc relies on "transparent" proxy option which is guarded by the USE_TPROXY ifdef at multiple places in the code. Hence, executing the above test when haproxy was compiled without the USE_TPROXY feature (ie: generic target) results in this kind of error: *** h1 debug|[NOTICE] (1189756) : haproxy version is 2.9-dev1-8fc21e-807 *** h1 debug|[NOTICE] (1189756) : path to executable is ./haproxy *** h1 debug|[ALERT] (1189756) : config : parsing [/tmp/vtc.1189751.18665e7b/h1/cfg:11]: option 'transparent' is not supported due to build options. *** h1 debug|[ALERT] (1189756) : config : Error(s) found in configuration file : /tmp/vtc.1189751.18665e7b/h1/cfg Now we skip the regtest if TPROXY feature is missing.
83 lines
1.9 KiB
Plaintext
83 lines
1.9 KiB
Plaintext
varnishtest "Test the proper interaction between http-reuse and backend in transparent mode"
|
|
feature cmd "$HAPROXY_PROGRAM -cc 'feature(TPROXY)'"
|
|
|
|
# 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
|
|
|