mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2024-12-20 10:40:13 +00:00
1dcc6a8a96
Previously an expression like: path,word(2,/) -m found always returned `true`. Bug exists since the `word` converter exists. That is:c9a0f6d023
The same bug was previously fixed for the `field` converter in commit4381d26edc
. The fix should be backported to 1.6+.
44 lines
905 B
Plaintext
44 lines
905 B
Plaintext
varnishtest "word converter Test"
|
|
|
|
feature ignore_unknown_macro
|
|
|
|
server s1 {
|
|
rxreq
|
|
txresp -hdr "Connection: close"
|
|
} -repeat 3 -start
|
|
|
|
haproxy h1 -conf {
|
|
defaults
|
|
mode http
|
|
timeout connect "${HAPROXY_TEST_TIMEOUT-5s}"
|
|
timeout client "${HAPROXY_TEST_TIMEOUT-5s}"
|
|
timeout server "${HAPROXY_TEST_TIMEOUT-5s}"
|
|
|
|
frontend fe
|
|
bind "fd@${fe}"
|
|
|
|
#### requests
|
|
http-request set-var(txn.uri) path
|
|
http-response set-header Found %[var(txn.uri),word(2,/)] if { var(txn.uri),word(2,/) -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//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
|