*** Settings *** Documentation Test Redfish to verify responses for SessionService and Hypermedia. Resource ../../lib/bmc_redfish_resource.robot Resource ../../lib/openbmc_ffdc.robot Test Teardown FFDC On Test Case Fail Test Setup Printn Test Tags Service_Root *** Test Cases *** Redfish Login And Logout [Documentation] Login to BMCweb and then logout. [Tags] Redfish_Login_And_Logout Redfish.Login Redfish.Logout GET Redfish Hypermedia Without Login [Documentation] GET hypermedia URL without login. [Tags] GET_Redfish_Hypermedia_Without_Login [Setup] Redfish.Logout [Template] GET And Verify Redfish Response # Expect status Resource URL Path ${HTTP_OK} /redfish ${HTTP_OK} /redfish/v1 GET Redfish SessionService Without Login [Documentation] Get /redfish/v1/SessionService without login [Tags] GET_Redfish_SessionService_Without_Login [Setup] Redfish.Logout ${resp}= Redfish.Get /redfish/v1/SessionService ... valid_status_codes=[${HTTP_UNAUTHORIZED}] GET Redfish Resources With Login [Documentation] Login to BMCweb and GET valid resource. [Tags] GET_Redfish_Resources_With_Login [Setup] Redfish.Login [Template] GET And Verify Redfish Response # Expect status Resource URL Path ${HTTP_OK} /redfish/v1/SessionService ${HTTP_OK} /redfish/v1/AccountService ${HTTP_OK} /redfish/v1/Systems/${SYSTEM_ID} ${HTTP_OK} /redfish/v1/Chassis/${CHASSIS_ID} ${HTTP_OK} /redfish/v1/Managers/${MANAGER_ID} ${HTTP_OK} /redfish/v1/UpdateService Redfish Login Using Invalid Token [Documentation] Login to BMCweb with invalid token. [Tags] Redfish_Login_Using_Invalid_Token Create Session openbmc ${AUTH_URI} # Example: "X-Auth-Token: 3la1JUf1vY4yN2dNOwun" ${headers}= Create Dictionary Content-Type=application/json ... X-Auth-Token=deadbeef ${resp}= GET On Session ... openbmc /redfish/v1/SessionService/Sessions headers=${headers} ... expected_status=${HTTP_UNAUTHORIZED} Should Be Equal As Strings ${resp.status_code} ${HTTP_UNAUTHORIZED} Verify Redfish Invalid URL Response Code [Documentation] Login to BMCweb and verify error response code. [Tags] Verify_Redfish_Invalid_URL_Response_Code Redfish.Login Wait Until Keyword Succeeds 1 min 30 sec ... Redfish.Get /redfish/v1/idontexist valid_status_codes=[${HTTP_NOT_FOUND}] Redfish.Logout Delete Redfish Session Using Valid Login [Documentation] Delete a session using valid login. [Tags] Delete_Redfish_Session_Using_Valid_Login Redfish.Login ${session_info}= Get Redfish Session Info Redfish.Login # Example o/p: # [{'@odata.id': '/redfish/v1/SessionService/Sessions/bOol3WlCI8'}, # {'@odata.id': '/redfish/v1/SessionService/Sessions/Yu3xFqjZr1'}] ${resp_list}= Redfish_Utils.List Request ... /redfish/v1/SessionService/Sessions Redfish.Delete ${session_info["location"]} ${resp}= Redfish_Utils.List Request /redfish/v1/SessionService/Sessions List Should Not Contain Value ${resp} ${session_info["location"]} Redfish Login Via SessionService [Documentation] Login to BMC via redfish session service. [Tags] Redfish_Login_Via_SessionService Create Session openbmc https://${OPENBMC_HOST}:${HTTPS_PORT} ${headers}= Create Dictionary Content-Type=application/json ${data}= Set Variable {"UserName":"${OPENBMC_USERNAME}", "Password":"${OPENBMC_PASSWORD}"} ${resp}= POST On Session openbmc /redfish/v1/SessionService/Sessions data=${data} headers=${headers} Should Be Equal As Strings ${resp.status_code} ${HTTP_CREATED} ${headers}= Create Dictionary Content-Type=application/json ... X-Auth-Token=${resp.headers["X-Auth-Token"]} ${resp}= DELETE On Session openbmc ${REDFISH_SESSION}${/}${resp.json()["Id"]} headers=${headers} Should Be Equal As Strings ${resp.status_code} ${HTTP_OK} Verify Redfish Unresponsive URL paths [Documentation] Verify that all URLs in /redfish/v1 respond. [Tags] Verify_Redfish_Unresponsive_URL_paths Redfish.Login ${resource_list} ${dead_resources}= Enumerate Request /redfish/v1 include_dead_resources=True Redfish.Logout Valid Length dead_resources max_length=0 *** Keywords *** GET And Verify Redfish Response [Documentation] GET given resource and verify response. [Arguments] ${valid_status_codes} ${resource_path} # Description of argument(s): # valid_status_codes A comma-separated list of acceptable # status codes (e.g. 200). # resource_path Redfish resource URL path. ${resp}= Redfish.Get ${resource_path} ... valid_status_codes=[${valid_status_codes}]