mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-08-15 19:46:57 +02:00
A better name was found for the option implemented inec74438
("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 withec74438
andf2838f5
("REGTESTS: fix lua-based regtests using tune.lua.smp-preserve-bool")
89 lines
2.1 KiB
Plaintext
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
|