VOL-2642 Add a Makefile, tests, and virtualenv
Convert common python and robot into a CORDRobot python module that can
be installed via standard python tools (pip) and from PyPI
Uses a fork of https://github.com/rasjani/robotframework-importresource,
which has been backported to Python 3.5 (used in Ubuntu 16.04
executors).
Reformatted and moved keywords so resource files are scoped to a
specific topic.
Added tox tests for library consistency
- flake8
- pylint
- robotframework-lint
- Ran robot against installed library to verify it can be loaded and
used
Added basic lint and tests to whole repo
Removed old tests:
- CORD <6.x era: SanityPhyPOD.robot, and onosUtils.py
Change-Id: I61265a9fb04034a086e20be1f7236a8793a218aa
diff --git a/cord-robot/CORDRobot/rf-resources/OLT.resource b/cord-robot/CORDRobot/rf-resources/OLT.resource
new file mode 100644
index 0000000..bdfc1a1
--- /dev/null
+++ b/cord-robot/CORDRobot/rf-resources/OLT.resource
@@ -0,0 +1,87 @@
+# Copyright 2017-present Open Networking Foundation
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+*** Settings ***
+Documentation Library of functions related to OLT
+Library SSHLibrary
+Library Collections
+Library String
+Library OperatingSystem
+Library RequestsLibrary
+Library CORDRobot
+
+*** Keywords ***
+Openolt is Up
+ [Documentation] Verify that openolt process is started and ready to connect to voltha
+ [Arguments] ${ip} ${user} ${pass} ${prompt}=~#
+ Check Remote File Contents True
+ ... /var/log/openolt.log oper_state: up
+ ... ${ip} ${user} ${pass} prompt=${prompt}
+
+OLT Status Check
+ [Documentation] Returns "operational_status" and "admin_status" of a particular
+ ... OLT device from "olt device list"
+ [Arguments] ${olt_device}
+ ${json_result}= CORDRobot.ApiGet VOLT_DEVICE
+ Log ${json_result}
+ ${json_result_list}= Get From dictionary ${json_result} items
+ ${getJsonDict}= CORDRobot.getDictFromListOfDict
+ ... ${json_result_list} host ${olt_device}
+ ${operational_status}= Get From Dictionary ${getJsonDict} oper_status
+ ${admin_status}= Get From Dictionary ${getJsonDict} admin_state
+ [Return] ${operational_status} ${admin_status}
+
+Validate OLT States
+ [Documentation] Check that OLT has the expected 'operational_status' and 'admin_status'
+ [Arguments] ${expected_op_status} ${expected_admin_status} ${olt_device}
+ ${operational_status} ${admin_status} OLT Status Check ${olt_device}
+ Should Be Equal ${operational_status} ${expected_op_status}
+ Should Be Equal ${admin_status} ${expected_admin_status}
+
+Get VOLTHA Status
+ [Documentation] Obtain and log output of VOLTHA diagnostic commands
+ ${resp}= CORD Get ${VOLT_DEVICE}
+ ${jsondata}= To Json ${resp.content}
+ Log ${jsondata}
+ ${length}= Get Length ${jsondata['items']}
+ FOR ${INDEX} IN RANGE 0 ${length}
+ ${value}= Get From List ${jsondata['items']} ${INDEX}
+ ${olt_device_id}= Get From Dictionary ${value} device_id
+ ${logical_device_id}= Get From Dictionary ${value} of_id
+ END
+ Set Suite Variable ${olt_device_id}
+ Set Suite Variable ${logical_device_id}
+ CORDRobot.write_log_of_voltha_cli_comand /tmp
+ ... voltha_devices.log devices
+ ... host=${server_ip}
+ CORDRobot.write_log_of_voltha_cli_comand /tmp
+ ... logical_devices.log logical_device ${logical_device_id}
+ ... voltha_logical_ports.log ports
+ ... voltha_logical_flows.log flow
+ ... host=${server_ip}
+ CORDRobot.write_log_of_voltha_cli_comand /tmp
+ ... devices.log device ${olt_device_id}
+ ... voltha_olt_ports.log ports
+ ... voltha_olt_flows.log flows
+ ... host=${server_ip}
+ ${voltha_devices_log}= Get Binary File /tmp/voltha_devices.log
+ ${devices_flows}= Get Binary File /tmp/voltha_olt_flows.log
+ ${device_ports}= Get Binary File /tmp/voltha_olt_ports.log
+ ${logical_devices}= Get Binary File /tmp/voltha_logical_flows.log
+ ${l_device_ports}= Get Binary File /tmp/voltha_logical_ports.log
+ Log ${voltha_devices_log}
+ Log ${devices_flows}
+ Log ${device_ports}
+ Log ${logical_devices}
+ Log ${l_device_ports}