blob: 1a7888cfced4bada2b603f15cbf70ee9f3bd27d9 [file] [log] [blame]
*** 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}]