t_pppoe.sh revision 1.7 1 1.7 knakahar # $NetBSD: t_pppoe.sh,v 1.7 2016/10/26 03:27:24 knakahara Exp $
2 1.1 ozaki #
3 1.1 ozaki # Copyright (c) 2016 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.2 pgoyette server="rump_server -lrump -lrumpnet -lrumpnet_net -lrumpnet_netinet \
29 1.2 pgoyette -lrumpnet_netinet6 -lrumpnet_shmif -lrumpdev \
30 1.2 pgoyette -lrumpnet_pppoe"
31 1.1 ozaki HIJACKING="env LD_PRELOAD=/usr/lib/librumphijack.so"
32 1.1 ozaki
33 1.1 ozaki SERVER=unix://commsock1
34 1.1 ozaki CLIENT=unix://commsock2
35 1.1 ozaki
36 1.1 ozaki SERVER_IP=10.3.3.1
37 1.1 ozaki CLIENT_IP=10.3.3.3
38 1.7 knakahar SERVER_IP6=fc00::1
39 1.7 knakahar CLIENT_IP6=fc00::3
40 1.1 ozaki AUTHNAME=foobar@baz.com
41 1.1 ozaki SECRET=oink
42 1.1 ozaki BUS=bus0
43 1.1 ozaki TIMEOUT=3
44 1.1 ozaki WAITTIME=5
45 1.1 ozaki DEBUG=false
46 1.1 ozaki
47 1.1 ozaki setup()
48 1.1 ozaki {
49 1.7 knakahar inet=true
50 1.7 knakahar
51 1.7 knakahar if [ $# -ne 0 ]; then
52 1.7 knakahar eval $@
53 1.7 knakahar fi
54 1.7 knakahar
55 1.1 ozaki atf_check -s exit:0 ${server} $SERVER
56 1.1 ozaki atf_check -s exit:0 ${server} $CLIENT
57 1.1 ozaki
58 1.1 ozaki export RUMP_SERVER=$SERVER
59 1.1 ozaki atf_check -s exit:0 rump.ifconfig shmif0 create
60 1.1 ozaki atf_check -s exit:0 rump.ifconfig shmif0 linkstr $BUS
61 1.1 ozaki atf_check -s exit:0 rump.ifconfig shmif0 up
62 1.1 ozaki
63 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 create
64 1.7 knakahar $inet && atf_check -s exit:0 rump.ifconfig pppoe0 \
65 1.7 knakahar inet $SERVER_IP $CLIENT_IP down
66 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 link0
67 1.1 ozaki
68 1.1 ozaki $DEBUG && rump.ifconfig
69 1.1 ozaki $DEBUG && $HIJACKING pppoectl -d pppoe0
70 1.1 ozaki
71 1.1 ozaki atf_check -s exit:0 -x "$HIJACKING pppoectl -e shmif0 pppoe0"
72 1.1 ozaki unset RUMP_SERVER
73 1.1 ozaki
74 1.1 ozaki export RUMP_SERVER=$CLIENT
75 1.1 ozaki atf_check -s exit:0 rump.ifconfig shmif0 create
76 1.1 ozaki atf_check -s exit:0 rump.ifconfig shmif0 linkstr $BUS
77 1.1 ozaki atf_check -s exit:0 rump.ifconfig shmif0 up
78 1.1 ozaki
79 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 create
80 1.7 knakahar $inet && atf_check -s exit:0 rump.ifconfig pppoe0 \
81 1.7 knakahar inet 0.0.0.0 0.0.0.1 down
82 1.1 ozaki
83 1.1 ozaki atf_check -s exit:0 -x "$HIJACKING pppoectl -e shmif0 pppoe0"
84 1.1 ozaki unset RUMP_SERVER
85 1.1 ozaki }
86 1.3 christos
87 1.1 ozaki cleanup()
88 1.1 ozaki {
89 1.1 ozaki env RUMP_SERVER=$SERVER rump.halt
90 1.1 ozaki env RUMP_SERVER=$CLIENT rump.halt
91 1.1 ozaki }
92 1.1 ozaki
93 1.1 ozaki
94 1.1 ozaki wait_for_session_established()
95 1.1 ozaki {
96 1.1 ozaki local dontfail=$1
97 1.1 ozaki local n=$WAITTIME
98 1.1 ozaki
99 1.1 ozaki for i in $(seq $n); do
100 1.1 ozaki $HIJACKING pppoectl -d pppoe0 |grep -q "state = session"
101 1.1 ozaki [ $? = 0 ] && return
102 1.1 ozaki sleep 1
103 1.1 ozaki done
104 1.1 ozaki
105 1.1 ozaki if [ $dontfail != "dontfail" ]; then
106 1.1 ozaki atf_fail "Couldn't connect to the server for $n seconds."
107 1.1 ozaki fi
108 1.1 ozaki }
109 1.1 ozaki
110 1.7 knakahar wait_for_disconnected()
111 1.7 knakahar {
112 1.7 knakahar local dontfail=$1
113 1.7 knakahar local n=$WAITTIME
114 1.7 knakahar
115 1.7 knakahar for i in $(seq $n); do
116 1.7 knakahar $HIJACKING pppoectl -d pppoe0 | grep -q "state = session"
117 1.7 knakahar [ $? -eq 0 ] || return
118 1.7 knakahar sleep 1
119 1.7 knakahar done
120 1.7 knakahar
121 1.7 knakahar if [ $dontfail != "dontfail" ]; then
122 1.7 knakahar atf_fail "Couldn't disconnect for $n seconds."
123 1.7 knakahar fi
124 1.7 knakahar }
125 1.7 knakahar
126 1.3 christos run_test()
127 1.1 ozaki {
128 1.3 christos local auth=$1
129 1.1 ozaki setup
130 1.1 ozaki
131 1.4 knakahar # As pppoe client doesn't support rechallenge yet.
132 1.4 knakahar local server_optparam=""
133 1.4 knakahar if [ $auth = "chap" ]; then
134 1.4 knakahar server_optparam="norechallenge"
135 1.4 knakahar fi
136 1.4 knakahar
137 1.1 ozaki export RUMP_SERVER=$SERVER
138 1.1 ozaki local setup_serverparam="pppoectl pppoe0 hisauthproto=$auth \
139 1.1 ozaki 'hisauthname=$AUTHNAME' \
140 1.1 ozaki 'hisauthsecret=$SECRET' \
141 1.4 knakahar 'myauthproto=none' \
142 1.4 knakahar $server_optparam"
143 1.1 ozaki atf_check -s exit:0 -x "$HIJACKING $setup_serverparam"
144 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 up
145 1.1 ozaki unset RUMP_SERVER
146 1.1 ozaki
147 1.1 ozaki export RUMP_SERVER=$CLIENT
148 1.1 ozaki local setup_clientparam="pppoectl pppoe0 myauthproto=$auth \
149 1.1 ozaki 'myauthname=$AUTHNAME' \
150 1.1 ozaki 'myauthsecret=$SECRET' \
151 1.1 ozaki 'hisauthproto=none'"
152 1.1 ozaki atf_check -s exit:0 -x "$HIJACKING $setup_clientparam"
153 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 up
154 1.1 ozaki $DEBUG && rump.ifconfig
155 1.1 ozaki wait_for_session_established
156 1.1 ozaki atf_check -s exit:0 -o ignore rump.ping -c 1 -w $TIMEOUT $SERVER_IP
157 1.1 ozaki unset RUMP_SERVER
158 1.1 ozaki
159 1.1 ozaki # test for disconnection from server
160 1.1 ozaki atf_check -s exit:0 -x "env RUMP_SERVER=$SERVER rump.ifconfig pppoe0 down"
161 1.1 ozaki export RUMP_SERVER=$CLIENT
162 1.1 ozaki atf_check -s not-exit:0 -o ignore -e ignore \
163 1.1 ozaki rump.ping -c 1 -w $TIMEOUT $SERVER_IP
164 1.1 ozaki atf_check -s exit:0 -o match:'PADI sent' -x "$HIJACKING pppoectl -d pppoe0"
165 1.1 ozaki unset RUMP_SERVER
166 1.1 ozaki
167 1.1 ozaki # test for recoonecting
168 1.1 ozaki atf_check -s exit:0 -x "env RUMP_SERVER=$SERVER rump.ifconfig pppoe0 up"
169 1.1 ozaki export RUMP_SERVER=$CLIENT
170 1.1 ozaki wait_for_session_established
171 1.1 ozaki atf_check -s exit:0 -o ignore rump.ping -c 1 -w $TIMEOUT $SERVER_IP
172 1.1 ozaki unset RUMP_SERVER
173 1.1 ozaki
174 1.1 ozaki # test for disconnection from client
175 1.1 ozaki atf_check -s exit:0 -x "env RUMP_SERVER=$CLIENT rump.ifconfig pppoe0 down"
176 1.1 ozaki export RUMP_SERVER=$SERVER
177 1.1 ozaki $DEBUG && $HIJACKING pppoectl -d pppoe0
178 1.1 ozaki atf_check -s not-exit:0 -o ignore -e ignore \
179 1.1 ozaki rump.ping -c 1 -w $TIMEOUT $CLIENT_IP
180 1.1 ozaki atf_check -s exit:0 -o match:'initial' -x "$HIJACKING pppoectl -d pppoe0"
181 1.1 ozaki unset RUMP_SERVER
182 1.1 ozaki
183 1.1 ozaki # test for recconecting
184 1.1 ozaki export RUMP_SERVER=$CLIENT
185 1.1 ozaki atf_check -s exit:0 -x rump.ifconfig pppoe0 up
186 1.1 ozaki wait_for_session_established
187 1.1 ozaki $DEBUG && rump.ifconfig pppoe0
188 1.1 ozaki $DEBUG && $HIJACKING pppoectl -d pppoe0
189 1.1 ozaki unset RUMP_SERVER
190 1.1 ozaki
191 1.1 ozaki export RUMP_SERVER=$SERVER
192 1.1 ozaki atf_check -s exit:0 -o ignore rump.ping -c 1 -w $TIMEOUT $CLIENT_IP
193 1.1 ozaki atf_check -s exit:0 -o match:'session' -x "$HIJACKING pppoectl -d pppoe0"
194 1.1 ozaki $DEBUG && HIJACKING pppoectl -d pppoe0
195 1.1 ozaki unset RUMP_SERVER
196 1.1 ozaki
197 1.1 ozaki # test for invalid password
198 1.1 ozaki export RUMP_SERVER=$CLIENT
199 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 down
200 1.1 ozaki local setup_clientparam="pppoectl pppoe0 myauthproto=$auth \
201 1.1 ozaki 'myauthname=$AUTHNAME' \
202 1.1 ozaki 'myauthsecret=invalidsecret' \
203 1.1 ozaki 'hisauthproto=none'"
204 1.1 ozaki atf_check -s exit:0 -x "$HIJACKING $setup_clientparam"
205 1.1 ozaki atf_check -s exit:0 rump.ifconfig pppoe0 up
206 1.1 ozaki wait_for_session_established dontfail
207 1.1 ozaki atf_check -s not-exit:0 -o ignore -e ignore \
208 1.1 ozaki rump.ping -c 1 -w $TIMEOUT $SERVER_IP
209 1.1 ozaki atf_check -s exit:0 -o match:'initial' -x "$HIJACKING pppoectl -d pppoe0"
210 1.1 ozaki unset RUMP_SERVER
211 1.1 ozaki }
212 1.1 ozaki
213 1.6 ozaki atf_test_case pppoe_pap cleanup
214 1.3 christos
215 1.5 ozaki pppoe_pap_head()
216 1.3 christos {
217 1.3 christos atf_set "descr" "Does simple pap tests"
218 1.3 christos atf_set "require.progs" "rump_server pppoectl"
219 1.3 christos }
220 1.3 christos
221 1.5 ozaki pppoe_pap_body()
222 1.3 christos {
223 1.3 christos run_test pap
224 1.3 christos }
225 1.3 christos
226 1.5 ozaki pppoe_pap_cleanup()
227 1.1 ozaki {
228 1.1 ozaki cleanup
229 1.1 ozaki }
230 1.3 christos
231 1.6 ozaki atf_test_case pppoe_chap cleanup
232 1.3 christos
233 1.5 ozaki pppoe_chap_head()
234 1.3 christos {
235 1.3 christos atf_set "descr" "Does simple chap tests"
236 1.3 christos atf_set "require.progs" "rump_server pppoectl"
237 1.3 christos }
238 1.3 christos
239 1.5 ozaki pppoe_chap_body()
240 1.3 christos {
241 1.3 christos run_test chap
242 1.3 christos }
243 1.3 christos
244 1.5 ozaki pppoe_chap_cleanup()
245 1.3 christos {
246 1.3 christos cleanup
247 1.3 christos }
248 1.3 christos
249 1.7 knakahar run_test6()
250 1.7 knakahar {
251 1.7 knakahar local auth=$1
252 1.7 knakahar setup "inet=false"
253 1.7 knakahar
254 1.7 knakahar # As pppoe client doesn't support rechallenge yet.
255 1.7 knakahar local server_optparam=""
256 1.7 knakahar if [ $auth = "chap" ]; then
257 1.7 knakahar server_optparam="norechallenge"
258 1.7 knakahar fi
259 1.7 knakahar
260 1.7 knakahar export RUMP_SERVER=$SERVER
261 1.7 knakahar local setup_serverparam="pppoectl pppoe0 hisauthproto=$auth \
262 1.7 knakahar 'hisauthname=$AUTHNAME' \
263 1.7 knakahar 'hisauthsecret=$SECRET' \
264 1.7 knakahar 'myauthproto=none' \
265 1.7 knakahar $server_optparam"
266 1.7 knakahar atf_check -s exit:0 -x "$HIJACKING $setup_serverparam"
267 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 inet6 $SERVER_IP6/64 down
268 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 up
269 1.7 knakahar unset RUMP_SERVER
270 1.7 knakahar
271 1.7 knakahar export RUMP_SERVER=$CLIENT
272 1.7 knakahar local setup_clientparam="pppoectl pppoe0 myauthproto=$auth \
273 1.7 knakahar 'myauthname=$AUTHNAME' \
274 1.7 knakahar 'myauthsecret=$SECRET' \
275 1.7 knakahar 'hisauthproto=none'"
276 1.7 knakahar atf_check -s exit:0 -x "$HIJACKING $setup_clientparam"
277 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 inet6 $CLIENT_IP6/64 down
278 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 up
279 1.7 knakahar $DEBUG && rump.ifconfig
280 1.7 knakahar wait_for_session_established
281 1.7 knakahar atf_check -s exit:0 -o ignore rump.ifconfig -w 10
282 1.7 knakahar export RUMP_SERVER=$SERVER
283 1.7 knakahar atf_check -s exit:0 -o ignore rump.ifconfig -w 10
284 1.7 knakahar export RUMP_SERVER=$CLIENT
285 1.7 knakahar atf_check -s exit:0 -o ignore rump.ping6 -c 1 -X $TIMEOUT $SERVER_IP6
286 1.7 knakahar unset RUMP_SERVER
287 1.7 knakahar
288 1.7 knakahar # test for disconnection from server
289 1.7 knakahar export RUMP_SERVER=$SERVER
290 1.7 knakahar session_id=`$HIJACKING pppoectl -d pppoe0 | grep state`
291 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 down
292 1.7 knakahar wait_for_disconnected
293 1.7 knakahar export RUMP_SERVER=$CLIENT
294 1.7 knakahar wait_for_disconnected
295 1.7 knakahar atf_check -s not-exit:0 -o ignore -e ignore \
296 1.7 knakahar rump.ping6 -c 1 -w $TIMEOUT $SERVER_IP6
297 1.7 knakahar atf_check -s exit:0 -o not-match:"$session_id" -x "$HIJACKING pppoectl -d pppoe0"
298 1.7 knakahar unset RUMP_SERVER
299 1.7 knakahar
300 1.7 knakahar # test for recoonecting
301 1.7 knakahar export RUMP_SERVER=$SERVER
302 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 up
303 1.7 knakahar wait_for_session_established
304 1.7 knakahar atf_check -s exit:0 rump.ifconfig -w 10
305 1.7 knakahar $DEBUG && $HIJACKING pppoectl -d pppoe0
306 1.7 knakahar $DEBUG && rump.ifconfig pppoe0
307 1.7 knakahar export RUMP_SERVER=$CLIENT
308 1.7 knakahar atf_check -s exit:0 -o ignore rump.ifconfig -w 10
309 1.7 knakahar atf_check -s exit:0 -o ignore rump.ping6 -c 1 -X $TIMEOUT $SERVER_IP6
310 1.7 knakahar unset RUMP_SERVER
311 1.7 knakahar
312 1.7 knakahar # test for disconnection from client
313 1.7 knakahar export RUMP_SERVER=$CLIENT
314 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 down
315 1.7 knakahar wait_for_disconnected
316 1.7 knakahar
317 1.7 knakahar export RUMP_SERVER=$SERVER
318 1.7 knakahar $DEBUG && $HIJACKING pppoectl -d pppoe0
319 1.7 knakahar wait_for_disconnected
320 1.7 knakahar atf_check -s not-exit:0 -o ignore -e ignore \
321 1.7 knakahar rump.ping6 -c 1 -X $TIMEOUT $CLIENT_IP6
322 1.7 knakahar atf_check -s exit:0 -o match:'initial' -x "$HIJACKING pppoectl -d pppoe0"
323 1.7 knakahar unset RUMP_SERVER
324 1.7 knakahar
325 1.7 knakahar # test for recconecting
326 1.7 knakahar export RUMP_SERVER=$CLIENT
327 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 up
328 1.7 knakahar wait_for_session_established
329 1.7 knakahar atf_check -s exit:0 rump.ifconfig -w 10
330 1.7 knakahar
331 1.7 knakahar $DEBUG && rump.ifconfig pppoe0
332 1.7 knakahar $DEBUG && $HIJACKING pppoectl -d pppoe0
333 1.7 knakahar unset RUMP_SERVER
334 1.7 knakahar
335 1.7 knakahar export RUMP_SERVER=$SERVER
336 1.7 knakahar atf_check -s exit:0 -o ignore rump.ping6 -c 1 -X $TIMEOUT $CLIENT_IP6
337 1.7 knakahar atf_check -s exit:0 -o match:'session' -x "$HIJACKING pppoectl -d pppoe0"
338 1.7 knakahar $DEBUG && HIJACKING pppoectl -d pppoe0
339 1.7 knakahar unset RUMP_SERVER
340 1.7 knakahar
341 1.7 knakahar # test for invalid password
342 1.7 knakahar export RUMP_SERVER=$CLIENT
343 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 down
344 1.7 knakahar wait_for_disconnected
345 1.7 knakahar local setup_clientparam="pppoectl pppoe0 myauthproto=$auth \
346 1.7 knakahar 'myauthname=$AUTHNAME' \
347 1.7 knakahar 'myauthsecret=invalidsecret' \
348 1.7 knakahar 'hisauthproto=none'"
349 1.7 knakahar atf_check -s exit:0 -x "$HIJACKING $setup_clientparam"
350 1.7 knakahar atf_check -s exit:0 rump.ifconfig pppoe0 up
351 1.7 knakahar wait_for_session_established dontfail
352 1.7 knakahar atf_check -s not-exit:0 -o ignore -e ignore \
353 1.7 knakahar rump.ping6 -c 1 -X $TIMEOUT $SERVER_IP6
354 1.7 knakahar atf_check -s exit:0 -o match:'DETACHED' rump.ifconfig pppoe0
355 1.7 knakahar unset RUMP_SERVER
356 1.7 knakahar }
357 1.7 knakahar
358 1.7 knakahar atf_test_case pppoe6_pap cleanup
359 1.7 knakahar
360 1.7 knakahar pppoe6_pap_head()
361 1.7 knakahar {
362 1.7 knakahar atf_set "descr" "Does simple pap using IPv6 tests"
363 1.7 knakahar atf_set "require.progs" "rump_server pppoectl"
364 1.7 knakahar }
365 1.7 knakahar
366 1.7 knakahar pppoe6_pap_body()
367 1.7 knakahar {
368 1.7 knakahar run_test6 pap
369 1.7 knakahar }
370 1.7 knakahar
371 1.7 knakahar pppoe6_pap_cleanup()
372 1.7 knakahar {
373 1.7 knakahar cleanup
374 1.7 knakahar }
375 1.7 knakahar
376 1.7 knakahar atf_test_case pppoe6_chap cleanup
377 1.7 knakahar
378 1.7 knakahar pppoe6_chap_head()
379 1.7 knakahar {
380 1.7 knakahar atf_set "descr" "Does simple chap using IPv6 tests"
381 1.7 knakahar atf_set "require.progs" "rump_server pppoectl"
382 1.7 knakahar }
383 1.7 knakahar
384 1.7 knakahar pppoe6_chap_body()
385 1.7 knakahar {
386 1.7 knakahar run_test6 chap
387 1.7 knakahar }
388 1.7 knakahar
389 1.7 knakahar pppoe6_chap_cleanup()
390 1.7 knakahar {
391 1.7 knakahar cleanup
392 1.7 knakahar }
393 1.7 knakahar
394 1.1 ozaki atf_init_test_cases()
395 1.1 ozaki {
396 1.5 ozaki atf_add_test_case pppoe_pap
397 1.5 ozaki atf_add_test_case pppoe_chap
398 1.7 knakahar atf_add_test_case pppoe6_pap
399 1.7 knakahar atf_add_test_case pppoe6_chap
400 1.1 ozaki }
401