blob: 39c2aa7aef7d4a8efbe4136137de0c89a119f8f2 [file] [log] [blame]
Gilles Depatieb5682f82019-10-31 10:39:45 -04001#Copyright 2017-present Open Networking Foundation
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
15*** Settings ***
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053016Documentation Test suite that engages a larger number of ONU at the same which makes it a more realistic test
17... It is addaptable to either BBSim or Real H/W using a configuration file
Gilles Depatieb5682f82019-10-31 10:39:45 -040018Suite Setup Setup Suite
19Suite Teardown Teardown Suite
20Library Collections
21Library String
22Library OperatingSystem
23Library XML
24Library RequestsLibrary
25Library ../../libraries/DependencyLibrary.py
26Resource ../../libraries/onos.robot
27Resource ../../libraries/voltctl.robot
28Resource ../../libraries/utils.robot
29Resource ../../libraries/k8s.robot
30Resource ../../variables/variables.robot
31
32*** Variables ***
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053033${timeout} 60s
Andy Baviere118e052020-03-06 12:49:24 -070034${long_timeout} 420
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053035${of_id} 0
36${logical_id} 0
Gilles Depatieb5682f82019-10-31 10:39:45 -040037${has_dataplane} True
Gilles Depatieb5682f82019-10-31 10:39:45 -040038${teardown_device} False
39
40*** Test Cases ***
41Activate Devices OLT/ONU
42 [Documentation] Validate deployment -> Empty Device List
43 ... create and enable device -> Preprovision and Enable
44 ... re-validate deployment -> Active OLT
45 [Tags] active
46 #test for empty device list
David Bainbridgef81cd642019-11-20 00:14:47 +000047 Test Empty Device List
Gilles Depatieb5682f82019-10-31 10:39:45 -040048 #create/preprovision device
49 ${olt_device_id}= Create Device ${olt_ip} ${OLT_PORT}
50 Set Global Variable ${olt_device_id}
51 #validate olt states
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053052 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Device PREPROVISIONED UNKNOWN UNKNOWN
Andy Baviere118e052020-03-06 12:49:24 -070053 ... ${olt_device_id}
Gilles Depatieb5682f82019-10-31 10:39:45 -040054 #enable device
55 Enable Device ${olt_device_id}
56 #validate olt states
Andy Baviere118e052020-03-06 12:49:24 -070057 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Device ENABLED ACTIVE REACHABLE
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053058 ... ${olt_device_id}
Gilles Depatieb5682f82019-10-31 10:39:45 -040059
60ONU Discovery
61 [Documentation] Discover lists of ONUS, their Serial Numbers and device id
62 [Tags] active
63 #build onu sn list
64 ${List_ONU_Serial} Create List
65 Set Suite Variable ${List_ONU_Serial}
66 Build ONU SN List ${List_ONU_Serial}
Gilles Depatieb5682f82019-10-31 10:39:45 -040067 #validate onu states
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053068 Wait Until Keyword Succeeds ${long_timeout} 20s Validate ONU Devices ENABLED ACTIVE REACHABLE
69 ... ${List_ONU_Serial}
70
71Verify AAA-Users Authentication
72 [Documentation] Authenticating all AAA-users in onos
73 [Tags] VOL-1823 active
74 #build onu sn list
75 ${List_ONU_Serial} Create List
76 Set Suite Variable ${List_ONU_Serial}
77 Build ONU SN List ${List_ONU_Serial}
Andy Baviere118e052020-03-06 12:49:24 -070078 Wait Until Keyword Succeeds ${long_timeout} 60s Verify Number of AAA-Users ${ONOS_SSH_IP}
79 ... ${ONOS_SSH_PORT} 16
Gilles Depatieb5682f82019-10-31 10:39:45 -040080
81Validate Device's Ports and Flows
82 [Documentation] Verify Ports and Flows listed for OLT and ONUs
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053083 ... For OLT we validate the port types and numbers and for flows we simply verify that their numbers > 0
Gilles Depatieb5682f82019-10-31 10:39:45 -040084 ... For each ONU, we validate the port types and numbers for each and for flows.
85 ... For flows they should be == 0 at this stage
86 [Tags] active
87 #validate olt port types
88 Validate OLT Port Types PON_OLT ETHERNET_NNI
89 #validate olt flows
Andy Bavierac7e5972019-11-14 15:35:48 -070090 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Flows
Gilles Depatieb5682f82019-10-31 10:39:45 -040091 #validate onu port types
92 Validate ONU Port Types ${List_ONU_Serial} PON_ONU ETHERNET_UNI
93 #validate onu flows
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +053094 Wait Until Keyword Succeeds ${timeout} 5s Validate ONU Flows ${List_ONU_Serial} ${num_onu_flows}
95
96Verify Total Number Of Eapol Flows
97 [Documentation] Verify Flows listed for ONUs
98 ... For 16 ONUs we validate the number of flows to be 16 eapol flows
99 [Tags] VOL-1823 active
100 #verify eapol flows added
Andy Baviere118e052020-03-06 12:49:24 -0700101 Wait Until Keyword Succeeds ${long_timeout} 5s Verify Eapol Flows Added ${ONOS_SSH_IP}
102 ... ${ONOS_SSH_PORT} 16
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530103
104Allocate DHCP To All ONU Devices
105 [Documentation] DHCP Allocation for all ONUs
106 [Tags] VOL-1824 active
107 ${of_id}= Wait Until Keyword Succeeds ${timeout} 15s Validate OLT Device in ONOS ${olt_serial_number}
108 Set Global Variable ${of_id}
109 FOR ${I} IN RANGE 0 ${num_onus}
110 ${src}= Set Variable ${hosts.src[${I}]}
111 ${dst}= Set Variable ${hosts.dst[${I}]}
Andy Baviere118e052020-03-06 12:49:24 -0700112 ${onu_device_id}= Get Device ID From SN ${src['onu']}
113 ${onu_port}= Run Keyword And Continue On Failure Wait Until Keyword Succeeds ${timeout} 2s
114 ... Get ONU Port in ONOS ${src['onu']} ${of_id}
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530115 Run Keyword And Continue On Failure Wait Until Keyword Succeeds ${timeout} 2
Andy Baviere118e052020-03-06 12:49:24 -0700116 ... Execute ONOS CLI Command ${ONOS_SSH_IP} ${ONOS_SSH_PORT}
117 ... volt-add-subscriber-access ${of_id} ${onu_port}
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530118 END
119
120Validate Total Number Of DHCP Allocations
121 [Documentation] Verify dhcp allocation for multiple ONU user
122 [Tags] VOL-1824 active
123 #validate total number of DHCP allocations
ubuntu6b6e7d42020-03-02 12:35:42 -0800124 Wait Until Keyword Succeeds ${long_timeout} 20s Validate DHCP Allocations ${ONOS_SSH_IP}
Andy Baviere118e052020-03-06 12:49:24 -0700125 ... ${ONOS_SSH_PORT} 16
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530126 #validate DHCP allocation for each port
127 FOR ${I} IN RANGE 0 ${num_onus}
128 ${src}= Set Variable ${hosts.src[${I}]}
129 ${dst}= Set Variable ${hosts.dst[${I}]}
130 ${onu_device_id}= Get Device ID From SN ${src['onu']}
Andy Baviere118e052020-03-06 12:49:24 -0700131 ${onu_port}= Run Keyword And Continue On Failure Wait Until Keyword Succeeds ${timeout} 2s
132 ... Get ONU Port in ONOS ${src['onu']} ${of_id}
133 Wait Until Keyword Succeeds ${long_timeout} 20s Validate Subscriber DHCP Allocation ${ONOS_SSH_IP}
134 ... ${ONOS_SSH_PORT} ${onu_port}
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530135 END
Gilles Depatieb5682f82019-10-31 10:39:45 -0400136
137Validate Logical Device
138 [Documentation] Verify that logical device exists and then verify its ports and flows
139 [Tags] active
140 #Verify logical device exists
141 ${logical_device_id}= Validate Logical Device
142 #Verify logical device ports
143 Validate Logical Device Ports ${logical_device_id}
144 #Verify logical device flows
145 Validate Logical Device Flows ${logical_device_id}
146
147Validate Peer Devices
148 [Documentation] Verify that peer lists matches up between that of ${olt_device_id}
149 ... and individual ONU device ids
150 [Tags] active
151 #Retrieve peer list from OLT
152 ${olt_peer_list}= Create List
153 Retrieve Peer List From OLT ${olt_peer_list}
154 Log ${olt_peer_list}
155 #Validate OLT peer id list
156 Validate OLT Peer Id List ${olt_peer_list}
157 #Validate ONU peer ids
158 Validate ONU Peer Id ${olt_device_id} ${List_ONU_Serial}
159
Debasish28130d02020-03-16 11:05:26 +0000160Test Disable and Enable ONU
161 [Documentation] Perform disable/enable on the ONUs and validate test assertions
162 [Tags] active VOL-2732
163 FOR ${I} IN RANGE 0 ${num_onus}
164 ${src}= Set Variable ${hosts.src[${I}]}
165 ${dst}= Set Variable ${hosts.dst[${I}]}
166 ${onu_device_id}= Get Device ID From SN ${src['onu']}
167 Disable Device ${onu_device_id}
168 END
169 Wait Until Keyword Succeeds ${long_timeout} 20s Validate ONU Devices DisableEnable
170 ... DISABLED UNKNOWN REACHABLE ${List_ONU_Serial}
171 FOR ${I} IN RANGE 0 ${num_onus}
172 ${src}= Set Variable ${hosts.src[${I}]}
173 ${dst}= Set Variable ${hosts.dst[${I}]}
174 ${onu_device_id}= Get Device ID From SN ${src['onu']}
175 Enable Device ${onu_device_id}
176 END
177 Wait Until Keyword Succeeds ${long_timeout} 20s Validate ONU Devices DisableEnable
178 ... ENABLED ACTIVE REACHABLE ${List_ONU_Serial}
179
Gilles Depatieb5682f82019-10-31 10:39:45 -0400180*** Keywords ***
181Setup Suite
Andy Bavier88cd9f62019-11-26 16:22:33 -0700182 [Documentation] Set up the test suite
183 Common Test Suite Setup
Gilles Depatieb5682f82019-10-31 10:39:45 -0400184
185Teardown Suite
186 [Documentation] Clean up devices if desired
187 ... kills processes and cleans up interfaces on src+dst servers
ubuntu6b6e7d42020-03-02 12:35:42 -0800188 Get ONOS Status ${ONOS_SSH_IP} ${ONOS_SSH_PORT}
Gilles Depatieb5682f82019-10-31 10:39:45 -0400189 Run Keyword If ${has_dataplane} Clean Up Linux
Gilles Depatieb5682f82019-10-31 10:39:45 -0400190 Run Keyword If ${teardown_device} Delete Device and Verify
David Bainbridgef81cd642019-11-20 00:14:47 +0000191 Run Keyword If ${teardown_device} Test Empty Device List
ubuntu6b6e7d42020-03-02 12:35:42 -0800192 Run Keyword If ${teardown_device} Execute ONOS CLI Command ${ONOS_SSH_IP} ${ONOS_SSH_PORT}
Gilles Depatieb5682f82019-10-31 10:39:45 -0400193 ... device-remove ${of_id}
194
195Clean Up Linux
196 [Documentation] Kill processes and clean up interfaces on src+dst servers
197 FOR ${I} IN RANGE 0 ${num_onus}
198 ${src}= Set Variable ${hosts.src[${I}]}
199 ${dst}= Set Variable ${hosts.dst[${I}]}
200 Run Keyword And Ignore Error Kill Linux Process [w]pa_supplicant ${src['ip']}
201 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
202 Run Keyword And Ignore Error Kill Linux Process [d]hclient ${src['ip']}
203 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
204 Run Keyword If '${dst['ip']}' != '${None}' Run Keyword And Ignore Error
205 ... Kill Linux Process [d]hcpd ${dst['ip']} ${dst['user']}
206 ... ${dst['pass']} ${dst['container_type']} ${dst['container_name']}
207 Delete IP Addresses from Interface on Remote Host ${src['dp_iface_name']} ${src['ip']}
208 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
209 Run Keyword If '${dst['ip']}' != '${None}' Delete Interface on Remote Host
210 ... ${dst['dp_iface_name']}.${src['s_tag']} ${dst['ip']} ${dst['user']} ${dst['pass']}
211 ... ${dst['container_type']} ${dst['container_name']}
212 END
213
214Delete Device and Verify
215 [Documentation] Disable -> Delete devices via voltctl and verify its removed
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530216 ${rc} ${output}= Run and Return Rc and Output ${VOLTCTL_CONFIG}; voltctl device disable ${olt_device_id}
Gilles Depatieb5682f82019-10-31 10:39:45 -0400217 Should Be Equal As Integers ${rc} 0
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530218 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Device DISABLED UNKNOWN REACHABLE
219 ... ${olt_serial_number}
Hardik Windlass7da42ca2020-03-13 14:25:44 +0530220 Delete Device ${olt_device_id}
DEBASISH MOHAPATRO8d8b8db2020-02-07 13:04:14 +0530221 Wait Until Keyword Succeeds ${timeout} 5s Validate Device Removed ${olt_device_id}