blob: e347a713529136893e2aec40155d8a395fb0c2c1 [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
Andy Bavierba9866b2019-10-11 07:11:53 -070043${timeout} 60s
Zack Williamsec53a1b2019-09-16 15:50:52 -070044${of_id} 0
45${logical_id} 0
Andy Bavierba9866b2019-10-11 07:11:53 -070046${has_dataplane} True
47${external_libs} True
48${teardown_device} False
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070049
50*** Test Cases ***
51Sanity E2E Test for OLT/ONU on POD
52 [Documentation] Validates E2E Ping Connectivity and object states for the given scenario:
53 ... Validate successful authentication/DHCP/E2E ping for the tech profile that is used
Andy Bavierba9866b2019-10-11 07:11:53 -070054 [Tags] sanity test1
Zack Williamsec53a1b2019-09-16 15:50:52 -070055 #[Setup] Clean Up Linux
Andy Bavierba9866b2019-10-11 07:11:53 -070056 ${of_id}= Wait Until Keyword Succeeds ${timeout} 15s Validate OLT Device in ONOS ${olt_serial_number}
57 Set Global Variable ${of_id}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -070058
59 FOR ${I} IN RANGE 0 ${num_onus}
60 ${src}= Set Variable ${hosts.src[${I}]}
61 ${dst}= Set Variable ${hosts.dst[${I}]}
62
63 ${onu_reasons}= Create List tech-profile-config-download-success omci-flows-pushed
64 Wait Until Keyword Succeeds ${timeout} 5s Validate Device ${src['onu']} ENABLED ACTIVE
65 ... REACHABLE onu=True onu_reasons=${onu_reasons}
66
67 ${onu_device_id}= Get Device ID From SN ${src['onu']}
68 ${onu_port}= Wait Until Keyword Succeeds ${timeout} 2s Get ONU Port in ONOS ${src['onu']} ${of_id}
69 Wait Until Keyword Succeeds ${timeout} 2s Verify Eapol Flows Added For ONU ${k8s_node_ip} ${ONOS_SSH_PORT} ${onu_port}
70
71 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure Validate Authentication True ${src['dp_iface_name']}
72 ... wpa_supplicant.conf ${src['ip']} ${src['user']} ${src['pass']}
73 ... ${src['container_type']} ${src['container_name']}
74
75 Wait Until Keyword Succeeds ${timeout} 2s Verify ONU in AAA-Users ${k8s_node_ip} ${ONOS_SSH_PORT}
76 ... ${onu_port}
77
78 Wait Until Keyword Succeeds ${timeout} 2s Execute ONOS CLI Command ${k8s_node_ip} ${ONOS_SSH_PORT}
79 ... volt-add-subscriber-access ${of_id} ${onu_port}
80
81 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure Validate DHCP and Ping True True ${src['dp_iface_name']}
82 ... ${src['s_tag']} ${src['c_tag']} ${dst['dp_iface_ip_qinq']} ${src['ip']} ${src['user']}
83 ... ${src['pass']} ${src['container_type']} ${src['container_name']} ${dst['dp_iface_name']}
84 ... ${dst['ip']} ${dst['user']} ${dst['pass']} ${dst['container_type']} ${dst['container_name']}
85
Suchitra Vemuri60d5f462019-10-25 16:13:15 -070086 Wait Until Keyword Succeeds ${timeout} 2s Run Keyword And Continue On Failure Validate Subscriber DHCP Allocation ${k8s_node_ip} ${ONOS_SSH_PORT} ${onu_port}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -070087 END
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070088
89*** Keywords ***
90Setup Suite
Zack Williamsec53a1b2019-09-16 15:50:52 -070091 [Documentation] Setup the whole test suite
Andy Bavierba9866b2019-10-11 07:11:53 -070092 # BBSim sanity test doesn't need these imports from other repositories
93 Run Keyword If ${external_libs} Import Library ${CURDIR}/../../../voltha/tests/atests/common/testCaseUtils.py
94 Run Keyword If ${external_libs} Import Resource ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/Subscriber.robot
95 Run Keyword If ${external_libs} Import Resource ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/OLT.robot
96 Run Keyword If ${external_libs} Import Resource ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/DHCP.robot
97 Run Keyword If ${external_libs} Import Resource ${CURDIR}/../../../cord-tester/src/test/cord-api/Framework/Kubernetes.robot
Suchitra Vemuri2adc07e2019-09-05 17:25:31 -070098 Set Global Variable ${KUBECTL_CONFIG} export KUBECONFIG=%{KUBECONFIG}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -070099 Set Global Variable ${export_kubeconfig} export KUBECONFIG=${KUBERNETES_CONF}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700100 Set Global Variable ${VOLTCTL_CONFIG} export VOLTCONFIG=%{VOLTCONFIG}
101 ${k8s_node_ip}= Evaluate ${nodes}[0].get("ip")
102 ${k8s_node_user}= Evaluate ${nodes}[0].get("user")
103 ${k8s_node_pass}= Evaluate ${nodes}[0].get("pass")
104 Check CLI Tools Configured
105 ${onos_auth}= Create List karaf karaf
106 ${HEADERS} Create Dictionary Content-Type=application/json
Suchitra Vemuri9c24d2b2019-09-30 10:28:25 -0700107 Create Session ONOS http://${k8s_node_ip}:${ONOS_REST_PORT} auth=${ONOS_AUTH}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700108 Set Global Variable ${export_kubeconfig} export KUBECONFIG=${KUBERNETES_CONF}
109 ${olt_ip}= Evaluate ${olts}[0].get("ip")
110 ${olt_user}= Evaluate ${olts}[0].get("user")
111 ${olt_pass}= Evaluate ${olts}[0].get("pass")
112 ${olt_serial_number}= Evaluate ${olts}[0].get("serial")
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -0700113 ${num_onus}= Get Length ${hosts.src}
114 ${num_onus}= Convert to String ${num_onus}
115 Set Suite Variable ${num_onus}
Suchitra Vemuri2adc07e2019-09-05 17:25:31 -0700116 Set Suite Variable ${olt_serial_number}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700117 Set Suite Variable ${olt_ip}
118 Set Suite Variable ${olt_user}
119 Set Suite Variable ${olt_pass}
120 Set Suite Variable ${k8s_node_ip}
121 Set Suite Variable ${k8s_node_user}
122 Set Suite Variable ${k8s_node_pass}
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -0700123 @{container_list}= Create List adapter-open-olt adapter-open-onu voltha-api-server
124 ... voltha-ro-core voltha-rw-core-11 voltha-rw-core-12 voltha-ofagent
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700125 Set Suite Variable ${container_list}
Andy Bavierba9866b2019-10-11 07:11:53 -0700126 ${datetime}= Get Current Date
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700127 Set Suite Variable ${datetime}
128
Andy Bavierba9866b2019-10-11 07:11:53 -0700129
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700130Setup
Zack Williamsec53a1b2019-09-16 15:50:52 -0700131 [Documentation] Pre-test Setup
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700132 #create/preprovision device
Suchitra Vemuric59eb272019-09-18 17:59:33 -0700133 ${olt_device_id}= Create Device ${olt_ip} ${OLT_PORT}
134 Set Suite Variable ${olt_device_id}
Suchitra Vemuric59eb272019-09-18 17:59:33 -0700135 Enable Device ${olt_device_id}
Andy Bavierba9866b2019-10-11 07:11:53 -0700136 Wait Until Keyword Succeeds ${timeout} 5s Validate Device ${olt_serial_number} ENABLED ACTIVE
Zack Williamsec53a1b2019-09-16 15:50:52 -0700137 ... REACHABLE
Suchitra Vemuri00d147d2019-09-13 13:07:32 -0700138 ${logical_id}= Get Logical Device ID From SN ${olt_serial_number}
139 Set Suite Variable ${logical_id}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700140
141Teardown
142 [Documentation] kills processes and cleans up interfaces on src+dst servers
Suchitra Vemuri65e5fbb2019-09-27 15:23:52 -0700143 Get Device Output from Voltha ${olt_device_id}
144 #Get Logical Device Output from Voltha ${logical_id}
Andy Bavierba9866b2019-10-11 07:11:53 -0700145 Run Keyword If ${external_libs} Get ONOS Status ${k8s_node_ip}
146 Run Keyword If ${has_dataplane} Clean Up Linux
147 Run Keyword If ${external_libs} Log Kubernetes Containers Logs Since Time ${datetime} ${container_list}
148
149Teardown Suite
150 [Documentation] Clean up device if desired
151 Run Keyword If ${teardown_device} Delete Device and Verify
152 Run Keyword If ${teardown_device} Execute ONOS CLI Command ${k8s_node_ip} ${ONOS_SSH_PORT}
153 ... device-remove ${of_id}
Suchitra Vemuri65cd65f2019-08-30 14:39:22 -0700154
155Clean Up Linux
156 [Documentation] Kill processes and clean up interfaces on src+dst servers
Suchitra Vemuri8a9c3782019-10-23 12:43:01 -0700157 FOR ${I} IN RANGE 0 ${num_onus}
158 ${src}= Set Variable ${hosts.src[${I}]}
159 ${dst}= Set Variable ${hosts.dst[${I}]}
160 Run Keyword And Ignore Error Kill Linux Process [w]pa_supplicant ${src['ip']}
161 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
162 Run Keyword And Ignore Error Kill Linux Process [d]hclient ${src['ip']}
163 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
164 Run Keyword If '${dst['ip']}' != '${None}' Run Keyword And Ignore Error
165 ... Kill Linux Process [d]hcpd ${dst['ip']} ${dst['user']}
166 ... ${dst['pass']} ${dst['container_type']} ${dst['container_name']}
167 Delete IP Addresses from Interface on Remote Host ${src['dp_iface_name']} ${src['ip']}
168 ... ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
169 Run Keyword If '${dst['ip']}' != '${None}' Delete Interface on Remote Host
170 ... ${dst['dp_iface_name']}.${src['s_tag']} ${dst['ip']} ${dst['user']} ${dst['pass']}
171 ... ${dst['container_type']} ${dst['container_name']}
172 END
Andy Bavierba9866b2019-10-11 07:11:53 -0700173
174Delete Device and Verify
175 [Documentation] Disable -> Delete devices via voltctl and verify its removed
Andy Bavierba9866b2019-10-11 07:11:53 -0700176 ${rc} ${output}= Run and Return Rc and Output ${VOLTCTL_CONFIG}; voltctl device disable ${olt_device_id}
177 Should Be Equal As Integers ${rc} 0
178 Wait Until Keyword Succeeds ${timeout} 5s Validate Device ${olt_serial_number} DISABLED UNKNOWN
179 ... REACHABLE
180 ${rc} ${output}= Run and Return Rc and Output ${VOLTCTL_CONFIG}; voltctl device delete ${olt_device_id}
181 Should Be Equal As Integers ${rc} 0
182 Wait Until Keyword Succeeds ${timeout} 5s Validate Device Removed ${olt_device_id}