blob: 42f87f19f0fab9c73a4d680ac6033a9e9b9731e5 [file] [log] [blame]
Christopher Faulet16b37512021-04-07 14:37:07 +02001varnishtest "A test for the abortonclose option (H1 only)"
2feature ignore_unknown_macro
3
4# NOTE : This test may fail if too many vtest are running in parallel because
5# the port reserved for closed s1 server may be reused by another vtest
6
Tim Duesterhus5efc48d2021-06-11 19:56:15 +02007feature cmd "$HAPROXY_PROGRAM -cc 'version_atleast(2.5-dev0)'"
Christopher Faulet16b37512021-04-07 14:37:07 +02008#REGTEST_TYPE=slow
9
10# b1 : Don't send /c4 before /c3 was received by s2 server
11# b2 : Don't finish c2 before c1 and c3 before c4 (from syslog POV)
12# b3 : finish c3 before s2
13
14barrier b1 cond 2 -cyclic
15barrier b2 cond 2 -cyclic
16barrier b3 cond 2 -cyclic
17
18server s1 {
19} -start
20server s1 -break
21
22server s2 {
23 rxreq
24
25 # unlock c4
26 barrier b1 sync
27
28 # wait end of c3
29 barrier b3 sync
30
31 expect_close
32} -start
33
34syslog S -level info {
35 recv
36 expect ~ "[^:\\[ ]*\\[[0-9]*\\]: .* .* fe1 be1/srv1 [0-9]*/[0-9]*/-1/-1/[0-9]* 503 .* - - SC-- .* .* \"GET /c1 HTTP/1\\.1\""
37 barrier b2 sync
38 recv
Christopher Faulet3b9cb602021-06-02 17:23:47 +020039 expect ~ "[^:\\[ ]*\\[[0-9]*\\]: .* .* fe1 be1/srv1 [0-9]*/[0-9]*/-1/-1/[0-9]* -1 .* - - CC-- .* .* \"GET /c2 HTTP/1\\.1\""
Christopher Faulet16b37512021-04-07 14:37:07 +020040
41 recv
Christopher Faulet3b9cb602021-06-02 17:23:47 +020042 expect ~ "[^:\\[ ]*\\[[0-9]*\\]: .* .* fe2 be2/<NOSRV> [0-9]*/[0-9]*/-1/-1/[0-9]* -1 .* - - CQ-- .* .* \"GET /c4 HTTP/1\\.1\""
Christopher Faulet16b37512021-04-07 14:37:07 +020043 barrier b2 sync
44 recv
45 expect ~ "[^:\\[ ]*\\[[0-9]*\\]: .* .* fe2 be2/srv1 [0-9]*/[0-9]*/[0-9]*/-1/[0-9]* 400 .* - - CH-- .* .* \"GET /c3 HTTP/1\\.1\""
46} -start
47
48haproxy h1 -conf {
Willy Tarreaue1465c12021-05-09 14:41:41 +020049 global
50 # WT: limit false-positives causing "HTTP header incomplete" due to
51 # idle server connections being randomly used and randomly expiring
52 # under us.
53 tune.idle-pool.shared off
54
Christopher Faulet16b37512021-04-07 14:37:07 +020055 defaults
56 mode http
Christopher Faulet16b37512021-04-07 14:37:07 +020057 option abortonclose
Willy Tarreau419c1172021-11-18 17:15:59 +010058 retries 1
Christopher Faulet16b37512021-04-07 14:37:07 +020059 timeout client 10s
60 timeout server 10s
61 timeout connect 100ms
62 timeout queue 5s
63
64 frontend fe1
65 option httplog
66 log ${S_addr}:${S_port} local0 debug err
67 bind "fd@${fe1}"
68 use_backend be1
69
70 frontend fe2
71 option httplog
72 log ${S_addr}:${S_port} local0 debug err
73 bind "fd@${fe2}"
74 use_backend be2
75
76 backend be1
77 server srv1 ${s1_addr}:${s1_port}
78
79 backend be2
80 server srv1 ${s2_addr}:${s2_port} maxconn 1
81} -start
82
83# No server, wait all connection retries : SC--
84client c1 -connect ${h1_fe1_sock} {
85 txreq -url /c1
Willy Tarreau1713eec2021-08-20 11:12:47 +020086 rxresp
87 expect resp.status == 503
Christopher Faulet16b37512021-04-07 14:37:07 +020088} -run
89
90# Wait c1 log entry
91barrier b2 sync
92
93# No server, abort during connections retries : CC--
94client c2 -connect ${h1_fe1_sock} {
95 txreq -url /c2
96} -run
97
98# server with maxconn=1, abort waiting the server reply : CH--
99client c3 -connect ${h1_fe2_sock} {
100 txreq -url /c3
101
102 # Wait c4 log entry
103 barrier b2 sync
104} -start
105
106# server with maxconn=1, abort waiting in the queue (c3 still attached) : CQ--
107client c4 -connect ${h1_fe2_sock} {
108 # Wait s2 receives c3 request
109 barrier b1 sync
110
111 txreq -url /c4
112 delay .2
113} -run
114
115client c3 -wait
116
117# unlock s2
118barrier b3 sync
119
120syslog S -wait