xref: /aosp_15_r20/external/openthread/tests/toranj/cli/test-031-service-aloc-route-lookup.py (revision cfb92d1480a9e65faed56933e9c12405f45898b4)
1*cfb92d14SAndroid Build Coastguard Worker#!/usr/bin/env python3
2*cfb92d14SAndroid Build Coastguard Worker#
3*cfb92d14SAndroid Build Coastguard Worker#  Copyright (c) 2024, The OpenThread Authors.
4*cfb92d14SAndroid Build Coastguard Worker#  All rights reserved.
5*cfb92d14SAndroid Build Coastguard Worker#
6*cfb92d14SAndroid Build Coastguard Worker#  Redistribution and use in source and binary forms, with or without
7*cfb92d14SAndroid Build Coastguard Worker#  modification, are permitted provided that the following conditions are met:
8*cfb92d14SAndroid Build Coastguard Worker#  1. Redistributions of source code must retain the above copyright
9*cfb92d14SAndroid Build Coastguard Worker#     notice, this list of conditions and the following disclaimer.
10*cfb92d14SAndroid Build Coastguard Worker#  2. Redistributions in binary form must reproduce the above copyright
11*cfb92d14SAndroid Build Coastguard Worker#     notice, this list of conditions and the following disclaimer in the
12*cfb92d14SAndroid Build Coastguard Worker#     documentation and/or other materials provided with the distribution.
13*cfb92d14SAndroid Build Coastguard Worker#  3. Neither the name of the copyright holder nor the
14*cfb92d14SAndroid Build Coastguard Worker#     names of its contributors may be used to endorse or promote products
15*cfb92d14SAndroid Build Coastguard Worker#     derived from this software without specific prior written permission.
16*cfb92d14SAndroid Build Coastguard Worker#
17*cfb92d14SAndroid Build Coastguard Worker#  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18*cfb92d14SAndroid Build Coastguard Worker#  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*cfb92d14SAndroid Build Coastguard Worker#  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*cfb92d14SAndroid Build Coastguard Worker#  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21*cfb92d14SAndroid Build Coastguard Worker#  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22*cfb92d14SAndroid Build Coastguard Worker#  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23*cfb92d14SAndroid Build Coastguard Worker#  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24*cfb92d14SAndroid Build Coastguard Worker#  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25*cfb92d14SAndroid Build Coastguard Worker#  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26*cfb92d14SAndroid Build Coastguard Worker#  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27*cfb92d14SAndroid Build Coastguard Worker#  POSSIBILITY OF SUCH DAMAGE.
28*cfb92d14SAndroid Build Coastguard Worker
29*cfb92d14SAndroid Build Coastguard Workerfrom cli import verify
30*cfb92d14SAndroid Build Coastguard Workerfrom cli import verify_within
31*cfb92d14SAndroid Build Coastguard Workerimport cli
32*cfb92d14SAndroid Build Coastguard Workerimport time
33*cfb92d14SAndroid Build Coastguard Worker
34*cfb92d14SAndroid Build Coastguard Worker# -----------------------------------------------------------------------------------------------------------------------
35*cfb92d14SAndroid Build Coastguard Worker# Test description: Service ALOC destination route lookup
36*cfb92d14SAndroid Build Coastguard Worker#
37*cfb92d14SAndroid Build Coastguard Worker# Test topology:
38*cfb92d14SAndroid Build Coastguard Worker#
39*cfb92d14SAndroid Build Coastguard Worker#     r1---- r2 ---- r3 ---- r4
40*cfb92d14SAndroid Build Coastguard Worker#     |
41*cfb92d14SAndroid Build Coastguard Worker#     |
42*cfb92d14SAndroid Build Coastguard Worker#    fed1
43*cfb92d14SAndroid Build Coastguard Worker#
44*cfb92d14SAndroid Build Coastguard Worker# The same service is added on `r4` and `fed1`.
45*cfb92d14SAndroid Build Coastguard Worker
46*cfb92d14SAndroid Build Coastguard Workertest_name = __file__[:-3] if __file__.endswith('.py') else __file__
47*cfb92d14SAndroid Build Coastguard Workerprint('-' * 120)
48*cfb92d14SAndroid Build Coastguard Workerprint('Starting \'{}\''.format(test_name))
49*cfb92d14SAndroid Build Coastguard Worker
50*cfb92d14SAndroid Build Coastguard Worker# -----------------------------------------------------------------------------------------------------------------------
51*cfb92d14SAndroid Build Coastguard Worker# Creating `cli.Nodes` instances
52*cfb92d14SAndroid Build Coastguard Worker
53*cfb92d14SAndroid Build Coastguard Workerspeedup = 40
54*cfb92d14SAndroid Build Coastguard Workercli.Node.set_time_speedup_factor(speedup)
55*cfb92d14SAndroid Build Coastguard Worker
56*cfb92d14SAndroid Build Coastguard Workerr1 = cli.Node()
57*cfb92d14SAndroid Build Coastguard Workerr2 = cli.Node()
58*cfb92d14SAndroid Build Coastguard Workerr3 = cli.Node()
59*cfb92d14SAndroid Build Coastguard Workerr4 = cli.Node()
60*cfb92d14SAndroid Build Coastguard Workerfed1 = cli.Node()
61*cfb92d14SAndroid Build Coastguard Worker
62*cfb92d14SAndroid Build Coastguard Workernodes = [r1, r2, r3, r4, fed1]
63*cfb92d14SAndroid Build Coastguard Worker
64*cfb92d14SAndroid Build Coastguard Worker# -----------------------------------------------------------------------------------------------------------------------
65*cfb92d14SAndroid Build Coastguard Worker# Form topology
66*cfb92d14SAndroid Build Coastguard Worker
67*cfb92d14SAndroid Build Coastguard Workerr1.allowlist_node(r2)
68*cfb92d14SAndroid Build Coastguard Workerr1.allowlist_node(fed1)
69*cfb92d14SAndroid Build Coastguard Worker
70*cfb92d14SAndroid Build Coastguard Workerr2.allowlist_node(r1)
71*cfb92d14SAndroid Build Coastguard Workerr2.allowlist_node(r3)
72*cfb92d14SAndroid Build Coastguard Worker
73*cfb92d14SAndroid Build Coastguard Workerr3.allowlist_node(r2)
74*cfb92d14SAndroid Build Coastguard Workerr3.allowlist_node(r4)
75*cfb92d14SAndroid Build Coastguard Worker
76*cfb92d14SAndroid Build Coastguard Workerr4.allowlist_node(r3)
77*cfb92d14SAndroid Build Coastguard Worker
78*cfb92d14SAndroid Build Coastguard Workerfed1.allowlist_node(r1)
79*cfb92d14SAndroid Build Coastguard Worker
80*cfb92d14SAndroid Build Coastguard Workerr1.form("srv-aloc")
81*cfb92d14SAndroid Build Coastguard Workerr2.join(r1)
82*cfb92d14SAndroid Build Coastguard Workerr3.join(r2)
83*cfb92d14SAndroid Build Coastguard Workerr4.join(r3)
84*cfb92d14SAndroid Build Coastguard Workerfed1.join(r1, cli.JOIN_TYPE_REED)
85*cfb92d14SAndroid Build Coastguard Worker
86*cfb92d14SAndroid Build Coastguard Workerverify(r1.get_state() == 'leader')
87*cfb92d14SAndroid Build Coastguard Workerverify(r2.get_state() == 'router')
88*cfb92d14SAndroid Build Coastguard Workerverify(r3.get_state() == 'router')
89*cfb92d14SAndroid Build Coastguard Workerverify(r4.get_state() == 'router')
90*cfb92d14SAndroid Build Coastguard Workerverify(fed1.get_state() == 'child')
91*cfb92d14SAndroid Build Coastguard Worker
92*cfb92d14SAndroid Build Coastguard Worker# -----------------------------------------------------------------------------------------------------------------------
93*cfb92d14SAndroid Build Coastguard Worker# Test Implementation
94*cfb92d14SAndroid Build Coastguard Worker
95*cfb92d14SAndroid Build Coastguard Worker# Wait till first router has either established a link or
96*cfb92d14SAndroid Build Coastguard Worker# has a valid "next hop" towards all other routers.
97*cfb92d14SAndroid Build Coastguard Worker
98*cfb92d14SAndroid Build Coastguard Workerr1_rloc16 = int(r1.get_rloc16(), 16)
99*cfb92d14SAndroid Build Coastguard Worker
100*cfb92d14SAndroid Build Coastguard Worker
101*cfb92d14SAndroid Build Coastguard Workerdef check_r1_router_table():
102*cfb92d14SAndroid Build Coastguard Worker    table = r1.get_router_table()
103*cfb92d14SAndroid Build Coastguard Worker    verify(len(table) == 4)
104*cfb92d14SAndroid Build Coastguard Worker    for entry in table:
105*cfb92d14SAndroid Build Coastguard Worker        verify(int(entry['RLOC16'], 0) == r1_rloc16 or int(entry['Link']) == 1 or int(entry['Next Hop']) != 63)
106*cfb92d14SAndroid Build Coastguard Worker
107*cfb92d14SAndroid Build Coastguard Worker
108*cfb92d14SAndroid Build Coastguard Workerverify_within(check_r1_router_table, 120)
109*cfb92d14SAndroid Build Coastguard Worker
110*cfb92d14SAndroid Build Coastguard Worker# Add the same service on `r4` and `fed1`
111*cfb92d14SAndroid Build Coastguard Worker
112*cfb92d14SAndroid Build Coastguard Workerr4.cli('service add 44970 11 00')
113*cfb92d14SAndroid Build Coastguard Workerr4.register_netdata()
114*cfb92d14SAndroid Build Coastguard Worker
115*cfb92d14SAndroid Build Coastguard Workerfed1.cli('service add 44970 11 00')
116*cfb92d14SAndroid Build Coastguard Workerfed1.register_netdata()
117*cfb92d14SAndroid Build Coastguard Worker
118*cfb92d14SAndroid Build Coastguard Worker
119*cfb92d14SAndroid Build Coastguard Workerdef check_netdata_services(expected_num_services):
120*cfb92d14SAndroid Build Coastguard Worker    # Check that all nodes see the `expected_num_services` service
121*cfb92d14SAndroid Build Coastguard Worker    # entries in network data.
122*cfb92d14SAndroid Build Coastguard Worker    for node in nodes:
123*cfb92d14SAndroid Build Coastguard Worker        verify(len(node.get_netdata_services()) == expected_num_services)
124*cfb92d14SAndroid Build Coastguard Worker
125*cfb92d14SAndroid Build Coastguard Worker
126*cfb92d14SAndroid Build Coastguard Workerverify_within(check_netdata_services, 100, 2)
127*cfb92d14SAndroid Build Coastguard Worker
128*cfb92d14SAndroid Build Coastguard Worker# Determine the ALOC address of the added service.
129*cfb92d14SAndroid Build Coastguard Worker
130*cfb92d14SAndroid Build Coastguard Workeraloc = r4.get_mesh_local_prefix().split('/')[0] + 'ff:fe00:fc10'
131*cfb92d14SAndroid Build Coastguard Worker
132*cfb92d14SAndroid Build Coastguard Worker# Ping ALOC address from `r3` and verify that `r4` responds.
133*cfb92d14SAndroid Build Coastguard Worker# `r4` should be chosen due to its shorter path cost from `r3`.
134*cfb92d14SAndroid Build Coastguard Worker
135*cfb92d14SAndroid Build Coastguard Workerold_counters = r4.get_ip_counters()
136*cfb92d14SAndroid Build Coastguard Workerr3.ping(aloc)
137*cfb92d14SAndroid Build Coastguard Workernew_counters = r4.get_ip_counters()
138*cfb92d14SAndroid Build Coastguard Worker
139*cfb92d14SAndroid Build Coastguard Workerverify(int(new_counters['RxSuccess']) > int(old_counters['RxSuccess']))
140*cfb92d14SAndroid Build Coastguard Workerverify(int(new_counters['TxSuccess']) > int(old_counters['TxSuccess']))
141*cfb92d14SAndroid Build Coastguard Worker
142*cfb92d14SAndroid Build Coastguard Worker# Ping ALOC address from `r1` and verify that `fed1` responds.
143*cfb92d14SAndroid Build Coastguard Worker# `fed1` should be chosen due to its shorter path cost from `r1`.
144*cfb92d14SAndroid Build Coastguard Worker
145*cfb92d14SAndroid Build Coastguard Workerold_counters = fed1.get_ip_counters()
146*cfb92d14SAndroid Build Coastguard Workerr1.ping(aloc)
147*cfb92d14SAndroid Build Coastguard Workernew_counters = fed1.get_ip_counters()
148*cfb92d14SAndroid Build Coastguard Worker
149*cfb92d14SAndroid Build Coastguard Workerverify(int(new_counters['RxSuccess']) > int(old_counters['RxSuccess']))
150*cfb92d14SAndroid Build Coastguard Workerverify(int(new_counters['TxSuccess']) > int(old_counters['TxSuccess']))
151*cfb92d14SAndroid Build Coastguard Worker
152*cfb92d14SAndroid Build Coastguard Worker# Ping ALOC address from `r2` and verify that `r4` responds.
153*cfb92d14SAndroid Build Coastguard Worker# Both `r4` and `fed1` have the same path cost, but `r4` is
154*cfb92d14SAndroid Build Coastguard Worker# preferred because it is acting as a router.
155*cfb92d14SAndroid Build Coastguard Worker
156*cfb92d14SAndroid Build Coastguard Workerold_counters = r4.get_ip_counters()
157*cfb92d14SAndroid Build Coastguard Workerr2.ping(aloc)
158*cfb92d14SAndroid Build Coastguard Workernew_counters = r4.get_ip_counters()
159*cfb92d14SAndroid Build Coastguard Worker
160*cfb92d14SAndroid Build Coastguard Workerverify(int(new_counters['RxSuccess']) > int(old_counters['RxSuccess']))
161*cfb92d14SAndroid Build Coastguard Workerverify(int(new_counters['TxSuccess']) > int(old_counters['TxSuccess']))
162*cfb92d14SAndroid Build Coastguard Worker
163*cfb92d14SAndroid Build Coastguard Worker# -----------------------------------------------------------------------------------------------------------------------
164*cfb92d14SAndroid Build Coastguard Worker# Test finished
165*cfb92d14SAndroid Build Coastguard Worker
166*cfb92d14SAndroid Build Coastguard Workercli.Node.finalize_all_nodes()
167*cfb92d14SAndroid Build Coastguard Worker
168*cfb92d14SAndroid Build Coastguard Workerprint('\'{}\' passed.'.format(test_name))
169