t_cbq.sh revision 1.1 1 1.1 ozaki # $NetBSD: t_cbq.sh,v 1.1 2021/07/14 03:22:33 ozaki-r Exp $
2 1.1 ozaki #
3 1.1 ozaki # Copyright (c) 2021 Internet Initiative Japan Inc.
4 1.1 ozaki # All rights reserved.
5 1.1 ozaki #
6 1.1 ozaki # Redistribution and use in source and binary forms, with or without
7 1.1 ozaki # modification, are permitted provided that the following conditions
8 1.1 ozaki # are met:
9 1.1 ozaki # 1. Redistributions of source code must retain the above copyright
10 1.1 ozaki # notice, this list of conditions and the following disclaimer.
11 1.1 ozaki # 2. Redistributions in binary form must reproduce the above copyright
12 1.1 ozaki # notice, this list of conditions and the following disclaimer in the
13 1.1 ozaki # documentation and/or other materials provided with the distribution.
14 1.1 ozaki #
15 1.1 ozaki # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
16 1.1 ozaki # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17 1.1 ozaki # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18 1.1 ozaki # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
19 1.1 ozaki # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 1.1 ozaki # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 1.1 ozaki # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 1.1 ozaki # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 1.1 ozaki # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 1.1 ozaki # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 1.1 ozaki # POSSIBILITY OF SUCH DAMAGE.
26 1.1 ozaki #
27 1.1 ozaki
28 1.1 ozaki SOCK_LOCAL=unix://altq_local
29 1.1 ozaki SOCK_REMOTE=unix://altq_remote
30 1.1 ozaki BUS=bus_altq
31 1.1 ozaki TIMEOUT=3
32 1.1 ozaki
33 1.1 ozaki # rumphijack can't handle AF_LOCAL socket (/var/run/altq_quip) correctly,
34 1.1 ozaki # so use the socket via the host.
35 1.1 ozaki HIJACKING_ALTQ="$HIJACKING,blanket=/dev/altq/altq:/dev/altq/cbq:/etc/altq.conf:/var/run/altqd.pid"
36 1.1 ozaki
37 1.1 ozaki DEBUG=${DEBUG:-false}
38 1.1 ozaki
39 1.1 ozaki IP_LOCAL1=10.0.0.1
40 1.1 ozaki IP_LOCAL2=10.0.1.1
41 1.1 ozaki IP_REMOTE11=10.0.0.2
42 1.1 ozaki IP_REMOTE12=10.0.0.22
43 1.1 ozaki IP_REMOTE21=10.0.1.2
44 1.1 ozaki IP_REMOTE22=10.0.1.22
45 1.1 ozaki ALTQD_PIDFILE=./pid
46 1.1 ozaki
47 1.1 ozaki
48 1.1 ozaki start_altqd_basic()
49 1.1 ozaki {
50 1.1 ozaki
51 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
52 1.1 ozaki
53 1.1 ozaki $HIJACKING_ALTQ mkdir -p /rump/etc
54 1.1 ozaki $HIJACKING_ALTQ mkdir -p /rump/var/run
55 1.1 ozaki
56 1.1 ozaki cat > ./altq.conf <<-EOF
57 1.1 ozaki interface shmif0 cbq
58 1.1 ozaki class cbq shmif0 root_class NULL pbandwidth 100
59 1.1 ozaki class cbq shmif0 normal_class root_class pbandwidth 50 default
60 1.1 ozaki filter shmif0 normal_class $IP_REMOTE11 0 0 0 0
61 1.1 ozaki class cbq shmif0 drop_class root_class pbandwidth 0
62 1.1 ozaki filter shmif0 drop_class $IP_REMOTE12 0 0 0 0
63 1.1 ozaki EOF
64 1.1 ozaki $DEBUG && cat ./altq.conf
65 1.1 ozaki atf_check -s exit:0 $HIJACKING_ALTQ cp ./altq.conf /rump/etc/altq.conf
66 1.1 ozaki $HIJACKING_ALTQ test -f /rump/etc/altq.conf
67 1.1 ozaki
68 1.1 ozaki #atf_check -s exit:0 $HIJACKING_ALTQ altqd
69 1.1 ozaki $HIJACKING_ALTQ altqd
70 1.1 ozaki
71 1.1 ozaki $HIJACKING_ALTQ test -f /var/run/altqd.pid
72 1.1 ozaki if [ $? != 0 ]; then
73 1.1 ozaki atf_check -s exit:0 $HIJACKING_ALTQ altqd -d
74 1.1 ozaki # Should abort
75 1.1 ozaki fi
76 1.1 ozaki
77 1.1 ozaki $HIJACKING_ALTQ cat /var/run/altqd.pid > $ALTQD_PIDFILE
78 1.1 ozaki
79 1.1 ozaki $DEBUG && $HIJACKING_ALTQ altqstat -s
80 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 >./out
81 1.1 ozaki $DEBUG && cat ./out
82 1.1 ozaki atf_check -s exit:0 \
83 1.1 ozaki -o match:"altqstat: cbq on interface shmif0" \
84 1.1 ozaki -o match:'Class 1 on Interface shmif0: root_class' \
85 1.1 ozaki -o match:'Class 2 on Interface shmif0: normal_class' \
86 1.1 ozaki -o match:'Class 3 on Interface shmif0: ctl_class' \
87 1.1 ozaki -o match:'Class 4 on Interface shmif0: drop_class' \
88 1.1 ozaki cat ./out
89 1.1 ozaki rm -f ./out
90 1.1 ozaki }
91 1.1 ozaki
92 1.1 ozaki shutdown_altqd()
93 1.1 ozaki {
94 1.1 ozaki local pid="$(cat $ALTQD_PIDFILE)"
95 1.1 ozaki
96 1.1 ozaki if [ -n "$pid" ]; then
97 1.1 ozaki pgrep -x altqd | grep -q $pid
98 1.1 ozaki if [ $? = 0 ]; then
99 1.1 ozaki kill $(cat $ALTQD_PIDFILE)
100 1.1 ozaki sleep 1
101 1.1 ozaki fi
102 1.1 ozaki $DEBUG && pgrep -x altqd
103 1.1 ozaki fi
104 1.1 ozaki }
105 1.1 ozaki
106 1.1 ozaki check_counter()
107 1.1 ozaki {
108 1.1 ozaki local file=$1
109 1.1 ozaki local name=$2
110 1.1 ozaki local match="$3"
111 1.1 ozaki
112 1.1 ozaki grep -A 8 ${name}_class $file > $file.$name
113 1.1 ozaki atf_check -s exit:0 -o match:"$match" cat $file.$name
114 1.1 ozaki rm -f $file.$name
115 1.1 ozaki }
116 1.1 ozaki
117 1.1 ozaki test_altq_cbq_basic_ipv4()
118 1.1 ozaki {
119 1.1 ozaki local ifconfig="atf_check -s exit:0 rump.ifconfig"
120 1.1 ozaki local ping="atf_check -s exit:0 -o ignore rump.ping"
121 1.1 ozaki local opts="-q -c 1 -w 1"
122 1.1 ozaki
123 1.1 ozaki rump_server_fs_start $SOCK_LOCAL local altq
124 1.1 ozaki rump_server_start $SOCK_REMOTE
125 1.1 ozaki
126 1.1 ozaki rump_server_add_iface $SOCK_LOCAL shmif0 $BUS
127 1.1 ozaki rump_server_add_iface $SOCK_REMOTE shmif0 $BUS
128 1.1 ozaki
129 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
130 1.1 ozaki $ifconfig shmif0 inet $IP_LOCAL1/24
131 1.1 ozaki export RUMP_SERVER=$SOCK_REMOTE
132 1.1 ozaki $ifconfig shmif0 inet $IP_REMOTE11/24
133 1.1 ozaki $ifconfig shmif0 inet $IP_REMOTE12/24 alias
134 1.1 ozaki $ifconfig -w 10
135 1.1 ozaki
136 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
137 1.1 ozaki # Invoke ARP
138 1.1 ozaki $ping $opts $IP_REMOTE11
139 1.1 ozaki $ping $opts $IP_REMOTE12
140 1.1 ozaki
141 1.1 ozaki start_altqd_basic
142 1.1 ozaki
143 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
144 1.1 ozaki $ping $opts $IP_REMOTE11
145 1.1 ozaki
146 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 >./out
147 1.1 ozaki $DEBUG && cat ./out
148 1.1 ozaki
149 1.1 ozaki check_counter ./out normal 'pkts: 1'
150 1.1 ozaki check_counter ./out root 'pkts: 1'
151 1.1 ozaki check_counter ./out drop 'pkts: 0'
152 1.1 ozaki
153 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
154 1.1 ozaki atf_check -s not-exit:0 -o ignore -e match:"No buffer space available" \
155 1.1 ozaki rump.ping $opts $IP_REMOTE12
156 1.1 ozaki
157 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 >./out
158 1.1 ozaki $DEBUG && cat ./out
159 1.1 ozaki
160 1.1 ozaki check_counter ./out drop 'drops: 1'
161 1.1 ozaki check_counter ./out drop 'pkts: 0'
162 1.1 ozaki check_counter ./out normal 'pkts: 1'
163 1.1 ozaki check_counter ./out root 'pkts: 1'
164 1.1 ozaki
165 1.1 ozaki rm -f ./out
166 1.1 ozaki
167 1.1 ozaki shutdown_altqd
168 1.1 ozaki
169 1.1 ozaki rump_server_destroy_ifaces
170 1.1 ozaki }
171 1.1 ozaki
172 1.1 ozaki start_altqd_multi_ifaces()
173 1.1 ozaki {
174 1.1 ozaki
175 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
176 1.1 ozaki
177 1.1 ozaki $HIJACKING_ALTQ mkdir -p /rump/etc
178 1.1 ozaki $HIJACKING_ALTQ mkdir -p /rump/var/run
179 1.1 ozaki
180 1.1 ozaki cat > ./altq.conf <<-EOF
181 1.1 ozaki interface shmif0 cbq
182 1.1 ozaki class cbq shmif0 root_class NULL pbandwidth 100
183 1.1 ozaki class cbq shmif0 normal_class root_class pbandwidth 50 default
184 1.1 ozaki filter shmif0 normal_class $IP_REMOTE11 0 0 0 0
185 1.1 ozaki class cbq shmif0 drop_class root_class pbandwidth 0
186 1.1 ozaki filter shmif0 drop_class $IP_REMOTE12 0 0 0 0
187 1.1 ozaki interface shmif1 cbq
188 1.1 ozaki class cbq shmif1 root_class NULL pbandwidth 100
189 1.1 ozaki class cbq shmif1 normal_class root_class pbandwidth 50 default
190 1.1 ozaki filter shmif1 normal_class $IP_REMOTE21 0 0 0 0
191 1.1 ozaki class cbq shmif1 drop_class root_class pbandwidth 0
192 1.1 ozaki filter shmif1 drop_class $IP_REMOTE22 0 0 0 0
193 1.1 ozaki EOF
194 1.1 ozaki $DEBUG && cat ./altq.conf
195 1.1 ozaki atf_check -s exit:0 $HIJACKING_ALTQ cp ./altq.conf /rump/etc/altq.conf
196 1.1 ozaki $HIJACKING_ALTQ test -f /rump/etc/altq.conf
197 1.1 ozaki
198 1.1 ozaki #atf_check -s exit:0 $HIJACKING_ALTQ altqd
199 1.1 ozaki $HIJACKING_ALTQ altqd
200 1.1 ozaki
201 1.1 ozaki $HIJACKING_ALTQ test -f /var/run/altqd.pid
202 1.1 ozaki if [ $? != 0 ]; then
203 1.1 ozaki atf_check -s exit:0 $HIJACKING_ALTQ altqd -d
204 1.1 ozaki # Should abort
205 1.1 ozaki fi
206 1.1 ozaki
207 1.1 ozaki $HIJACKING_ALTQ cat /var/run/altqd.pid > $ALTQD_PIDFILE
208 1.1 ozaki
209 1.1 ozaki $DEBUG && $HIJACKING_ALTQ altqstat -s
210 1.1 ozaki
211 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 -i shmif0 >./out
212 1.1 ozaki $DEBUG && cat ./out
213 1.1 ozaki atf_check -s exit:0 \
214 1.1 ozaki -o match:"altqstat: cbq on interface shmif0" \
215 1.1 ozaki -o match:'Class 1 on Interface shmif0: root_class' \
216 1.1 ozaki -o match:'Class 2 on Interface shmif0: normal_class' \
217 1.1 ozaki -o match:'Class 3 on Interface shmif0: ctl_class' \
218 1.1 ozaki -o match:'Class 4 on Interface shmif0: drop_class' \
219 1.1 ozaki cat ./out
220 1.1 ozaki
221 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 -i shmif1 >./out
222 1.1 ozaki $DEBUG && cat ./out
223 1.1 ozaki atf_check -s exit:0 \
224 1.1 ozaki -o match:"altqstat: cbq on interface shmif1" \
225 1.1 ozaki -o match:'Class 1 on Interface shmif1: root_class' \
226 1.1 ozaki -o match:'Class 2 on Interface shmif1: normal_class' \
227 1.1 ozaki -o match:'Class 3 on Interface shmif1: ctl_class' \
228 1.1 ozaki -o match:'Class 4 on Interface shmif1: drop_class' \
229 1.1 ozaki cat ./out
230 1.1 ozaki
231 1.1 ozaki rm -f ./out
232 1.1 ozaki }
233 1.1 ozaki
234 1.1 ozaki test_altq_cbq_multi_ifaces_ipv4()
235 1.1 ozaki {
236 1.1 ozaki local ifconfig="atf_check -s exit:0 rump.ifconfig"
237 1.1 ozaki local ping="atf_check -s exit:0 -o ignore rump.ping"
238 1.1 ozaki local opts="-q -c 1 -w 1"
239 1.1 ozaki
240 1.1 ozaki rump_server_fs_start $SOCK_LOCAL local altq
241 1.1 ozaki rump_server_start $SOCK_REMOTE
242 1.1 ozaki
243 1.1 ozaki rump_server_add_iface $SOCK_LOCAL shmif0 $BUS
244 1.1 ozaki rump_server_add_iface $SOCK_LOCAL shmif1 $BUS
245 1.1 ozaki rump_server_add_iface $SOCK_REMOTE shmif0 $BUS
246 1.1 ozaki
247 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
248 1.1 ozaki $ifconfig shmif0 inet $IP_LOCAL1/24
249 1.1 ozaki $ifconfig shmif1 inet $IP_LOCAL2/24
250 1.1 ozaki export RUMP_SERVER=$SOCK_REMOTE
251 1.1 ozaki $ifconfig shmif0 inet $IP_REMOTE11/24
252 1.1 ozaki $ifconfig shmif0 inet $IP_REMOTE12/24 alias
253 1.1 ozaki $ifconfig shmif0 inet $IP_REMOTE21/24 alias
254 1.1 ozaki $ifconfig shmif0 inet $IP_REMOTE22/24 alias
255 1.1 ozaki $ifconfig -w 10
256 1.1 ozaki
257 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
258 1.1 ozaki # Invoke ARP
259 1.1 ozaki $ping $opts $IP_REMOTE11
260 1.1 ozaki $ping $opts $IP_REMOTE12
261 1.1 ozaki $ping $opts $IP_REMOTE21
262 1.1 ozaki $ping $opts $IP_REMOTE22
263 1.1 ozaki
264 1.1 ozaki start_altqd_multi_ifaces
265 1.1 ozaki
266 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
267 1.1 ozaki $ping $opts $IP_REMOTE11
268 1.1 ozaki
269 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 -i shmif0 >./out
270 1.1 ozaki $DEBUG && cat ./out
271 1.1 ozaki
272 1.1 ozaki check_counter ./out normal 'pkts: 1'
273 1.1 ozaki check_counter ./out root 'pkts: 1'
274 1.1 ozaki check_counter ./out drop 'pkts: 0'
275 1.1 ozaki
276 1.1 ozaki $ping $opts $IP_REMOTE21
277 1.1 ozaki
278 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 -i shmif1 >./out
279 1.1 ozaki $DEBUG && cat ./out
280 1.1 ozaki
281 1.1 ozaki check_counter ./out normal 'pkts: 1'
282 1.1 ozaki check_counter ./out root 'pkts: 1'
283 1.1 ozaki check_counter ./out drop 'pkts: 0'
284 1.1 ozaki
285 1.1 ozaki export RUMP_SERVER=$SOCK_LOCAL
286 1.1 ozaki atf_check -s not-exit:0 -o ignore -e match:"No buffer space available" \
287 1.1 ozaki rump.ping $opts $IP_REMOTE12
288 1.1 ozaki
289 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 -i shmif0 >./out
290 1.1 ozaki $DEBUG && cat ./out
291 1.1 ozaki
292 1.1 ozaki check_counter ./out drop 'drops: 1'
293 1.1 ozaki check_counter ./out drop 'pkts: 0'
294 1.1 ozaki check_counter ./out normal 'pkts: 1'
295 1.1 ozaki check_counter ./out root 'pkts: 1'
296 1.1 ozaki
297 1.1 ozaki atf_check -s not-exit:0 -o ignore -e match:"No buffer space available" \
298 1.1 ozaki rump.ping $opts $IP_REMOTE22
299 1.1 ozaki
300 1.1 ozaki $HIJACKING_ALTQ altqstat -c 1 -i shmif1 >./out
301 1.1 ozaki $DEBUG && cat ./out
302 1.1 ozaki
303 1.1 ozaki check_counter ./out drop 'drops: 1'
304 1.1 ozaki check_counter ./out drop 'pkts: 0'
305 1.1 ozaki check_counter ./out normal 'pkts: 1'
306 1.1 ozaki check_counter ./out root 'pkts: 1'
307 1.1 ozaki
308 1.1 ozaki rm -f ./out
309 1.1 ozaki
310 1.1 ozaki shutdown_altqd
311 1.1 ozaki
312 1.1 ozaki rump_server_destroy_ifaces
313 1.1 ozaki }
314 1.1 ozaki
315 1.1 ozaki add_test_case()
316 1.1 ozaki {
317 1.1 ozaki local algo=$1
318 1.1 ozaki local type=$2
319 1.1 ozaki local ipproto=$3
320 1.1 ozaki
321 1.1 ozaki name="altq_${algo}_${type}_${ipproto}"
322 1.1 ozaki desc="Tests for ALTQ $algo (${type}) on ${ipproto}"
323 1.1 ozaki
324 1.1 ozaki atf_test_case ${name} cleanup
325 1.1 ozaki eval "
326 1.1 ozaki ${name}_head() {
327 1.1 ozaki atf_set descr \"$desc\"
328 1.1 ozaki atf_set require.progs rump_server altqd altqstat
329 1.1 ozaki }
330 1.1 ozaki ${name}_body() {
331 1.1 ozaki test_altq_${algo}_${type}_${ipproto}
332 1.1 ozaki }
333 1.1 ozaki ${name}_cleanup() {
334 1.1 ozaki shutdown_altqd
335 1.1 ozaki \$DEBUG && dump
336 1.1 ozaki cleanup
337 1.1 ozaki }
338 1.1 ozaki "
339 1.1 ozaki atf_add_test_case ${name}
340 1.1 ozaki }
341 1.1 ozaki
342 1.1 ozaki atf_init_test_cases()
343 1.1 ozaki {
344 1.1 ozaki
345 1.1 ozaki add_test_case cbq basic ipv4
346 1.1 ozaki add_test_case cbq multi_ifaces ipv4
347 1.1 ozaki }
348