xref: /aosp_15_r20/external/openthread/tests/scripts/expect/cli_non_rcp-radiostats.exp (revision cfb92d1480a9e65faed56933e9c12405f45898b4)
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