haproxy/reg-tests/connection/http_reuse_be_transparent.vtc
Aurelien DARRAGON 3a1b8ad1b5 REGTESTS: connection: disable http_reuse_be_transparent.vtc if !TPROXY
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.
2023-11-24 16:27:55 +01:00

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