285 lines
7.3 KiB
Plaintext
285 lines
7.3 KiB
Plaintext
|
|
#!/usr/bin/expect -f
|
||
|
|
#
|
||
|
|
# Copyright (c) 2020, The OpenThread Authors.
|
||
|
|
# All rights reserved.
|
||
|
|
#
|
||
|
|
# Redistribution and use in source and binary forms, with or without
|
||
|
|
# modification, are permitted provided that the following conditions are met:
|
||
|
|
# 1. Redistributions of source code must retain the above copyright
|
||
|
|
# notice, this list of conditions and the following disclaimer.
|
||
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
||
|
|
# notice, this list of conditions and the following disclaimer in the
|
||
|
|
# documentation and/or other materials provided with the distribution.
|
||
|
|
# 3. Neither the name of the copyright holder nor the
|
||
|
|
# names of its contributors may be used to endorse or promote products
|
||
|
|
# derived from this software without specific prior written permission.
|
||
|
|
#
|
||
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
||
|
|
#
|
||
|
|
|
||
|
|
source "tests/scripts/expect/_common.exp"
|
||
|
|
source "tests/scripts/expect/_multinode.exp"
|
||
|
|
|
||
|
|
|
||
|
|
# The expect on macOS doesn't support `try` or `file tempfile`.
|
||
|
|
skip_on_macos
|
||
|
|
|
||
|
|
file tempfile socat_out
|
||
|
|
set socat_pid [exec socat -d -d pty,raw,echo=0 pty,raw,echo=0 >/dev/null 2>$socat_out &]
|
||
|
|
while {true} {
|
||
|
|
if {[exec head -n2 $socat_out | wc -l] == 2} {
|
||
|
|
set radio_pty [exec head -n1 $socat_out | grep -o {/dev/.\+}]
|
||
|
|
set host_pty [exec head -n2 $socat_out | tail -n1 | grep -o {/dev/.\+}]
|
||
|
|
break
|
||
|
|
}
|
||
|
|
sleep 1
|
||
|
|
}
|
||
|
|
|
||
|
|
puts "Radio PTY: $radio_pty"
|
||
|
|
puts "Host PTY: $host_pty"
|
||
|
|
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
try {
|
||
|
|
puts "Before enabling"
|
||
|
|
|
||
|
|
spawn_node 1 "rcp" "spinel+hdlc_uart://$host_pty"
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
expect eof
|
||
|
|
|
||
|
|
|
||
|
|
puts "Queued parent-to-child packets, as parent"
|
||
|
|
|
||
|
|
spawn_node 1 "rcp" "spinel+hdlc_uart://$host_pty"
|
||
|
|
spawn_node 2
|
||
|
|
|
||
|
|
setup_two_nodes "-" false
|
||
|
|
|
||
|
|
switch_node 2
|
||
|
|
set addr_2 [get_ipaddr mleid]
|
||
|
|
send "udp open\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp bind :: 11003\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "pollperiod 100000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
switch_node 1
|
||
|
|
set addr_1 [get_ipaddr mleid]
|
||
|
|
send "udp open\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp bind :: 11004\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp connect $addr_2 11003\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp send hello\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp send there\n"
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
switch_node 2
|
||
|
|
send "pollperiod 1000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
expect "5 bytes from $addr_1 11004 hello"
|
||
|
|
expect "5 bytes from $addr_1 11004 there"
|
||
|
|
|
||
|
|
dispose_all
|
||
|
|
|
||
|
|
|
||
|
|
puts "Queued parent-to-child packets, as child"
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 2 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
spawn_node 1
|
||
|
|
spawn_node 2 "rcp" "spinel+hdlc_uart://$host_pty"
|
||
|
|
|
||
|
|
setup_two_nodes "-" false
|
||
|
|
|
||
|
|
switch_node 2
|
||
|
|
set addr_2 [get_ipaddr mleid]
|
||
|
|
send "udp open\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp bind :: 11003\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "pollperiod 100000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
switch_node 1
|
||
|
|
set addr_1 [get_ipaddr mleid]
|
||
|
|
send "udp open\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp bind :: 11004\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp connect $addr_2 11003\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp send hello\n"
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 2 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
switch_node 2
|
||
|
|
send "pollperiod 1000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
expect "5 bytes from $addr_1 11004 hello"
|
||
|
|
|
||
|
|
dispose_all
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
|
||
|
|
puts "Many children, queued child-to-child packets"
|
||
|
|
|
||
|
|
spawn_node 1 "rcp" "spinel+hdlc_uart://$host_pty"
|
||
|
|
setup_leader
|
||
|
|
set addr(1) [get_ipaddr mleid]
|
||
|
|
send "udp open\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp bind :: 11004\n"
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
set max_children 10
|
||
|
|
for {set i 2} {$i <= $max_children + 1} {incr i} {
|
||
|
|
spawn_node $i
|
||
|
|
setup_node $i "-"
|
||
|
|
switch_node $i
|
||
|
|
set addr($i) [get_ipaddr mleid]
|
||
|
|
send "udp open\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "udp bind :: 11003\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "pollperiod 100000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
}
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
switch_node 1
|
||
|
|
for {set i 2} {$i <= $max_children + 1} {incr i} {
|
||
|
|
send "udp send $addr($i) 11003 hello\n"
|
||
|
|
expect_line "Done"
|
||
|
|
}
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
for {set i 7} {$i <= 9} {incr i} {
|
||
|
|
switch_node $i
|
||
|
|
send "pollperiod 1000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
expect "5 bytes from $addr(1) 11004 hello"
|
||
|
|
}
|
||
|
|
|
||
|
|
switch_node 4
|
||
|
|
send "udp send $addr(5) 11003 hello_from_node_4\n"
|
||
|
|
expect_line "Done"
|
||
|
|
if {$::env(THREAD_VERSION) != "1.1"} {
|
||
|
|
expect "5 bytes from $addr(1) 11004 hello"
|
||
|
|
}
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
switch_node 5
|
||
|
|
send "pollperiod 1000\n"
|
||
|
|
expect_line "Done"
|
||
|
|
expect "17 bytes from $addr(4) 11003 hello_from_node_4"
|
||
|
|
|
||
|
|
dispose_all
|
||
|
|
|
||
|
|
|
||
|
|
puts "While energy scanning"
|
||
|
|
|
||
|
|
spawn_node 1 "rcp" "spinel+hdlc_uart://$host_pty"
|
||
|
|
send "ifconfig up\n"
|
||
|
|
expect_line "Done"
|
||
|
|
send "thread start\n"
|
||
|
|
expect_line "Done"
|
||
|
|
wait_for "state" "leader"
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
send "scan energy 100\n"
|
||
|
|
expect "| Ch | RSSI |"
|
||
|
|
expect "+----+------+"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
exec kill $rcp_pid
|
||
|
|
puts "Killed $rcp_pid"
|
||
|
|
sleep 1
|
||
|
|
set rcp_pid [exec $::env(OT_SIMULATION_APPS)/ncp/ot-rcp 1 < $radio_pty > $radio_pty &]
|
||
|
|
puts "RCP PID: $rcp_pid"
|
||
|
|
|
||
|
|
sleep 1
|
||
|
|
|
||
|
|
for {set i 11} {$i <= 26} {incr i} {
|
||
|
|
expect -re "\\| +$i \\| +-?\\d+ \\|"
|
||
|
|
}
|
||
|
|
expect_line "Done"
|
||
|
|
|
||
|
|
dispose_all
|
||
|
|
} finally {
|
||
|
|
exec kill $rcp_pid
|
||
|
|
exec kill $socat_pid
|
||
|
|
}
|