blob: f326bea9aaef2ed745b89f77579ea6f327df095c [file] [log] [blame]
Gayathri.Selvan283a63c2020-01-23 04:09:18 +00001# 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# FIXME Can we use the same test against BBSim and Hardware?
15
16*** Settings ***
HungWei Chiu87edb1f2020-01-28 00:10:58 +000017Documentation Test various failure scenarios
Gayathri.Selvan283a63c2020-01-23 04:09:18 +000018Suite Setup Common Test Suite Setup
19Test Setup Setup
20Test Teardown Teardown
21#Suite Teardown Teardown Suite
22Library Collections
23Library String
24Library OperatingSystem
25Library XML
26Library RequestsLibrary
27Library ../../libraries/DependencyLibrary.py
28Resource ../../libraries/onos.robot
29Resource ../../libraries/voltctl.robot
30Resource ../../libraries/voltha.robot
31Resource ../../libraries/utils.robot
32Resource ../../libraries/k8s.robot
33Resource ../../variables/variables.robot
HungWei Chiu87edb1f2020-01-28 00:10:58 +000034Resource ../../libraries/power_switch.robot
Gayathri.Selvan283a63c2020-01-23 04:09:18 +000035
36*** Variables ***
37${POD_NAME} flex-ocp-cord
38${KUBERNETES_CONF} ${KUBERNETES_CONFIGS_DIR}/${POD_NAME}.conf
39${KUBERNETES_CONFIGS_DIR} ~/pod-configs/kubernetes-configs
40#${KUBERNETES_CONFIGS_DIR} ${KUBERNETES_CONFIGS_DIR}/${POD_NAME}.conf
41${KUBERNETES_YAML} ${KUBERNETES_CONFIGS_DIR}/${POD_NAME}.yml
42${HELM_CHARTS_DIR} ~/helm-charts
43${VOLTHA_POD_NUM} 8
44${NAMESPACE} voltha
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
Suchitra Vemuri109feb12020-01-23 16:25:02 -080051${has_dataplane} True
Gayathri.Selvan283a63c2020-01-23 04:09:18 +000052${external_libs} True
53${teardown_device} False
54${scripts} ../../scripts
55
56*** Test Cases ***
Gayathri.Selvanb6a2b542020-01-24 07:24:23 +000057Verify restart ofagent container after VOLTHA is operational
58 [Documentation] Restart ofagent container after VOLTHA is operational.
59 ... Please note this test case should be run before the restart of other containers.
60 ... Prerequisite : ONUs are authenticated and pingable.
Suchitra Vemuri65649cf2020-01-24 13:16:00 -080061 [Tags] functional VOL-2409 ofagentRestart
Gayathri.Selvanb6a2b542020-01-24 07:24:23 +000062 [Setup] NONE
63 [Teardown] NONE
64 ${waitforRestart} Set Variable 120s
65 ${podStatusOutput}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE}
66 Log ${podStatusOutput}
67 ${countBforRestart}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE} | grep Running | wc -l
68 Restart Pod ${NAMESPACE} ofagent
69 Sleep 60s
70 Wait Until Keyword Succeeds ${waitforRestart} 2s Validate Pod Status ofagent ${NAMESPACE}
71 ... Running
72 Repeat Sanity Test
73 ${podStatusOutput}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE}
74 Log ${podStatusOutput}
75 ${countAfterRestart}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE} | grep Running | wc -l
76 Should Be Equal As Strings ${countAfterRestart} ${countBforRestart}
77 Run Keyword and Ignore Error Collect Logs
78
Gayathri.Selvan283a63c2020-01-23 04:09:18 +000079Verify restart any container after VOLTHA is operational
80 [Documentation] Restart any container after VOLTHA is operational.
81 ... Prerequisite : ONUs are authenticated and pingable.
Suchitra Vemuri109feb12020-01-23 16:25:02 -080082 [Tags] functional VOL-1958 RestartPods
Gayathri.Selvan283a63c2020-01-23 04:09:18 +000083 [Setup] NONE
84 [Teardown] NONE
85 ${waitforRestart} Set Variable 120s
86 ${podStatusOutput}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE}
87 Log ${podStatusOutput}
88 ${countBforRestart}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE} | grep Running | wc -l
89 ${podName} Set Variable adapter-open-olt
90 Restart Pod ${NAMESPACE} ${podName}
91 Wait Until Keyword Succeeds ${waitforRestart} 2s Validate Pod Status ${podName} ${NAMESPACE}
92 ... Running
93 Repeat Sanity Test
94 ${podStatusOutput}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE}
95 Log ${podStatusOutput}
96 ${countAfterRestart}= Run ${KUBECTL_CONFIG};kubectl get pods -n ${NAMESPACE} | grep Running | wc -l
97 Should Be Equal As Strings ${countAfterRestart} ${countBforRestart}
98 Log to console Pod ${podName} restarted and sanity checks passed successfully
Gayathri.Selvanb6a2b542020-01-24 07:24:23 +000099
HungWei Chiu87edb1f2020-01-28 00:10:58 +0000100Verify ONU after rebooting physically
101 [Documentation] Test the ONU funcaionality by physically turning on/off ONU.
102 ... Prerequisite : Subscriber are authenticated/DHCP/pingable state
103 [Tags] functional VOL-2488 PowerSwitch notready
104 [Setup] NONE
105 [Teardown] NONE
106 Power Switch Connection Suite ${web_power_switch.ip} ${web_power_switch.user} ${web_power_switch.password}
107 FOR ${I} IN RANGE 0 ${num_onus}
108 ${src}= Set Variable ${hosts.src[${I}]}
109 ${dst}= Set Variable ${hosts.dst[${I}]}
110 Disable Switch Outlet ${src['power_switch_port']}
111 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure
112 ... Wait Until Keyword Succeeds 60s 2s
113 ... Check Ping False ${dst['dp_iface_ip_qinq']} ${src['dp_iface_name']}
114 ... ${src['ip']} ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
115
116 Run Keyword And Continue On Failure Wait Until Keyword Succeeds ${timeout} 5s Validate Device
117 ... ENABLED ACTIVE REACHABLE ${src['onu']}
118 Enable Switch Outlet ${src['power_switch_port']}
119 Run Keyword If ${has_dataplane} Run Keyword And Continue On Failure
120 ... Wait Until Keyword Succeeds 60s 2s
121 ... Check Ping True ${dst['dp_iface_ip_qinq']} ${src['dp_iface_name']}
122 ... ${src['ip']} ${src['user']} ${src['pass']} ${src['container_type']} ${src['container_name']}
123 END