haproxy/reg-tests/connection/proxy_protocol_send_generic.vtc
Willy Tarreau 9d511b3c27 REGTESTS: enable -dW on almost all tests to fail on warnings
Now that warnings were almost all removed, let's enable zero-warning
via -dW. All tests were adjusted, but two:

  - mcli/mcli_start_progs.vtc:
      the programs section currently cannot be silenced

  - stats/stats-file.vtc:
      the warning comes from the stats file itself on comment lines.

All other ones are now OK.
2024-11-19 09:27:08 +01:00

73 lines
2.1 KiB
Plaintext

varnishtest "Check that generic TLV IDs are sent properly"
feature ignore_unknown_macro
haproxy h1 -arg '-dW' -conf {
defaults
mode http
log global
timeout connect "${HAPROXY_TEST_TIMEOUT-5s}"
timeout client "${HAPROXY_TEST_TIMEOUT-5s}"
timeout server "${HAPROXY_TEST_TIMEOUT-5s}"
listen sender
bind "fd@${feS}"
server example ${h1_feR_addr}:${h1_feR_port} send-proxy-v2 set-proxy-v2-tlv-fmt(0xE1) %[str("foo")] set-proxy-v2-tlv-fmt(0xE2)
listen receiver
bind "fd@${feR}" accept-proxy
# Check that the TLV value is set in the backend.
http-request set-var(txn.custom_tlv_a) fc_pp_tlv(0xE1)
http-after-response set-header proxy_custom_tlv_a %[var(txn.custom_tlv_a)]
# Check that TLVs without an value are sent out.
http-request set-var(txn.custom_tlv_b) fc_pp_tlv(0xE2)
http-after-response set-header proxy_custom_tlv_b %[var(txn.custom_tlv_b)]
# Note that we do not check for an invalid TLV ID as that would result in an
# parser error anyway.
http-request return status 200
} -start
client c1 -connect ${h1_feS_sock} {
txreq -url "/"
rxresp
expect resp.http.proxy_custom_tlv_a == "foo"
expect resp.http.proxy_custom_tlv_b == ""
} -run
# Ensure that we achieve the same via a default-server.
haproxy h2 -arg '-dW' -conf {
defaults
mode http
log global
timeout connect "${HAPROXY_TEST_TIMEOUT-5s}"
timeout client "${HAPROXY_TEST_TIMEOUT-5s}"
timeout server "${HAPROXY_TEST_TIMEOUT-5s}"
listen sender
bind "fd@${feS}"
default-server send-proxy-v2 set-proxy-v2-tlv-fmt(0xE1) %[str("bar")]
server example ${h1_feR_addr}:${h1_feR_port}
listen receiver
bind "fd@${feR}" accept-proxy
http-request set-var(txn.custom_tlv_a) fc_pp_tlv(0xE1)
http-after-response set-header proxy_custom_tlv_a %[var(txn.custom_tlv_a)]
http-request return status 200
} -start
client c2 -connect ${h2_feS_sock} {
txreq -url "/"
rxresp
expect resp.http.proxy_custom_tlv_a == "bar"
} -run