mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-08-07 15:47:01 +02:00
BUG/MINOR: sample: Make the field
converter compatible with -m found
Previously an expression like:
path,field(2,/) -m found
always returned `true`.
Bug exists since the `field` converter exists. That is:
f399b0debf
The fix should be backported to 1.6+.
This commit is contained in:
parent
d1d1e22945
commit
4381d26edc
39
reg-tests/converter/field.vtc
Normal file
39
reg-tests/converter/field.vtc
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
varnishtest "field converter Test"
|
||||||
|
|
||||||
|
feature ignore_unknown_macro
|
||||||
|
|
||||||
|
server s1 {
|
||||||
|
rxreq
|
||||||
|
txresp
|
||||||
|
} -repeat 3 -start
|
||||||
|
|
||||||
|
haproxy h1 -conf {
|
||||||
|
defaults
|
||||||
|
mode http
|
||||||
|
timeout connect 1s
|
||||||
|
timeout client 1s
|
||||||
|
timeout server 1s
|
||||||
|
|
||||||
|
frontend fe
|
||||||
|
bind "fd@${fe}"
|
||||||
|
|
||||||
|
#### requests
|
||||||
|
http-request set-var(txn.uri) path
|
||||||
|
http-response set-header Found %[var(txn.uri),field(3,/)] if { var(txn.uri),field(3,/) -m found }
|
||||||
|
|
||||||
|
default_backend be
|
||||||
|
|
||||||
|
backend be
|
||||||
|
server s1 ${s1_addr}:${s1_port}
|
||||||
|
} -start
|
||||||
|
|
||||||
|
client c1 -connect ${h1_fe_sock} {
|
||||||
|
txreq -url "/foo/bar/baz"
|
||||||
|
rxresp
|
||||||
|
expect resp.status == 200
|
||||||
|
expect resp.http.found == "bar"
|
||||||
|
txreq -url "/foo"
|
||||||
|
rxresp
|
||||||
|
expect resp.status == 200
|
||||||
|
expect resp.http.found == "<undef>"
|
||||||
|
} -run
|
@ -2137,7 +2137,7 @@ static int sample_conv_field(const struct arg *arg_p, struct sample *smp, void *
|
|||||||
/* Field not found */
|
/* Field not found */
|
||||||
if (field != arg_p[0].data.sint) {
|
if (field != arg_p[0].data.sint) {
|
||||||
smp->data.u.str.data = 0;
|
smp->data.u.str.data = 0;
|
||||||
return 1;
|
return 0;
|
||||||
}
|
}
|
||||||
found:
|
found:
|
||||||
smp->data.u.str.data = end - start;
|
smp->data.u.str.data = end - start;
|
||||||
|
Loading…
Reference in New Issue
Block a user