blob: 2db750cf04e1b7aabd3ee49b6498a16c59fea10e [file] [log] [blame]
TorstenThiemed4f48962020-12-08 12:17:19 +00001# Copyright 2020 - present Open Networking Foundation
TorstenThiemefd7e7ba2020-11-06 13:57:57 +00002#
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.
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000014
15*** Settings ***
16Documentation Library for various openonu-go-adpter utilities
17
TorstenThiemed4f48962020-12-08 12:17:19 +000018
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000019*** Keywords ***
TorstenThieme440b7c02020-12-18 15:42:57 +000020Calculate Timeout
21 [Documentation] Calculates the timeout regarding num-onus in case of more than 4 onus
22 [Arguments] ${basetimeout}=60s
23 ${new_timeout} Fetch From Left ${basetimeout} s
24 ${new_timeout}= evaluate ${new_timeout}+((${num_all_onus}-4)*10)
25 ${new_timeout}= Set Variable If (not ${debugmode}) and (${new_timeout}>300)
26 ... 300 ${new_timeout}
27 ${new_timeout}= Catenate SEPARATOR= ${new_timeout} s
28 [Return] ${new_timeout}
29
30Power On ONU Device
31 [Documentation] This keyword turns on the power for all onus.
32 [Arguments] ${namespace}
TorstenThiemefe7099e2021-01-29 08:41:04 +000033 FOR ${J} IN RANGE 0 ${num_olts}
34 ${olt_serial_number}= Set Variable ${list_olts}[${J}][sn]
35 ${bbsim}= Catenate SEPARATOR= bbsim ${J}
36 ${bbsim_pod}= Get Pod Name By Label ${namespace} release ${bbsim}
37 Power On ONU Device per OLT ${namespace} ${olt_serial_number} ${bbsim_pod}
38 END
39
40Power On ONU Device per OLT
41 [Documentation] This keyword turns on the power for all onus.
42 [Arguments] ${namespace} ${olt_serial_number} ${bbsim_pod}
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000043 FOR ${I} IN RANGE 0 ${num_all_onus}
44 ${src}= Set Variable ${hosts.src[${I}]}
TorstenThiemefe7099e2021-01-29 08:41:04 +000045 Continue For Loop If "${olt_serial_number}"!="${src['olt']}"
46 Power On ONU ${namespace} ${bbsim_pod} ${src['onu']}
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000047 END
48
TorstenThieme440b7c02020-12-18 15:42:57 +000049Power Off ONU Device
TorstenThiemefe7099e2021-01-29 08:41:04 +000050 [Documentation] This keyword turns off the power for all onus per olt.
TorstenThieme440b7c02020-12-18 15:42:57 +000051 [Arguments] ${namespace}
TorstenThiemefe7099e2021-01-29 08:41:04 +000052 FOR ${J} IN RANGE 0 ${num_olts}
53 ${olt_serial_number}= Set Variable ${list_olts}[${J}][sn]
54 ${bbsim}= Catenate SEPARATOR= bbsim ${J}
55 ${bbsim_pod}= Get Pod Name By Label ${namespace} release ${bbsim}
56 Power Off ONU Device per OLT ${namespace} ${olt_serial_number} ${bbsim_pod}
57 END
58
59Power Off ONU Device per OLT
60 [Documentation] This keyword turns off the power for all onus per olt.
61 [Arguments] ${namespace} ${olt_serial_number} ${bbsim_pod}
TorstenThieme440b7c02020-12-18 15:42:57 +000062 FOR ${I} IN RANGE 0 ${num_all_onus}
63 ${src}= Set Variable ${hosts.src[${I}]}
TorstenThiemefe7099e2021-01-29 08:41:04 +000064 Continue For Loop If "${olt_serial_number}"!="${src['olt']}"
65 Power Off ONU ${namespace} ${bbsim_pod} ${src['onu']}
TorstenThieme440b7c02020-12-18 15:42:57 +000066 END
67
68Current State Test
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000069 [Documentation] This keyword checks the passed state of the given onu.
70 [Arguments] ${state} ${onu} ${reqadminstate}=${EMPTY} ${reqoperstatus}=${EMPTY}
71 ... ${reqconnectstatus}=${EMPTY}
72 ${admin_state} ${oper_status} ${connect_status} ${onu_state_nb} ${onu_state}= Map State ${state}
73 ${admin_state}= Set Variable If '${reqadminstate}'!='${EMPTY}' ${reqadminstate} ${admin_state}
74 ${oper_status}= Set Variable If '${reqoperstatus}'!='${EMPTY}' ${reqoperstatus} ${oper_status}
75 ${connect_status}= Set Variable If '${reqconnectstatus}'!='${EMPTY}' ${reqconnectstatus}
76 ... ${connect_status}
77 Run Keyword And Continue On Failure Wait Until Keyword Succeeds ${timeout} 50ms
78 ... Validate Device ${admin_state} ${oper_status} ${connect_status}
79 ... ${onu} onu=True onu_reason=${onu_state}
80
TorstenThieme440b7c02020-12-18 15:42:57 +000081Current State Test All Onus
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000082 [Documentation] This keyword checks the passed state of all onus.
83 ... Hint: ${timeStart} will be not evaluated here!
84 [Arguments] ${state} ${reqadminstate}=${EMPTY} ${reqoperstatus}=${EMPTY} ${reqconnectstatus}=${EMPTY}
85 ... ${alternativeonustate}=${EMPTY}
TorstenThieme440b7c02020-12-18 15:42:57 +000086 ${timeStart}= Get Current Date
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000087 ${list_onus} Create List
88 Build ONU SN List ${list_onus}
89 ${admin_state} ${oper_status} ${connect_status} ${onu_state_nb} ${onu_state}= Map State ${state}
90 ${admin_state}= Set Variable If '${reqadminstate}'!='${EMPTY}' ${reqadminstate} ${admin_state}
91 ${oper_status}= Set Variable If '${reqoperstatus}'!='${EMPTY}' ${reqoperstatus} ${oper_status}
92 ${connect_status}= Set Variable If '${reqconnectstatus}'!='${EMPTY}' ${reqconnectstatus}
93 ... ${connect_status}
94 Run Keyword And Continue On Failure Wait Until Keyword Succeeds ${timeout} 50ms
95 ... Validate ONU Devices With Duration
96 ... ${admin_state} ${oper_status} ${connect_status}
TorstenThieme52ef8392020-11-10 13:42:26 +000097 ... ${onu_state} ${list_onus} ${timeStart} alternate_reason=${alternativeonustate}
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000098
TorstenThiemefd7e7ba2020-11-06 13:57:57 +000099Log Ports
100 [Documentation] This keyword logs all port data available in ONOS of first port per ONU
101 [Arguments] ${onlyenabled}=False
102 ${cmd} Set Variable If ${onlyenabled} ports -e ports
103 ${onu_ports}= Execute ONOS CLI Command on open connection ${onos_ssh_connection} ${cmd}
104 ${lines} = Get Lines Matching Regexp ${onu_ports} .*portName=BBSM[0-9]{8}-1
105 Log ${lines}
106
107Kill Adaptor
108 [Documentation] This keyword kills the passed adaptor.
109 [Arguments] ${namespace} ${name}
110 ${cmd} Catenate
111 ... kubectl exec -it -n voltha $(kubectl get pods -n ${namespace} | grep ${name} | awk 'NR==1{print $1}')
112 ... -- /bin/sh -c "kill 1"
113 ${rc} ${output}= Run and Return Rc and Output ${cmd}
114 Log ${output}
115
TorstenThieme440b7c02020-12-18 15:42:57 +0000116Kill And Check Onu Adaptor
117 [Documentation] This keyword kills ONU Adaptor and waits for it to come up again
118 ... Following steps will be executed:
119 ... - kill openonu adaptor
120 ... - check openonu adaptor is ready again
121 [Arguments] ${namespace}
122 ${list_openonu_apps} Create List adapter-open-onu
123 ${adaptorname}= Set Variable open-onu
124 Kill Adaptor ${namespace} ${adaptorname}
125 Sleep 5s
126 Wait For Pods Ready ${namespace} ${list_openonu_apps}
127
128Restart And Check Onu Adaptor
129 [Documentation] This keyword restarts ONU Adaptor and waits for it to come up again
130 ... Following steps will be executed:
131 ... - restart openonu adaptor
132 ... - check openonu adaptor is ready again
133 [Arguments] ${namespace}
134 ${list_openonu_apps} Create List adapter-open-onu
135 ${adaptorname}= Set Variable open-onu
136 Restart Pod ${namespace} ${adaptorname}
137 Sleep 5s
138 Wait For Pods Ready ${namespace} ${list_openonu_apps}
139
140Disable Onu Device
141 [Documentation] This keyword disables all onus.
TorstenThieme70bc5262021-01-19 12:12:55 +0000142 ${onu_list} Create List
TorstenThieme440b7c02020-12-18 15:42:57 +0000143 FOR ${I} IN RANGE 0 ${num_all_onus}
144 ${src}= Set Variable ${hosts.src[${I}]}
145 ${onu_device_id}= Get Device ID From SN ${src['onu']}
TorstenThieme70bc5262021-01-19 12:12:55 +0000146 ${onu_id}= Get Index From List ${onu_list} ${onu_device_id}
147 Continue For Loop If -1 != ${onu_id}
148 Append To List ${onu_list} ${onu_device_id}
TorstenThieme440b7c02020-12-18 15:42:57 +0000149 Disable Device ${onu_device_id}
150 Wait Until Keyword Succeeds 20s 2s Test Devices Disabled in VOLTHA Id=${onu_device_id}
151 END
152
153Enable Onu Device
154 [Documentation] This keyword enables all onus.
TorstenThieme70bc5262021-01-19 12:12:55 +0000155 ${onu_list} Create List
TorstenThieme440b7c02020-12-18 15:42:57 +0000156 FOR ${I} IN RANGE 0 ${num_all_onus}
157 ${src}= Set Variable ${hosts.src[${I}]}
158 ${onu_device_id}= Get Device ID From SN ${src['onu']}
TorstenThieme70bc5262021-01-19 12:12:55 +0000159 ${onu_id}= Get Index From List ${onu_list} ${onu_device_id}
160 Continue For Loop If -1 != ${onu_id}
161 Append To List ${onu_list} ${onu_device_id}
TorstenThieme440b7c02020-12-18 15:42:57 +0000162 Enable Device ${onu_device_id}
163 END
164
TorstenThiemefd7e7ba2020-11-06 13:57:57 +0000165Verify MIB Template Data Available
166 [Documentation] This keyword verifies MIB Template Data stored in etcd
167 ${namespace}= Set Variable default
TorstenThiemed4f48962020-12-08 12:17:19 +0000168 ${podname}= Set Variable etcd
TorstenThiemefd7e7ba2020-11-06 13:57:57 +0000169 ${commandget} Catenate
Matteo Scandolo341b9372020-12-09 14:15:06 -0800170 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl get --prefix service/voltha/omci_mibs/go_templates/'
Holger Hildebrandt23147742020-11-16 10:13:21 +0000171 ${result}= Exec Pod In Kube ${namespace} ${podname} ${commandget}
TorstenThiemefd7e7ba2020-11-06 13:57:57 +0000172 Should Not Be Empty ${result} No MIB Template Data stored in etcd!
173
174Delete MIB Template Data
175 [Documentation] This keyword deletes MIB Template Data stored in etcd
176 ${namespace}= Set Variable default
177 ${podname}= Set Variable etcd
178 ${commanddel} Catenate
Matteo Scandolo341b9372020-12-09 14:15:06 -0800179 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl del --prefix service/voltha/omci_mibs/go_templates/'
Holger Hildebrandt23147742020-11-16 10:13:21 +0000180 ${result}= Exec Pod In Kube ${namespace} ${podname} ${commanddel}
TorstenThiemefd7e7ba2020-11-06 13:57:57 +0000181 Sleep 3s
182 ${commandget} Catenate
Matteo Scandolo341b9372020-12-09 14:15:06 -0800183 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl get --prefix service/voltha/omci_mibs/go_templates/'
Holger Hildebrandt23147742020-11-16 10:13:21 +0000184 ${result}= Exec Pod In Kube ${namespace} ${podname} ${commandget}
TorstenThiemefd7e7ba2020-11-06 13:57:57 +0000185 Should Be Empty ${result} Could not delete MIB Template Data stored in etcd!
186
TorstenThieme440b7c02020-12-18 15:42:57 +0000187Set Tech Profile
188 [Documentation] This keyword sets the passed TechProfile for the test
189 [Arguments] ${TechProfile}
190 Log To Console \nTechProfile:${TechProfile}
191 ${namespace}= Set Variable default
192 ${podname}= Set Variable etcd
193 ${src}= Set Variable ${data_dir}/TechProfile-${TechProfile}.json
194 ${dest}= Set Variable /tmp/flexpod.json
195 ${command} Catenate
196 ... /bin/sh -c 'cat ${dest} | ETCDCTL_API=3 etcdctl put service/voltha/technology_profiles/XGS-PON/64'
197 Copy File To Pod ${namespace} ${podname} ${src} ${dest}
198 Exec Pod In Kube ${namespace} ${podname} ${command}
199 ${commandget} Catenate
200 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl get --prefix service/voltha/technology_profiles/XGS-PON/64'
201 Exec Pod In Kube ${namespace} ${podname} ${commandget}
202
203Remove Tech Profile
204 [Documentation] This keyword removes TechProfile
205 Log To Console \nTechProfile:${TechProfile}
206 ${namespace}= Set Variable default
207 ${podname}= Set Variable etcd
208 ${command} Catenate
209 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl del --prefix service/voltha/technology_profiles/XGS-PON/64'
210 Exec Pod In Kube ${namespace} ${podname} ${command}
211 ${commandget} Catenate
212 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl get --prefix service/voltha/technology_profiles/XGS-PON/64'
213 Exec Pod In Kube ${namespace} ${podname} ${commandget}
214
TorstenThieme17756ea2020-11-11 14:09:47 +0000215Validate Onu Data In Etcd
216 [Documentation] This keyword validates openonu-go-adapter Data stored in etcd.
217 ... It checks unique of serial_number and combination of pon, onu and uni in tp_path.
218 ... Furthermore it evaluates the values of onu_id and uni_id with values read from tp_path.
219 ... Number of etcd entries has to match with the passed number.
TorstenThieme3385cdc2021-02-04 13:50:50 +0000220 [Arguments] ${nbofetcddata}=${num_all_onus} ${defaultkvstoreprefix}=voltha_voltha
TorstenThiemefa29a892021-03-11 14:11:29 +0000221 ... ${without_prefix}=True ${without_pm_data}=True
TorstenThieme3385cdc2021-02-04 13:50:50 +0000222 ${kvstoreprefix}= Get Kv Store Prefix ${defaultkvstoreprefix}
TorstenThiemefa29a892021-03-11 14:11:29 +0000223 ${etcddata}= Get ONU Go Adapter ETCD Data ${kvstoreprefix} ${without_prefix} ${without_pm_data}
TorstenThieme17756ea2020-11-11 14:09:47 +0000224 #prepare result for json convert
225 ${result}= Prepare ONU Go Adapter ETCD Data For Json ${etcddata}
226 ${jsondata}= To Json ${result}
227 ${length}= Get Length ${jsondata}
228 log ${jsondata}
229 Run Keyword And Continue On Failure Should Be Equal As Integers ${length} ${nbofetcddata}
230 ... msg=Number etcd data (${length}) does not match required (${nbofetcddata})!
TorstenThiemefe7099e2021-01-29 08:41:04 +0000231 ${oltpononuuniidlist}= Create List
TorstenThieme17756ea2020-11-11 14:09:47 +0000232 ${serialnumberlist}= Create List
233 FOR ${INDEX} IN RANGE 0 ${length}
234 ${value}= Get From List ${jsondata} ${INDEX}
Girish Gowdra97f8d062020-11-17 15:48:23 -0800235 # TODO: The TP ID is hardcoded to 64 below. It is fine when testing single-tcont workflow.
236 # When testing multi-tcont this may need some adjustment.
237 ${tp_path}= Get From Dictionary ${value['uni_config'][0]['PersTpPathMap']} 64
TorstenThiemefe7099e2021-01-29 08:41:04 +0000238 ${oltpononuuniid}= Read Pon Onu Uni String ${tp_path}
239 ${list_id}= Get Index From List ${oltpononuuniidlist} ${oltpononuuniid}
TorstenThieme17756ea2020-11-11 14:09:47 +0000240 Should Be Equal As Integers ${list_id} -1
TorstenThiemefe7099e2021-01-29 08:41:04 +0000241 ... msg=Combination of Pon, Onu and Uni (${oltpononuuniid}) exist multiple in etcd data!
242 Append To List ${oltpononuuniidlist} ${oltpononuuniid}
TorstenThieme17756ea2020-11-11 14:09:47 +0000243 Validate Onu Id ${value}
244 Validate Uni Id ${value}
245 ${serial_number}= Get From Dictionary ${value} serial_number
246 ${list_id}= Get Index From List ${serialnumberlist} ${serial_number}
247 Should Be Equal As Integers ${list_id} -1
248 ... msg=Serial number (${serial_number}) exists multiple in etcd data!
249 Append To List ${serialnumberlist} ${serial_number}
250 END
251
TorstenThieme52ef8392020-11-10 13:42:26 +0000252Validate Vlan Rules In Etcd
253 [Documentation] This keyword validates Vlan rules of openonu-go-adapter Data stored in etcd.
254 ... It checks the given number of cookie_slice, match_vid (=4096) and set_vid.
255 ... Furthermore it returns a list of all set_vid.
256 ... In case of a passed dictionary containing set_vids these will be checked for to
257 ... current set-vid depending on setvidequal (True=equal, False=not equal).
258 [Arguments] ${nbofcookieslice}=1 ${reqmatchvid}=4096 ${prevvlanrules}=${NONE} ${setvidequal}=False
TorstenThiemefa29a892021-03-11 14:11:29 +0000259 ... ${defaultkvstoreprefix}=voltha_voltha ${without_prefix}=True ${without_pm_data}=True
TorstenThieme3385cdc2021-02-04 13:50:50 +0000260 ${kvstoreprefix}= Get Kv Store Prefix ${defaultkvstoreprefix}
TorstenThiemefa29a892021-03-11 14:11:29 +0000261 ${etcddata}= Get ONU Go Adapter ETCD Data ${kvstoreprefix} ${without_prefix} ${without_pm_data}
TorstenThieme52ef8392020-11-10 13:42:26 +0000262 #prepare result for json convert
263 ${result}= Prepare ONU Go Adapter ETCD Data For Json ${etcddata}
264 ${jsondata}= To Json ${result}
265 ${length}= Get Length ${jsondata}
266 log ${jsondata}
267 ${vlan_rules}= Create Dictionary
268 FOR ${INDEX} IN RANGE 0 ${length}
269 ${value}= Get From List ${jsondata} ${INDEX}
Girish Gowdra295c1692020-11-19 10:51:53 -0800270 # TODO: The TP ID is hardcoded to 64 below. It is fine when testing single-tcont workflow.
271 # When testing multi-tcont this may need some adjustment.
272 ${tp_path}= Get From Dictionary ${value['uni_config'][0]['PersTpPathMap']} 64
TorstenThiemefe7099e2021-01-29 08:41:04 +0000273 ${oltpononuuniid}= Read Pon Onu Uni String ${tp_path}
TorstenThieme52ef8392020-11-10 13:42:26 +0000274 ${cookieslice}= Get From Dictionary ${value['uni_config'][0]['flow_params'][0]} cookie_slice
275 #@{cookieslicelist}= Split String ${cookieslice} ,
276 ${foundcookieslices}= Get Length ${cookieslice}
277 Should Be Equal As Integers ${foundcookieslices} ${nbofcookieslice}
278 ${matchvid}= Get From Dictionary ${value['uni_config'][0]['flow_params'][0]['vlan_rule_params']}
279 ... match_vid
280 Should Be Equal As Integers ${matchvid} ${reqmatchvid}
281 ${setvid}= Get From Dictionary ${value['uni_config'][0]['flow_params'][0]['vlan_rule_params']}
282 ... set_vid
283 ${evalresult}= Evaluate 2 <= ${setvid} <= 4095
284 Should Be True ${evalresult} msg=set_vid out of range (${setvid})!
TorstenThiemefe7099e2021-01-29 08:41:04 +0000285 Set To Dictionary ${vlan_rules} ${oltpononuuniid} ${setvid}
TorstenThieme52ef8392020-11-10 13:42:26 +0000286 ${oldsetvidvalid} Set Variable If ${prevvlanrules} is ${NONE} False True
TorstenThiemefe7099e2021-01-29 08:41:04 +0000287 ${prevsetvid}= Set Variable If ${oldsetvidvalid} ${prevvlanrules['${oltpononuuniid}']}
TorstenThieme52ef8392020-11-10 13:42:26 +0000288 Run Keyword If ${oldsetvidvalid} and ${setvidequal}
289 ... Should Be Equal As Integers ${prevsetvid} ${setvid}
290 ... ELSE IF ${oldsetvidvalid} and not ${setvidequal}
291 ... Should Not Be Equal As Integers ${prevsetvid} ${setvid}
292 END
TorstenThieme440b7c02020-12-18 15:42:57 +0000293 log Many ${vlan_rules}
TorstenThieme52ef8392020-11-10 13:42:26 +0000294 [Return] ${vlan_rules}
295
296Get ONU Go Adapter ETCD Data
297 [Documentation] This keyword delivers openonu-go-adapter Data stored in etcd
TorstenThieme3af12312021-03-10 16:15:24 +0000298 [Arguments] ${defaultkvstoreprefix}=voltha_voltha ${without_prefix}=True ${without_pm_data}=True
TorstenThieme52ef8392020-11-10 13:42:26 +0000299 ${namespace}= Set Variable default
300 ${podname}= Set Variable etcd
TorstenThieme3385cdc2021-02-04 13:50:50 +0000301 ${kvstoreprefix}= Get Kv Store Prefix ${defaultkvstoreprefix}
TorstenThieme3af12312021-03-10 16:15:24 +0000302 ${commandget}= Catenate
303 ... /bin/sh -c 'ETCDCTL_API=3 etcdctl get --prefix service/${kvstoreprefix}/openonu'
304 ${commandget}= Run Keyword If ${without_prefix} Catenate ${commandget}
305 ... | grep -v service/${kvstoreprefix}/openonu
TorstenThiemefa29a892021-03-11 14:11:29 +0000306 ... ELSE Set Variable ${commandget}
TorstenThieme3af12312021-03-10 16:15:24 +0000307 ${commandget}= Run Keyword If ${without_pm_data} Catenate ${commandget} | grep -v instances_active
TorstenThiemefa29a892021-03-11 14:11:29 +0000308 ... ELSE Set Variable ${commandget}
Holger Hildebrandt23147742020-11-16 10:13:21 +0000309 ${result}= Exec Pod In Kube ${namespace} ${podname} ${commandget}
TorstenThieme52ef8392020-11-10 13:42:26 +0000310 log ${result}
311 [Return] ${result}
312
313Prepare ONU Go Adapter ETCD Data For Json
314 [Documentation] This keyword prepares openonu-go-adapter Data stored in etcd for converting
315 ... to json
316 [Arguments] ${etcddata}
317 #prepare result for json convert
318 ${prepresult}= Replace String ${etcddata} \n ,
319 ${prepresult}= Strip String ${prepresult} mode=right characters=,
320 ${prepresult}= Set Variable [${prepresult}]
321 log ${prepresult}
322 [Return] ${prepresult}
323
TorstenThieme52ef8392020-11-10 13:42:26 +0000324Read Pon Onu Uni String
TorstenThiemefe7099e2021-01-29 08:41:04 +0000325 [Documentation] This keyword builds a four digit string using Olt, Pon, Onu and Uni value of given tp-path taken
TorstenThieme52ef8392020-11-10 13:42:26 +0000326 ... taken from etcd data of onu go adapter
327 [Arguments] ${tp_path}
TorstenThieme52ef8392020-11-10 13:42:26 +0000328 ${tppathlines}= Replace String ${tp_path} / \n
TorstenThiemefe7099e2021-01-29 08:41:04 +0000329 ${olt}= Get Value Of Tp Path Element ${tppathlines} olt
TorstenThieme52ef8392020-11-10 13:42:26 +0000330 ${pon}= Get Value Of Tp Path Element ${tppathlines} pon
331 ${onu}= Get Value Of Tp Path Element ${tppathlines} onu
332 ${uni}= Get Value Of Tp Path Element ${tppathlines} uni
TorstenThiemefe7099e2021-01-29 08:41:04 +0000333 ${valuesid}= Set Variable ${olt}/${pon}/${onu}/${uni}
TorstenThieme52ef8392020-11-10 13:42:26 +0000334 log ${valuesid}
335 [Return] ${valuesid}
336
337Get Value Of Tp Path Element
TorstenThieme17756ea2020-11-11 14:09:47 +0000338 [Documentation] This keyword delivers numeric value of given tp path element.
TorstenThieme52ef8392020-11-10 13:42:26 +0000339 [Arguments] ${tp_path_lines} ${element}
340 ${value}= Get Lines Containing String ${tp_path_lines} ${element}-\{
341 ${value}= Remove String ${value} ${element}-\{
342 ${value}= Remove String ${value} \}
343 log ${value}
344 [Return] ${value}
345
TorstenThieme17756ea2020-11-11 14:09:47 +0000346Validate Onu Id
347 [Documentation] This keyword validates ONU Id of passed etcd data.
348 [Arguments] ${value}
Girish Gowdra295c1692020-11-19 10:51:53 -0800349 # TODO: The TP ID is hardcoded to 64 below. It is fine when testing single-tcont workflow.
350 # When testing multi-tcont this may need some adjustment.
351 ${tp_path}= Get From Dictionary ${value['uni_config'][0]['PersTpPathMap']} 64
TorstenThieme17756ea2020-11-11 14:09:47 +0000352 ${tppathlines}= Replace String ${tp_path} / \n
353 ${onu}= Get Value Of Tp Path Element ${tppathlines} onu
354 ${onu_id}= Get From Dictionary ${value} onu_id
355 Should Be Equal As Integers ${onu} ${onu_id}
356 ... msg=Onu-Id (${onu_id}) does not match onu (${onu}) from tp_path in etcd data!
357 Should Be True ${onu_id}>=1
358
359Validate Uni Id
360 [Documentation] This keyword validates UNI Id of passed etcd data.
361 [Arguments] ${value}
Girish Gowdra295c1692020-11-19 10:51:53 -0800362 # TODO: The TP ID is hardcoded to 64 below. It is fine when testing single-tcont workflow.
363 # When testing multi-tcont this may need some adjustment.
364 ${tp_path}= Get From Dictionary ${value['uni_config'][0]['PersTpPathMap']} 64
TorstenThieme17756ea2020-11-11 14:09:47 +0000365 ${tppathlines}= Replace String ${tp_path} / \n
366 ${uni}= Get Value Of Tp Path Element ${tppathlines} uni
367 ${uni_id}= Get From Dictionary ${value['uni_config'][0]} uni_id
368 Should Be Equal As Integers ${uni} ${uni_id}
369 ... msg=Uni-Id (${uni_id}) does not match onu (${uni}) from tp_path in etcd data!
TorstenThieme52ef8392020-11-10 13:42:26 +0000370
TorstenThiemed4f48962020-12-08 12:17:19 +0000371Wait for Ports in ONOS for all OLTs
TorstenThieme440b7c02020-12-18 15:42:57 +0000372 [Documentation] Waits untill a certain number of ports are enabled in all OLTs
TorstenThiemed4f48962020-12-08 12:17:19 +0000373 [Arguments] ${onos_ssh_connection} ${count} ${filter} ${max_wait_time}=10m
374 FOR ${J} IN RANGE 0 ${num_olts}
375 ${olt_serial_number}= Set Variable ${list_olts}[${J}][sn]
376 ${onu_count}= Set Variable ${list_olts}[${J}][onucount]
377 ${of_id}= Wait Until Keyword Succeeds ${timeout} 15s Validate OLT Device in ONOS
378 ... ${olt_serial_number}
379 Set Global Variable ${of_id}
TorstenThiemefe7099e2021-01-29 08:41:04 +0000380 ${count2check} Set Variable If ${count}==${num_all_onus} ${onu_count} ${count}
381 Wait for Ports in ONOS ${onos_ssh_connection} ${count2check} ${of_id} BBSM ${max_wait_time}
TorstenThiemed4f48962020-12-08 12:17:19 +0000382 END
383
TorstenThieme440b7c02020-12-18 15:42:57 +0000384Wait for all ONU Ports in ONOS Disabled
385 [Documentation] Waits untill a all ONU ports are disabled in all ONOS
386 [Arguments] ${onos_ssh_connection}
387 FOR ${I} IN RANGE 0 ${num_all_onus}
388 ${src}= Set Variable ${hosts.src[${I}]}
389 ${of_id}= Wait Until Keyword Succeeds ${timeout} 15s Validate OLT Device in ONOS
390 ... ${src['olt']}
391 ${onu_port}= Wait Until Keyword Succeeds ${timeout} 2s Get ONU Port in ONOS ${src['onu']} ${of_id}
392 Wait Until Keyword Succeeds ${timeout} 2s Assert ONU Port Is Disabled ${onos_ssh_connection} ${of_id}
393 ... ${onu_port}
394 END
395
TorstenThiemefd7e7ba2020-11-06 13:57:57 +0000396Map State
397 [Documentation] This keyword converts the passed numeric value or name of a onu state to its state values.
398 [Arguments] ${state}
399 # create state lists with corresponding return values
400 # ADMIN-STATE OPER-STATUS CONNECT-STATUS ONU-STATE (number/name)
401 ${state1} Create List ENABLED ACTIVATING REACHABLE 1 activating-onu
402 ${state2} Create List ENABLED ACTIVATING REACHABLE 2 starting-openomci
403 ${state3} Create List ENABLED ACTIVATING REACHABLE 3 discovery-mibsync-complete
404 ${state4} Create List ENABLED ACTIVE REACHABLE 4 initial-mib-downloaded
405 ${state5} Create List ENABLED ACTIVE REACHABLE 5 tech-profile-config-download-success
406 ${state6} Create List ENABLED ACTIVE REACHABLE 6 omci-flows-pushed
407 ${state7} Create List DISABLED UNKNOWN REACHABLE 7 omci-admin-lock
408 ${state8} Create List ENABLED ACTIVE REACHABLE 8 onu-reenabled
409 ${state9} Create List ENABLED DISCOVERED UNREACHABLE 9 stopping-openomci
410 ${state10} Create List ENABLED DISCOVERED REACHABLE 10 rebooting
411 ${state11} Create List ENABLED DISCOVERED REACHABLE 11 omci-flows-deleted
412 ${state12} Create List DISABLED UNKNOWN REACHABLE 12 tech-profile-config-delete-success
413 ${admin_state} ${oper_status} ${connect_status} ${onu_state_nb} ${onu_state}= Set Variable If
414 ... '${state}'=='1' or '${state}'=='activating-onu' ${state1}
415 ... '${state}'=='2' or '${state}'=='starting-openomci' ${state2}
416 ... '${state}'=='3' or '${state}'=='discovery-mibsync-complete' ${state3}
417 ... '${state}'=='4' or '${state}'=='initial-mib-downloaded' ${state4}
418 ... '${state}'=='5' or '${state}'=='tech-profile-config-download-success' ${state5}
419 ... '${state}'=='6' or '${state}'=='omci-flows-pushed' ${state6}
420 ... '${state}'=='7' or '${state}'=='omci-admin-lock' ${state7}
421 ... '${state}'=='8' or '${state}'=='onu-reenabled' ${state8}
422 ... '${state}'=='9' or '${state}'=='stopping-openomci' ${state9}
423 ... '${state}'=='10' or '${state}'=='rebooting' ${state10}
424 ... '${state}'=='11' or '${state}'=='omci-flows-deleted' ${state11}
425 ... '${state}'=='12' or '${state}'=='tech-profile-config-delete-success' ${state12}
426 [Return] ${admin_state} ${oper_status} ${connect_status} ${onu_state_nb} ${onu_state}