1#!/usr/bin/expect -f 2# 3# Copyright (c) 2023, The OpenThread Authors. 4# All rights reserved. 5# 6# Redistribution and use in source and binary forms, with or without 7# modification, are permitted provided that the following conditions are met: 8# 1. Redistributions of source code must retain the above copyright 9# notice, this list of conditions and the following disclaimer. 10# 2. Redistributions in binary form must reproduce the above copyright 11# notice, this list of conditions and the following disclaimer in the 12# documentation and/or other materials provided with the distribution. 13# 3. Neither the name of the copyright holder nor the 14# names of its contributors may be used to endorse or promote products 15# derived from this software without specific prior written permission. 16# 17# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 18# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 21# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 22# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 23# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 24# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 25# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 26# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 27# POSSIBILITY OF SUCH DAMAGE. 28# 29 30source "tests/scripts/expect/_common.exp" 31source "tests/scripts/expect/_multinode.exp" 32 33setup_two_nodes "-" 34 35switch_node 2 36set addr [get_ipaddr mleid] 37send "pollperiod 3000\n" 38expect_line "Done" 39send "radio stats clear\n" 40expect_line "Done" 41 42switch_node 1 43for {set i 1} {$i <= 10} {incr i} { 44 send "ping $addr\n" 45 sleep 3 46 expect "16 bytes from $addr: icmp_seq=" 47} 48 49switch_node 2 50send "radio stats\n" 51expect_line "Radio Statistics:" 52expect -re {Total Time: \d+\.\d+s} 53expect -re {Tx Time: \d+\.\d+s \(\d+\.\d+%\)} 54expect -re {Rx Time: \d+\.\d+s \(\d+\.\d+%\)} 55expect -re {Sleep Time: \d+\.\d+s \(\d+\.\d+%\)} 56expect -re {Disabled Time: \d+\.\d+s \(\d+\.\d+%\)} 57dispose_all 58