blob: a870073d750007ee796eea315f50669d88d38e9d [file] [log] [blame]
Joey Armstrong9fadcbe2024-01-17 19:00:37 -05001# Copyright 2020-2024 Open Networking Foundation (ONF) and the ONF Contributors
bharat raj58488b32023-05-11 22:46:18 +05302#
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 ***
16Documentation Test various end-to-end scenarios involing Multiple OLTs
17Suite Setup Setup Suite
18Test Setup Setup
19Test Teardown Teardown
20Suite Teardown Teardown Suite
21Library Collections
22Library String
23Library OperatingSystem
24Library XML
25Library RequestsLibrary
26Library ../../libraries/DependencyLibrary.py
27Resource ../../libraries/vgc.robot
28Resource ../../libraries/voltctl.robot
29Resource ../../libraries/voltha.robot
30Resource ../../libraries/utils_vgc.robot
31Resource ../../libraries/k8s.robot
32Resource ../../variables/variables.robot
33Resource ../../libraries/power_switch.robot
34
35*** Variables ***
36${POD_NAME} flex-ocp-cord
37${KUBERNETES_CONF} ${KUBERNETES_CONFIGS_DIR}/${POD_NAME}.conf
38${KUBERNETES_CONFIGS_DIR} ~/pod-configs/kubernetes-configs
39#${KUBERNETES_CONFIGS_DIR} ${KUBERNETES_CONFIGS_DIR}/${POD_NAME}.conf
40${KUBERNETES_YAML} ${KUBERNETES_CONFIGS_DIR}/${POD_NAME}.yml
41${HELM_CHARTS_DIR} ~/helm-charts
42${VOLTHA_POD_NUM} 8
43${NAMESPACE} voltha
44${INFRA_NAMESPACE} default
45# For below variable value, using deployment name as using grep for
46# parsing radius pod name, we can also use full radius pod name
47${RESTART_POD_NAME} radius
48${timeout} 60s
49${of_id} 0
50${logical_id} 0
51${has_dataplane} True
52${teardown_device} False
53${scripts} ../../scripts
54
55# Per-test logging on failure is turned off by default; set this variable to enable
56${container_log_dir} ${None}
57
58# logging flag to enable Collect Logs, can be passed via the command line too
59# example: -v logging:False
60${logging} True
61
62*** Test Cases ***
63Verify OLT after Rebooting Physically for DT - Multiple OLT
64 [Documentation] Test the physical reboot of the OLT
65 ... Assuming that all the ONUs are DHCP/pingable (i.e. assuming sanityDt test was executed)
66 ... Test performs a physical reboot, performs "reboot" from the OLT CLI
67 ... Test runs when more than one OLT exists
68 ... Only one OLT is rebooted in the test, while verifying if the ONUs on the
69 ... other OLT are still functional
70 [Tags] functionalDt MultiOLTPhysicalRebootDt
71 [Setup] Start Logging MultiOlt_Physical_Dt
72 [Teardown] Run Keywords Collect Logs
73 ... AND Stop Logging MultiOlt_Physical_Dt
74 # Execute the test when the number of OLTs are greater than one
75 Pass Execution If ${olt_count} == 1 Skipping test: just one OLT
76 Clear All Devices Then Perform Setup And Sanity
77 # Reboot the first OLT from the list of olts - rebooting from the OLT CLI
78 ${olt_user}= Get From Dictionary ${list_olts}[0] user
79 ${olt_pass}= Get From Dictionary ${list_olts}[0] pass
80 ${olt_ssh_ip}= Get From Dictionary ${list_olts}[0] sship
81 ${olt_serial_number}= Get From Dictionary ${list_olts}[0] sn
82 ${olt_device_id}= Get OLTDeviceID From OLT List ${olt_serial_number}
83 Run Keyword If ${has_dataplane} Login And Run Command On Remote System
84 ... reboot ${olt_ssh_ip} ${olt_user} ${olt_pass} prompt=#
85 # validate that the ONUs on the other OLTs are still functional
86 Verify ping is successful for ONUs not on this OLT ${num_all_onus} ${olt_device_id}
87
88 # validate that the ONUs on the rebooted OLT are not pingable
89 FOR ${I} IN RANGE 0 ${num_all_onus}
90 ${src}= Set Variable ${hosts.src[${I}]}
91 ${dst}= Set Variable ${hosts.dst[${I}]}
92 ${olt_serial_number}= Get From Dictionary ${list_olts}[0] sn
93 Continue For Loop If "${olt_serial_number}"!="${src['olt']}"
94 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure
95 ... Wait Until Keyword Succeeds ${timeout} 2s
96 ... Check Ping False ${dst['dp_iface_ip_qinq']} ${src['dp_iface_name']}
97 ... ${src['ip']} ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
98 END
99 # Wait for the rebooted OLT to come back up
100 ${olt_user}= Get From Dictionary ${list_olts}[0] user
101 ${olt_pass}= Get From Dictionary ${list_olts}[0] pass
102 ${olt_ssh_ip}= Get From Dictionary ${list_olts}[0] sship
103 ${olt_serial_number}= Get From Dictionary ${list_olts}[0] sn
104 ${olt_device_id}= Get OLTDeviceID From OLT List ${olt_serial_number}
105 Run Keyword If ${has_dataplane} Wait Until Keyword Succeeds 120s 10s
106 ... Check Remote System Reachability True ${olt_ssh_ip}
107 Wait Until Keyword Succeeds 360s 5s
108 ... Validate OLT Device ENABLED ACTIVE
109 ... REACHABLE ${olt_serial_number}
110 # Waiting extra time for the ONUs to come up
111 Sleep 60s
112 Run Keyword If ${has_dataplane} Clean Up Linux
113 Perform Sanity Test DT
114
115Verify OLT Soft Reboot for DT - Multiple OLT
116 [Documentation] Test soft reboot of the OLT using voltctl command
117 ... Test runs when more than one OLT exists
118 ... Only one OLT is rebooted in the test, while verifying if the ONUs on the
119 ... other OLT are still functional
120 [Tags] MultiOLTSoftRebootDt functionalDt
121 [Setup] Start Logging MultiOLTSoftRebootDt
122 [Teardown] Run Keywords Collect Logs
123 ... AND Delete All Devices and Verify
124 ... AND Run Keyword If ${logging} Collect Logs
125 ... AND Stop Logging MultiOLTSoftRebootDt
126 Pass Execution If ${olt_count} == 1 Skipping test: just one OLT
127 Clear All Devices Then Perform Setup And Sanity
128 # Reboot the first OLT
129 ${olt_user}= Get From Dictionary ${list_olts}[0] user
130 ${olt_pass}= Get From Dictionary ${list_olts}[0] pass
131 ${olt_ssh_ip}= Get From Dictionary ${list_olts}[0] sship
132 ${olt_serial_number}= Get From Dictionary ${list_olts}[0] sn
133 ${olt_device_id}= Get OLTDeviceID From OLT List ${olt_serial_number}
134 Run Keyword And Continue On Failure Wait Until Keyword Succeeds 360s 5s
135 ... Validate OLT Device ENABLED ACTIVE
136 ... REACHABLE ${olt_serial_number}
137 # Reboot the OLT using "voltctl device reboot" command
138 Reboot Device ${olt_device_id}
139 # Wait for the OLT to actually go down
140 Wait Until Keyword Succeeds 360s 5s Validate OLT Device ENABLED UNKNOWN UNREACHABLE
141 ... ${olt_serial_number}
142 # validate that the ONUs on the other OLTs are still functional
143 Verify ping is successful for ONUs not on this OLT ${num_all_onus} ${olt_device_id}
144 #Verify that ping fails for the ONUs where the OLT has been rebooted
145 FOR ${I} IN RANGE 0 ${num_all_onus}
146 ${src}= Set Variable ${hosts.src[${I}]}
147 ${dst}= Set Variable ${hosts.dst[${I}]}
148 ${olt_serial_number}= Get From Dictionary ${list_olts}[0] sn
149 Continue For Loop If "${olt_serial_number}"!="${src['olt']}"
150 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure
151 ... Wait Until Keyword Succeeds ${timeout} 2s
152 ... Check Ping False ${dst['dp_iface_ip_qinq']} ${src['dp_iface_name']}
153 ... ${src['ip']} ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
154 END
155 # Check OLT state
156 ${olt_serial_number}= Get From Dictionary ${list_olts}[0] sn
157 ${olt_ssh_ip}= Get From Dictionary ${list_olts}[0] sship
158 ${olt_device_id}= Get OLTDeviceID From OLT List ${olt_serial_number}
159 # Wait for the OLT to come back up
160 Run Keyword If ${has_dataplane} Wait Until Keyword Succeeds 120s 10s
161 ... Check Remote System Reachability True ${olt_ssh_ip}
162 # Check OLT states
163 Wait Until Keyword Succeeds 360s 5s
164 ... Validate OLT Device ENABLED ACTIVE
165 ... REACHABLE ${olt_serial_number}
166 # Waiting extra time for the ONUs to come up
167 Sleep 60s
168 #Check after reboot that ONUs are active, DHCP and pingable
169 Run Keyword If ${has_dataplane} Clean Up Linux
170 Perform Sanity Test DT
171
172*** Keywords ***
173Setup Suite
174 [Documentation] Set up the test suite
175 Common Test Suite Setup
176 #power_switch.robot needs it to support different vendor's power switch
177 ${switch_type}= Get Variable Value ${web_power_switch.type}
178 Run Keyword If "${switch_type}"!="" Set Global Variable ${powerswitch_type} ${switch_type}
179
180Clear All Devices Then Perform Setup And Sanity
181 [Documentation] Remove any devices from VOLTHA and Verify in VGC
182 ... Create New Device through Setup and Perform Sanity
183 # Remove all devices from voltha and nos
184 Delete All Devices and Verify
185 # Execute normal test Setup Keyword
186 Setup
187 # Performing Sanity Test to make sure subscribers are all DHCP and pingable
188 Run Keyword If ${has_dataplane} Clean Up Linux
189 Perform Sanity Test DT