haproxy/reg-tests/lua/set_var.vtc
Aurelien DARRAGON 29b6d8af16 MINOR: hlua: rename "tune.lua.preserve-smp-bool" to "tune.lua.bool-sample-conversion"
A better name was found for the option implemented in ec74438
("MINOR: hlua: add option to preserve bool type from smp to lua")

Indeed, "tune.lua.preserve-smp-bool {on | off}" wasn't explicit enough
nor did it encourage the adoption of the new "fixed" behavior (vs
historical behavior which is now considered as a bug).

Thus it becomes "tune.lua.bool-sample-conversion { normal | pre-3.1-bug }"
which actively encourage users to switch the new behavior after having
patched in-use Lua script if needed. From a technical point of view,
the logic remains the same, as the option currently defaults to
"pre-3.1-bug" to prevent script breakage, and a warning is emitted if
the option isn't set explicily and Lua is used.

Documentation and regtests were updated.

Must be backported in 3.1 with ec74438 and f2838f5 ("REGTESTS: fix
lua-based regtests using tune.lua.smp-preserve-bool")
2024-12-20 17:34:05 +01:00

89 lines
2.1 KiB
Plaintext

varnishtest "Lua: set_var"
#REQUIRE_OPTIONS=LUA
feature ignore_unknown_macro
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
global
tune.lua.bool-sample-conversion normal
lua-load ${testdir}/set_var.lua
defaults
timeout client 30s
timeout server 30s
timeout connect 30s
frontend fe1
mode http
bind "fd@${fe1}"
http-request use-service lua.set_var
frontend fe2
mode http
bind "fd@${fe2}"
# just make sure the variable exists
http-request set-header Dummy %[var(proc.fe2_foo)]
http-request use-service lua.set_var_ifexist
} -start
client c0 -connect ${h1_fe1_sock} {
# create var
txreq -url "/" \
-hdr "Var: txn.fe1_foo"
rxresp
expect resp.status == 202
expect resp.http.echo == "value"
# rewrite var
txreq -url "/" \
-hdr "Var: txn.fe1_foo"
rxresp
expect resp.status == 202
expect resp.http.echo == "value"
# create var under scope "proc"
txreq -url "/" \
-hdr "Var: proc.fe1_foo"
rxresp
expect resp.status == 202
expect resp.http.echo == "value"
# fail to create bad scope
txreq -url "/" \
-hdr "Var: invalid.var"
rxresp
expect resp.status == 400
expect resp.http.echo == "(nil)"
} -run
client c1 -connect ${h1_fe2_sock} {
# this one exists in the conf, it must succeed
txreq -url "/" \
-hdr "Var: proc.fe2_foo"
rxresp
expect resp.status == 202
expect resp.http.echo == "value"
# this one does not exist in the conf, it must fail
txreq -url "/" \
-hdr "Var: proc.fe2_bar"
rxresp
expect resp.status == 400
expect resp.http.echo == "(nil)"
# this one is under txn, it must succeed
txreq -url "/" \
-hdr "Var: txn.fe2_foo"
rxresp
expect resp.status == 202
expect resp.http.echo == "value"
} -run