*** Settings *** Documentation Utilities for SNMP testing. Resource ../../lib/rest_client.robot Resource ../../lib/utils.robot *** Keywords *** Get SNMP URI List [Documentation] Get all SNMP URIs and return them as list. # Sample output: # "data": [ # "/xyz/openbmc_project/network/snmp/manager/e9767624", # "/xyz/openbmc_project/network/snmp/manager/31f4ce8b" # ], @{snmp_uri_list}= Read Properties ${SNMP_MANAGER_URI} RETURN @{snmp_uri_list} Configure SNMP Manager On BMC [Documentation] Configure SNMP manager on BMC. [Arguments] ${snmp_ip} ${port} ${expected_result} # Description of argument(s): # snmp_ip SNMP manager IP. # port Network port where SNMP manager is listening. # expected_result Expected status of SNMP configuration. @{snmp_parm_list}= Create List ${snmp_ip} ${port} ${data}= Create Dictionary data=@{snmp_parm_list} ${resp}= OpenBMC Post Request ... ${SNMP_MANAGER_URI}action/Client data=${data} Run Keyword If '${expected_result}' == 'error' ... Should Be Equal As Strings ... ${resp.status_code} ${HTTP_BAD_REQUEST} ... msg=Allowing the configuration of an invalid SNMP. ... ELSE ... Should Be Equal As Strings ${resp.status_code} ${HTTP_OK} ... msg=Not allowing the configuration of a valid SNMP. Get List Of SNMP Manager And Port Configured On BMC [Documentation] Get list of SNMP managers and return the list. @{snmp_uri_list}= Get SNMP URI List @{ip_and_port_list}= Create List # Sample output of snmp_uri_list enumeration. # { # "data": { # "/xyz/openbmc_project/network/snmp/manager/92ae7a66": { # "Address": "10.6.6.6", # "AddressFamily": "xyz.openbmc_project.Network.Client.IPProtocol.IPv4", # "Port": 186 # }, FOR ${snmp_uri} IN @{snmp_uri_list} ${ip}= Read Attribute ${snmp_uri} Address ${port}= Read Attribute ${snmp_uri} Port Append To List ${ip_and_port_list} ${ip} ${port} END RETURN @{ip_and_port_list} Verify SNMP Manager [Documentation] Verify SNMP manager configured on BMC. [Arguments] ${snmp_ip} ${port} # Description of argument(s): # snmp_ip SNMP manager IP. # port Network port where SNMP manager is listening. @{ip_and_port}= Create List ${snmp_ip} ${port} @{ip_and_port_list}= Get List Of SNMP Manager And Port Configured On BMC List Should Contain Sub List ${ip_and_port_list} ${ip_and_port} ... msg=Valid SNMP manager is not found on BMC. Get SNMP Manager Object [Documentation] Find the SNMP object for the given ip and port and return it. # If no object can be located, return ${EMPTY}. [Arguments] ${ip} ${port} # Description of argument(s): # ip SNMP manager IP. # port Network port where SNMP manager is listening. ${snmp_objs}= Read Properties ${SNMP_MANAGER_URI}enumerate FOR ${snmp_obj} IN @{snmp_objs} ${obj}= Set Variable ${snmp_objs['${snmp_obj}']} Run Keyword If ... '${obj['Address']}' == '${ip}' and '${obj['Port']}' == '${port}' ... Return From Keyword ${snmp_obj} END Return From Keyword ${EMPTY} Delete SNMP Manager And Object [Documentation] Delete SNMP manager. [Arguments] ${snmp_ip} ${port} # Description of argument(s): # snmp_ip SNMP manager IP. # port Network port where SNMP manager is listening. ${snmp_obj}= Get SNMP Manager Object ${snmp_ip} ${port} # If the given IP and port is not configured, return. # Otherwise, delete the IP and object. Run Keyword And Return If '${snmp_obj}' == '${EMPTY}' ... Pass Execution SNMP manager to be deleted is not configured. OpenBMC Delete Request ${snmp_obj} # Verify whether deleted SNMP is removed from BMC system. ${status}= Run Keyword And Return Status Verify SNMP Manager ... ${snmp_ip} ${port} Should Be Equal ${status} ${False} msg=SNMP manager is not deleted. Start SNMP Manager [Documentation] Start SNMP listener on the remote SNMP manager. Open Connection And Log In ${SNMP_MGR1_USERNAME} ${SNMP_MGR1_PASSWORD} ... alias=snmp_server host=${SNMP_MGR1_IP} # The execution of the SNMP_TRAPD_CMD is necessary to cause SNMP to begin # listening to SNMP messages. SSHLibrary.write ${SNMP_TRAPD_CMD} &