move the library to ONF
Change-Id: I383437e2934ce04cc1a7dc332134f7308991776f
diff --git a/tests/test.robot b/tests/test.robot
new file mode 100644
index 0000000..1e0894c
--- /dev/null
+++ b/tests/test.robot
@@ -0,0 +1,172 @@
+# Copyright 2020-present Open Networking Foundation
+# Original copyright 2020-present ADTRAN, Inc.
+#
+# 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
+
+*** Settings ***
+Documentation Library test suite for the grpc_robot library. To run the test suite, the fake device manager from
+... _./servers/dmi_ must have been started beforehand with command _python3 dmi_server.py_.
+Library OperatingSystem WITH NAME os
+Library String
+Library Collections
+Variables ./variables.py
+
+*** Test Cases ***
+Library import
+ [Documentation] Checks if the grpc_robot libraries can be imported.
+ Import Library grpc_robot.Dmi WITH NAME dmi
+ Import Library grpc_robot.Collections
+ Import Library grpc_robot.DmiTools WITH NAME dtools
+ Import Library grpc_robot.VolthaTools WITH NAME vtools
+
+library_versions
+ [Documentation] Checks if the library returns the installed library and device-management-interface versions.
+ [Template] version_check
+ grpc-robot dmi.Library Version Get
+ device-management-interface dmi.Dmi Version Get
+
+keywords
+ [Documentation] Checks if the keyword name exists in the library's keyword list.
+ Keyword Should Exist dmi.connection_close
+ Keyword Should Exist dmi.connection_open
+ Keyword Should Exist dmi.connection_parameters_get
+ Keyword Should Exist dmi.connection_parameters_set
+ Keyword Should Exist dmi.hw_event_mgmt_service_list_events
+ Keyword Should Exist dmi.hw_event_mgmt_service_update_events_configuration
+ Keyword Should Exist dmi.hw_management_service_get_hw_component_info
+ Keyword Should Exist dmi.hw_management_service_get_logging_endpoint
+ Keyword Should Exist dmi.hw_management_service_get_managed_devices
+ Keyword Should Exist dmi.hw_management_service_get_msg_bus_endpoint
+ Keyword Should Exist dmi.hw_management_service_get_physical_inventory
+ Keyword Should Exist dmi.hw_management_service_set_hw_component_info
+ Keyword Should Exist dmi.hw_management_service_set_logging_endpoint
+ Keyword Should Exist dmi.hw_management_service_set_msg_bus_endpoint
+ Keyword Should Exist dmi.hw_management_service_start_managing_device
+ Keyword Should Exist dmi.hw_management_service_stop_managing_device
+ Keyword Should Exist dmi.hw_management_service_get_loggable_entities
+ Keyword Should Exist dmi.hw_management_service_set_log_level
+ Keyword Should Exist dmi.hw_management_service_get_log_level
+ Keyword Should Exist dmi.hw_metrics_mgmt_service_get_metric
+ Keyword Should Exist dmi.hw_metrics_mgmt_service_list_metrics
+ Keyword Should Exist dmi.hw_metrics_mgmt_service_update_metrics_configuration
+ Keyword Should Exist dmi.sw_management_service_activate_image
+ Keyword Should Exist dmi.sw_management_service_download_image
+ Keyword Should Exist dmi.sw_management_service_revert_to_standby_image
+ Keyword Should Exist dmi.sw_management_service_get_software_version
+ Keyword Should Exist dmi.sw_management_service_update_startup_configuration
+ Keyword Should Exist dmi.sw_management_service_get_startup_configuration_info
+ Keyword Should Exist dtools.hw_metrics_mgmt_decode_metric
+ Keyword Should Exist dtools.hw_events_mgmt_decode_event
+ Keyword Should Exist vtools.events_decode_event
+ Keyword Should Exist vtools.tech_profile_decode_resource_instance
+
+dmi
+ [Documentation] Checks the RPC keywords whether or not they handle their input and output correctly and uses the
+ ... fake device manager for that. The fake device manager returns _OK_STATUS_ for each RPC. The variables
+ ... _${keywords_to_skip}_ and _${params}_ are defined in the variables file _./variables.py_.
+ [Setup] dmi.Connection Open host=127.0.0.1 port=50051
+ ${keywords} Run Keyword dmi.Get Keyword Names
+ FOR ${keyword} IN @{keywords}
+ Continue For Loop If '${keyword}' in ${keywords_to_skip}
+ ${status} ${params} Run Keyword And Ignore Error Get From Dictionary ${param_dicts} ${keyword}
+ Run Keyword If '${status}' == 'FAIL' Log no parameters available for keyword '${keyword}' WARN
+ Continue For Loop If '${status}' == 'FAIL'
+ Run Keyword If ${params} == ${NONE} ${keyword} ELSE ${keyword} ${params}
+ END
+ [Teardown] dmi.Connection Close
+
+connection_params
+ [Documentation] Checks the connection parameter settings.
+ ${new_timeout} Set Variable 100
+ ${settings_before} dmi.Connection Parameters Get
+ ${settings_while_set} dmi.Connection Parameters Set timeout=${new_timeout}
+ ${settings_after} dmi.Connection Parameters Get
+ Should Be Equal ${settings_before} ${settings_while_set}
+ Should Be Equal As Integers ${settings_after}[timeout] ${new_timeout}
+
+enum_and_default_values
+ [Documentation] Checks the optional parameters _return_enum_integer_ and _return_defaults_ of the RPC keywords to
+ ... control their output. Check keyword documentation for the meaning of the parameters.
+ ... *Note*: The fake device manager must be running for this test case.
+ [Setup] dmi.Connection Open host=127.0.0.1 port=50051
+ ${params} Get From Dictionary ${param_dicts} hw_management_service_get_log_level
+ ${return} hw_management_service_get_log_level ${params}
+ Should Be Equal As Strings ${return}[status] OK_STATUS
+ Dictionary Should Not Contain Key ${return} reason
+ ${return} hw_management_service_get_log_level ${params} return_enum_integer=true
+ Should Be Equal As Integers ${return}[status] 1
+ Dictionary Should Not Contain Key ${return} reason
+ ${return} hw_management_service_get_log_level ${params} return_enum_integer=${TRUE}
+ Should Be Equal As Integers ${return}[status] 1
+ Dictionary Should Not Contain Key ${return} reason
+ ${return} hw_management_service_get_log_level ${params} return_defaults=true
+ Should Be Equal As Strings ${return}[status] OK_STATUS
+ Should Be Equal As Strings ${return}[reason] UNDEFINED_REASON
+ ${return} hw_management_service_get_log_level ${params} return_defaults=${TRUE}
+ Should Be Equal As Strings ${return}[status] OK_STATUS
+ Should Be Equal As Strings ${return}[reason] UNDEFINED_REASON
+ ${return} hw_management_service_get_log_level ${params} return_enum_integer=true return_defaults=true
+ Should Be Equal As Integers ${return}[status] 1
+ Should Be Equal As Integers ${return}[reason] 0
+ [Teardown] dmi.Connection Close
+
+tools
+ [Documentation] Checks some functions from the tools library which shall support the tester with general functionality.
+ ${dict_1} Create Dictionary name=abc type=123
+ ${dict_2} Create Dictionary name=def type=456
+ ${list} Create List ${dict_1} ${dict_2}
+ ${return_dict} grpc_robot.Collections.List Get Dict By Value ${list} name def
+ Should Be Equal ${return_dict}[type] 456
+
+dmi_tools
+ [Documentation] Checks functions from the DMI tools library with decoding Kafka messages. The variables
+ ... _kafka_metric_messages_ and _kafka_event_messages_ are defined in the variables file.
+ FOR ${kafka} IN @{kafka_metric_messages}
+ ${metric} dtools.Hw Metrics Mgmt Decode Metric ${kafka}[message]
+ Should Be Equal ${metric}[metric_metadata][device_uuid][uuid] 4c411df2-22e6-58d2-b1bb-545a0263d18d
+ Should Be Equal ${metric}[metric_id] ${kafka}[metric]
+ END
+ FOR ${kafka} IN @{kafka_event_messages}
+ ${event} dtools.Hw Events Mgmt Decode Event ${kafka}[message]
+ Should Be Equal ${event}[event_metadata][device_uuid][uuid] 84f46fde-89fa-5a2f-be4a-6d18abe6e953
+ Should Be Equal ${event}[event_id] ${kafka}[event]
+ END
+
+voltha_tools
+ [Documentation] Checks functions from the Voltha tools library with decoding Kafka messages. The variables
+ ... _kafka_voltha_events_messages_ and _voltha_resource_instances_ are defined in the variables file.
+ FOR ${kafka} IN @{kafka_voltha_events_messages}
+ ${event} vtools.Events Decode Event ${kafka}[message] return_defaults=true
+ Should Be Equal ${event}[header][id] Voltha.openolt..1613491472935896440
+ Should Be Equal ${event}[kpi_event2][type] slice
+ ${event} vtools.Events Decode Event ${kafka}[message]
+ Dictionary Should Not Contain Key ${event}[kpi_event2] type
+ END
+ FOR ${input} IN @{voltha_resource_instances}
+ ${instance} vtools.Tech Profile Decode Resource Instance ${input} return_defaults=true
+ Should Be Equal ${instance}[tp_id] ${64}
+ END
+
+*** Keywords ***
+version_check
+ [Documentation] Determines the version of the installed package and compares it with the returned version of the
+ ... corresponding keyword.
+ [Arguments] ${package_name} ${kw_name}
+ ${pip show} os.Run python3 -m pip show ${package_name} | grep Version
+ ${pip show} Split To Lines ${pip show}
+ FOR ${line} IN @{pip show}
+ ${is_version} Evaluate '${line}'.startswith('Version')
+ Continue For Loop If not ${is_version}
+ ${pip_version} Evaluate '${line}'.split(':')[-1].strip()
+ END
+ ${lib_version} Run Keyword ${kw_name}
+ Should Be Equal ${pip_version} ${lib_version}