1*** Settings ***
2Documentation      Test BMC using https://github.com/DMTF/Redfish-Service-Validator.
3...                DMTF tool.
4
5Library            OperatingSystem
6Library            ../../lib/gen_robot_print.py
7Resource           ../../lib/dmtf_tools_utils.robot
8Resource           ../../lib/bmc_redfish_resource.robot
9Resource           ../../lib/bmc_redfish_utils.robot
10
11*** Variables ***
12
13${DEFAULT_PYTHON}  python3
14${rsv_dir_path}    Redfish-Service-Validator
15${rsv_github_url}  https://github.com/DMTF/Redfish-Service-Validator.git
16${cmd_str_master}  ${DEFAULT_PYTHON} ${rsv_dir_path}${/}RedfishServiceValidator.py
17...                --ip https://${OPENBMC_HOST}:${HTTPS_PORT} --authtype=Session -u ${OPENBMC_USERNAME}
18...                -p ${OPENBMC_PASSWORD} --logdir ${EXECDIR}${/}logs${/} --debugging
19${branch_name}    main
20
21*** Test Case ***
22
23Test BMC Redfish Using Redfish Service Validator
24    [Documentation]  Check conformance with a Redfish service interface.
25    [Tags]  Test_BMC_Redfish_Using_Redfish_Service_Validator
26
27    Download DMTF Tool  ${rsv_dir_path}  ${rsv_github_url}  ${branch_name}
28
29    ${rc}  ${output}=  Run DMTF Tool  ${rsv_dir_path}  ${cmd_str_master}  check_error=1
30
31    Redfish Service Validator Result  ${output}
32    Run Keyword If  ${rc} != 0  Fail  Redfish-Service-Validator Failed.
33
34
35Run Redfish Service Validator With Additional Roles
36    [Documentation]  Check Redfish conformance using the Redfish Service Validator.
37    ...  Run the validator as additional non-admin user roles.
38    [Tags]  Run_Redfish_Service_Validator_With_Additional_Roles
39    [Template]  Create User And Run Service Validator
40
41    #username      password       role        enabled
42    operator_user  0penBmc123     Operator    ${True}
43    readonly_user  0penBmc123     ReadOnly    ${True}
44
45*** Keywords ***
46
47Create User And Run Service Validator
48    [Documentation]  Create user and run validator.
49    [Arguments]   ${username}  ${password}  ${role}  ${enabled}
50    [Teardown]  Delete User Created  ${username}
51
52    # Description of argument(s):
53    # username            The username to be created.
54    # password            The password to be assigned.
55    # role                The role of the user to be created
56    #                     (e.g. "Administrator", "Operator", etc.).
57    # enabled             Indicates whether the username being created
58    #                     should be enabled (${True}, ${False}).
59
60    Redfish.Login
61    Redfish Create User  ${username}  ${password}  ${role}  ${enabled}
62    Redfish.Logout
63
64    Download DMTF Tool  ${rsv_dir_path}  ${rsv_github_url}  ${branch_name}
65
66    ${cmd}=  Catenate  ${DEFAULT_PYTHON} ${rsv_dir_path}${/}RedfishServiceValidator.py
67    ...  --ip https://${OPENBMC_HOST}:${HTTPS_PORT} --authtype=Session -u ${username}
68    ...  -p ${password} --logdir ${EXECDIR}${/}logs_${username}${/} --debugging
69
70    Rprint Vars  cmd
71
72    ${rc}  ${output}=  Run DMTF Tool  ${rsv_dir_path}  ${cmd}  check_error=1
73
74    Redfish Service Validator Result  ${output}
75    Run Keyword If  ${rc} != 0  Fail
76
77
78Delete User Created
79    [Documentation]  Delete user.
80    [Arguments]   ${username}
81
82    # Description of argument(s):
83    # username            The username to be deleted.
84
85    Redfish.Login
86    Redfish.Delete  /redfish/v1/AccountService/Accounts/${username}
87    Redfish.Logout
88