blob: b394b1b574f525f2d01b2df8842d18002c4c0b31 [file] [log] [blame]
Suchitra Vemuri3f8b0f62019-09-12 13:25:16 -07001#Copyright 2017-present Open Networking Foundation
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -07002#
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
Matteo Scandolo1294aeb2019-09-24 16:20:32 -070015# FIXME Can we use the same test against BBSim and Hardware?
16
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070017*** Settings ***
Zack Williamsec53a1b2019-09-16 15:50:52 -070018Documentation Test various end-to-end scenarios
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070019Suite Setup Setup Suite
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070020Test Setup Setup
21Test Teardown Teardown
Andy Bavierba9866b2019-10-11 07:11:53 -070022Suite Teardown Teardown Suite
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070023Library Collections
24Library String
25Library OperatingSystem
26Library XML
27Library RequestsLibrary
Andy Bavierba9866b2019-10-11 07:11:53 -070028Library ../../libraries/DependencyLibrary.py
Suchitra Vemurib8ed2d52019-09-30 13:22:51 -070029Resource ../../libraries/onos.robot
30Resource ../../libraries/voltctl.robot
31Resource ../../libraries/utils.robot
Andy Bavierba9866b2019-10-11 07:11:53 -070032Resource ../../libraries/k8s.robot
Suchitra Vemurib8ed2d52019-09-30 13:22:51 -070033Resource ../../variables/variables.robot
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070034
35*** Variables ***
Zack Williamsec53a1b2019-09-16 15:50:52 -070036${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
suraj gourd64356b2019-11-07 13:26:20 +000043${NAMESPACE} voltha
44# For below variable value, using deployment name as using grep for
45# parsing radius pod name, we can also use full radius pod name
46${RESTART_POD_NAME} radius
Andy Bavierba9866b2019-10-11 07:11:53 -070047${timeout} 60s
Zack Williamsec53a1b2019-09-16 15:50:52 -070048${of_id} 0
49${logical_id} 0
Andy Bavierba9866b2019-10-11 07:11:53 -070050${has_dataplane} True
51${external_libs} True
52${teardown_device} False
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070053
54*** Test Cases ***
55Sanity E2E Test for OLT/ONU on POD
56 [Documentation] Validates E2E Ping Connectivity and object states for the given scenario:
57 ... Validate successful authentication/DHCP/E2E ping for the tech profile that is used
Andy Bavierba9866b2019-10-11 07:11:53 -070058 [Tags] sanity test1
Zack Williamsec53a1b2019-09-16 15:50:52 -070059 #[Setup] Clean Up Linux
suraj gourd64356b2019-11-07 13:26:20 +000060 [Teardown] NONE
Andy Bavierba9866b2019-10-11 07:11:53 -070061 ${of_id}= Wait Until Keyword Succeeds ${timeout} 15s Validate OLT Device in ONOS ${olt_serial_number}
62 Set Global Variable ${of_id}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -070063
64 FOR ${I} IN RANGE 0 ${num_onus}
65 ${src}= Set Variable ${hosts.src[${I}]}
66 ${dst}= Set Variable ${hosts.dst[${I}]}
67
Gilles Depatieb5682f82019-10-31 10:39:45 -040068 Wait Until Keyword Succeeds ${timeout} 5s Validate Device ENABLED ACTIVE REACHABLE
69 ... ${src['onu']} onu=True onu_reason=omci-flows-pushed
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -070070
71 ${onu_device_id}= Get Device ID From SN ${src['onu']}
Gilles Depatie675a2062019-10-22 12:44:42 -040072 ${onu_port}= Wait Until Keyword Succeeds ${timeout} 2s Get ONU Port in ONOS ${src['onu']}
73 ... ${of_id}
74 Wait Until Keyword Succeeds ${timeout} 2s Verify Eapol Flows Added For ONU ${k8s_node_ip}
75 ... ${ONOS_SSH_PORT} ${onu_port}
76 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure Validate Authentication True
77 ... ${src['dp_iface_name']} wpa_supplicant.conf ${src['ip']} ${src['user']} ${src['pass']}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -070078 ... ${src['container_type']} ${src['container_name']}
Gilles Depatie675a2062019-10-22 12:44:42 -040079 Wait Until Keyword Succeeds ${timeout} 2s Verify ONU in AAA-Users ${k8s_node_ip}
80 ... ${ONOS_SSH_PORT} ${onu_port}
81 Wait Until Keyword Succeeds ${timeout} 2s Execute ONOS CLI Command ${k8s_node_ip}
82 ... ${ONOS_SSH_PORT} volt-add-subscriber-access ${of_id} ${onu_port}
83 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure Validate DHCP and Ping True
84 ... True ${src['dp_iface_name']} ${src['s_tag']} ${src['c_tag']} ${dst['dp_iface_ip_qinq']}
85 ... ${src['ip']} ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
86 ... ${dst['dp_iface_name']} ${dst['ip']} ${dst['user']} ${dst['pass']} ${dst['container_type']}
87 ... ${dst['container_name']}
88 Wait Until Keyword Succeeds ${timeout} 2s Run Keyword And Continue On Failure
89 ... Validate Subscriber DHCP Allocation ${k8s_node_ip} ${ONOS_SSH_PORT} ${onu_port}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -070090 END
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070091
suraj gourd64356b2019-11-07 13:26:20 +000092Check OLT/ONU Authentication After Radius Pod Restart
93 [Documentation] After radius restart, validates eapol flows and dhcp allocation
94 ... and validates onu in onos
95 [Tags] sanity test2
96 #[Setup] Clean Up Linux
97 [Setup] NONE
98 Wait Until Keyword Succeeds ${timeout} 15s Restart Pod ${NAMESPACE} ${RESTART_POD_NAME}
99
100 FOR ${I} IN RANGE 0 ${num_onus}
101 ${src}= Set Variable ${hosts.src[${I}]}
102 ${dst}= Set Variable ${hosts.dst[${I}]}
103
104
105 ${onu_device_id}= Get Device ID From SN ${src['onu']}
106 ${onu_port}= Wait Until Keyword Succeeds ${timeout} 2s Get ONU Port in ONOS ${src['onu']}
107 ... ${of_id}
108 Wait Until Keyword Succeeds ${timeout} 2s Verify Eapol Flows Added For ONU ${k8s_node_ip}
109 ... ${ONOS_SSH_PORT} ${onu_port}
110 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure Validate Authentication True
111 ... ${src['dp_iface_name']} wpa_supplicant.conf ${src['ip']} ${src['user']} ${src['pass']}
112 ... ${src['container_type']} ${src['container_name']}
113 Wait Until Keyword Succeeds ${timeout} 2s Verify ONU in AAA-Users ${k8s_node_ip}
114 ... ${ONOS_SSH_PORT} ${onu_port}
115 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure Validate DHCP and Ping True
116 ... True ${src['dp_iface_name']} ${src['s_tag']} ${src['c_tag']} ${dst['dp_iface_ip_qinq']}
117 ... ${src['ip']} ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
118 ... ${dst['dp_iface_name']} ${dst['ip']} ${dst['user']} ${dst['pass']} ${dst['container_type']}
119 ... ${dst['container_name']}
120 Wait Until Keyword Succeeds ${timeout} 2s Run Keyword And Continue On Failure
121 ... Validate Subscriber DHCP Allocation ${k8s_node_ip} ${ONOS_SSH_PORT} ${onu_port}
122 END
123
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700124*** Keywords ***
125Setup Suite
Zack Williamsec53a1b2019-09-16 15:50:52 -0700126 [Documentation] Setup the whole test suite
Andy Bavierba9866b2019-10-11 07:11:53 -0700127 # BBSim sanity test doesn't need these imports from other repositories
Gilles Depatie675a2062019-10-22 12:44:42 -0400128 Run Keyword If ${external_libs} Import Library
129 ... ${CURDIR}/../../../voltha/tests/atests/common/testCaseUtils.py
130 Run Keyword If ${external_libs} Import Resource
131 ... ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/Subscriber.robot
132 Run Keyword If ${external_libs} Import Resource
133 ... ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/OLT.robot
134 Run Keyword If ${external_libs} Import Resource
135 ... ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/DHCP.robot
136 Run Keyword If ${external_libs} Import Resource
137 ... ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/Kubernetes.robot
Suchitra Vemuri2adc07e2019-09-05 17:25:31 -0700138 Set Global Variable ${KUBECTL_CONFIG} export KUBECONFIG=%{KUBECONFIG}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700139 Set Global Variable ${export_kubeconfig} export KUBECONFIG=${KUBERNETES_CONF}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700140 Set Global Variable ${VOLTCTL_CONFIG} export VOLTCONFIG=%{VOLTCONFIG}
141 ${k8s_node_ip}= Evaluate ${nodes}[0].get("ip")
142 ${k8s_node_user}= Evaluate ${nodes}[0].get("user")
143 ${k8s_node_pass}= Evaluate ${nodes}[0].get("pass")
144 Check CLI Tools Configured
145 ${onos_auth}= Create List karaf karaf
146 ${HEADERS} Create Dictionary Content-Type=application/json
Suchitra Vemuri9c24d2b2019-09-30 10:28:25 -0700147 Create Session ONOS http://${k8s_node_ip}:${ONOS_REST_PORT} auth=${ONOS_AUTH}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700148 ${olt_ip}= Evaluate ${olts}[0].get("ip")
149 ${olt_user}= Evaluate ${olts}[0].get("user")
150 ${olt_pass}= Evaluate ${olts}[0].get("pass")
151 ${olt_serial_number}= Evaluate ${olts}[0].get("serial")
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -0700152 ${num_onus}= Get Length ${hosts.src}
153 ${num_onus}= Convert to String ${num_onus}
154 Set Suite Variable ${num_onus}
Suchitra Vemuri2adc07e2019-09-05 17:25:31 -0700155 Set Suite Variable ${olt_serial_number}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700156 Set Suite Variable ${olt_ip}
157 Set Suite Variable ${olt_user}
158 Set Suite Variable ${olt_pass}
159 Set Suite Variable ${k8s_node_ip}
160 Set Suite Variable ${k8s_node_user}
161 Set Suite Variable ${k8s_node_pass}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -0700162 @{container_list}= Create List adapter-open-olt adapter-open-onu voltha-api-server
163 ... voltha-ro-core voltha-rw-core-11 voltha-rw-core-12 voltha-ofagent
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700164 Set Suite Variable ${container_list}
Andy Bavierba9866b2019-10-11 07:11:53 -0700165 ${datetime}= Get Current Date
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700166 Set Suite Variable ${datetime}
167
168Setup
Zack Williamsec53a1b2019-09-16 15:50:52 -0700169 [Documentation] Pre-test Setup
Gilles Depatieb5682f82019-10-31 10:39:45 -0400170 #test for empty device list
171 ${length}= Test Empty Device List
172 Should Be Equal As Integers ${length} 0
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700173 #create/preprovision device
Suchitra Vemuric59eb272019-09-18 17:59:33 -0700174 ${olt_device_id}= Create Device ${olt_ip} ${OLT_PORT}
175 Set Suite Variable ${olt_device_id}
Gilles Depatieb5682f82019-10-31 10:39:45 -0400176 #validate olt states
177 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Device PREPROVISIONED UNKNOWN UNKNOWN
178 ... ${EMPTY} ${olt_device_id}
Suchitra Vemuric59eb272019-09-18 17:59:33 -0700179 Enable Device ${olt_device_id}
Gilles Depatieb5682f82019-10-31 10:39:45 -0400180 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Device ENABLED ACTIVE REACHABLE
181 ... ${olt_serial_number}
Suchitra Vemuri00d147d2019-09-13 13:07:32 -0700182 ${logical_id}= Get Logical Device ID From SN ${olt_serial_number}
183 Set Suite Variable ${logical_id}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700184
185Teardown
186 [Documentation] kills processes and cleans up interfaces on src+dst servers
Suchitra Vemuri65e5fbb2019-09-27 15:23:52 -0700187 Get Device Output from Voltha ${olt_device_id}
188 #Get Logical Device Output from Voltha ${logical_id}
Andy Bavierba9866b2019-10-11 07:11:53 -0700189 Run Keyword If ${external_libs} Get ONOS Status ${k8s_node_ip}
190 Run Keyword If ${has_dataplane} Clean Up Linux
191 Run Keyword If ${external_libs} Log Kubernetes Containers Logs Since Time ${datetime} ${container_list}
192
193Teardown Suite
194 [Documentation] Clean up device if desired
195 Run Keyword If ${teardown_device} Delete Device and Verify
Gilles Depatieb5682f82019-10-31 10:39:45 -0400196 ${length}= Run Keyword If ${teardown_device} Run Keyword And Return Test Empty Device List
197 Run Keyword If ${teardown_device} Should Be Equal As Integers ${length} 0
Andy Bavierba9866b2019-10-11 07:11:53 -0700198 Run Keyword If ${teardown_device} Execute ONOS CLI Command ${k8s_node_ip} ${ONOS_SSH_PORT}
199 ... device-remove ${of_id}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700200
Gilles Depatieb5682f82019-10-31 10:39:45 -0400201
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700202Clean Up Linux
203 [Documentation] Kill processes and clean up interfaces on src+dst servers
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -0700204 FOR ${I} IN RANGE 0 ${num_onus}
205 ${src}= Set Variable ${hosts.src[${I}]}
206 ${dst}= Set Variable ${hosts.dst[${I}]}
207 Run Keyword And Ignore Error Kill Linux Process [w]pa_supplicant ${src['ip']}
208 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
209 Run Keyword And Ignore Error Kill Linux Process [d]hclient ${src['ip']}
210 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
211 Run Keyword If '${dst['ip']}' != '${None}' Run Keyword And Ignore Error
212 ... Kill Linux Process [d]hcpd ${dst['ip']} ${dst['user']}
213 ... ${dst['pass']} ${dst['container_type']} ${dst['container_name']}
214 Delete IP Addresses from Interface on Remote Host ${src['dp_iface_name']} ${src['ip']}
215 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
216 Run Keyword If '${dst['ip']}' != '${None}' Delete Interface on Remote Host
217 ... ${dst['dp_iface_name']}.${src['s_tag']} ${dst['ip']} ${dst['user']} ${dst['pass']}
218 ... ${dst['container_type']} ${dst['container_name']}
219 END
Andy Bavierba9866b2019-10-11 07:11:53 -0700220
221Delete Device and Verify
222 [Documentation] Disable -> Delete devices via voltctl and verify its removed
Andy Bavierba9866b2019-10-11 07:11:53 -0700223 ${rc} ${output}= Run and Return Rc and Output ${VOLTCTL_CONFIG}; voltctl device disable ${olt_device_id}
224 Should Be Equal As Integers ${rc} 0
Gilles Depatieb5682f82019-10-31 10:39:45 -0400225 Wait Until Keyword Succeeds ${timeout} 5s Validate OLT Device DISABLED UNKNOWN REACHABLE
226 ... ${olt_serial_number}
Andy Bavierba9866b2019-10-11 07:11:53 -0700227 ${rc} ${output}= Run and Return Rc and Output ${VOLTCTL_CONFIG}; voltctl device delete ${olt_device_id}
228 Should Be Equal As Integers ${rc} 0
229 Wait Until Keyword Succeeds ${timeout} 5s Validate Device Removed ${olt_device_id}