blob: a454f863ea6b94ff37384988dc9e9a55ab687336 [file] [log] [blame] [edit]
*** Settings ***
Documentation Websocket functionality test.
# Test Parameters:
# OPENBMC_HOST The BMC host name or IP address.
# OPENBMC_USERNAME The username for the BMC login.
# OPENBMC_PASSWORD The password for OPENBMC_USERNAME.
# OS_HOST The OS host name or IP address.
# OS_USERNAME The username for the OS login.
# OS_PASSWORD The password for OS_USERNAME.
Resource ../../lib/esel_utils.robot
Resource ../../lib/bmc_redfish_resource.robot
Resource ../../lib/logging_utils.robot
Resource ../../lib/dump_utils.robot
Resource ../../lib/os_utilities.robot
Library ../../lib/gen_cmd.py
Library OperatingSystem
Suite Setup Suite Setup Execution
Suite Teardown Suite Teardown Execution
Test Teardown Test Teardown Execution
*** Variables ***
${monitor_pgm} websocket_monitor.py
${monitor_file} websocket_monitor_out.txt
${esel_received} eSEL received over websocket interface
${dump_received} Dump notification received over websocket interface
${min_number_chars} 22
${monitor_cmd} ${monitor_pgm} ${OPENBMC_HOST} --openbmc_username ${OPENBMC_USERNAME}
*** Test Cases ***
Test BMC Websocket ESEL Interface
[Documentation] Verify eSELs are reported over the websocket interface.
[Tags] Test_BMC_Websocket_ESEL_Interface
# Check that the ipmitool is available. That tool is used to create an eSEL.
Tool Exist ipmitool
# Spawn the websocket monitor program and then generate an eSEL.
# The monitor should asynchronously receive the eSEL through the
# websocket interface and report this fact to standard output.
Start Websocket Monitor logging
${initial_esel_count}= Get Number Of Event Logs
# Generate eSEL (e.g. typically "CPU 1 core 3 has failed").
Create eSEL
${current_esel_count}= Get Number Of Event Logs
Run Keyword If ${initial_esel_count} == ${current_esel_count}
... Fail msg=System failed to generate eSEL upon request.
${line}= Grep File ${monitor_file} ${esel_received}
# Typical monitor_file contents:
# --------------- ON_MESSAGE:begin --------------------
# {"event":"PropertiesChanged","interface":"xyz.openbmc_project.Logging.
# Entry","path":"/xyz/openbmc_project/logging/entry/5","properties":{"Id":5}}
# eSEL received over websocket interface.
${num_chars}= Get Length ${line}
Run Keyword If ${num_chars} < ${min_number_chars} Fail
... msg=No eSEL notification from websocket_monitor.py.
Test BMC Websocket Dump Interface
[Documentation] Verify dumps are reported over the websocket interface.
[Tags] Test_BMC_Websocket_Dump_Interface
Redfish Delete All BMC Dumps
Start Websocket Monitor dump
${dump_id}= Create User Initiated BMC Dump Via Redfish
Check Existence Of BMC Dump File ${dump_id}
# Check that the monitor received notification of the dump.
${line}= Grep File ${monitor_file} ${dump_received}
# Typical monitor_file contents:
# --------------- ON_MESSAGE:begin --------------------
# {"event":"PropertiesChanged","interface":"xyz.openbmc_project.Dump.
# Entry","path":"/xyz/openbmc_project/dump/entry/1","properties":{"Size":157888}}
# Dump notification received over websocket interface.
${num_chars}= Get Length ${line}
Run Keyword If ${num_chars} < ${min_number_chars} Fail
... msg=No dump notification from websocket_monitor.py.
*** Keywords ***
Start Websocket Monitor
[Documentation] Fork the monitor to run in the background.
[Arguments] ${monitor_type}
# Description of Argument(s):
# monitor_type The type of websocket notifications to monitor,
# either "logging" or "dump".
# Delete the previous output file, if any.
Remove File ${monitor_file}
${command}= Catenate ${monitor_cmd} --openbmc_password ${OPENBMC_PASSWORD}
... --monitor_type ${monitor_type} 1>${monitor_file} 2>&1
# Start the monitor. Fork so its a parallel task.
Shell Cmd ${command} fork=${1}
# Allow time for the monitor to initialize.
Sleep 5s
Find Websocket Monitor
[Documentation] Return the process Id(s) of running websocket monitors.
${cmd}= Catenate ps -ef | grep '${monitor_cmd}'
... | grep -v grep | grep -v bash | cut -c10-14
${shell_rc} ${pid}= Shell Cmd ${cmd}
# There may be more than one pid returned if there is an instance
# of a monitory_pgm running from a previous run.
@{pid_list}= Split String ${pid}
RETURN ${pid_list}
Kill Websocket Monitor
[Documentation] Terminate running websocket monitor.
${pid_list}= Find Websocket Monitor
FOR ${pid} IN @{pid_list}
Shell Cmd kill -s SIGTERM ${pid}
END
Print Websocket Monitor Log
[Documentation] Show the contents of the monitor output file.
${websocket_monitor_log}= OperatingSystem.Get File ${monitor_file}
Log to Console websocket_monitor_log:
Log to Console ${websocket_monitor_log}
Suite Setup Execution
[Documentation] Do the suite setup tasks.
Run Keyword Redfish Power On stack_mode=skip
Redfish.Login
Delete All Error Logs
Kill Websocket Monitor
# Allow time for Error Logs to be deleted.
Sleep 5s
Test Teardown Execution
[Documentation] Do teardown tasks after a test.
FFDC On Test Case Fail
Run Keyword If '${TEST_STATUS}' == 'FAIL' Print Websocket Monitor Log
Kill Websocket Monitor
Redfish Delete All BMC Dumps
Suite Teardown Execution
[Documentation] Do the post-suite teardown.
Delete All Error Logs
Run Keyword and Return Status Redfish.Logout