xref: /openbmc/openbmc-test-automation/redfish/update_service/test_firmware_inventory.robot (revision eff332f552b4486fa1b675f0376f0546d25a452b)
1*** Settings ***
2Documentation    Verify that Redfish software inventory can be collected.
3
4Resource         ../../lib/resource.robot
5Resource         ../../lib/bmc_redfish_resource.robot
6Resource         ../../lib/openbmc_ffdc.robot
7Library          ../../lib/gen_robot_valid.py
8
9Test Setup       Test Setup Execution
10Test Teardown    Test Teardown Execution
11
12*** Test Cases ***
13
14Verify Redfish Update Service Enabled
15    [Documentation]  Verify "ServiceEnabled" is enabled.
16    [Tags]  Verify_Update_Service_Enabled
17
18    # Example:
19    # "HttpPushUri": "/redfish/v1/UpdateService",
20    # "Id": "UpdateService",
21    # "Name": "Update Service",
22    # "ServiceEnabled": true
23
24    ${resp}=  Redfish.Get  /redfish/v1/UpdateService
25    Should Be Equal As Strings  ${resp.dict["ServiceEnabled"]}  ${True}
26
27
28Verify Redfish Software Inventory Collection
29    [Documentation]  Verify software inventory collection member and object entries.
30    [Tags]  Verify_Redfish_Software_Inventory_Collection
31
32    # Example:
33    # {
34    #    "@odata.type": "#SoftwareInventoryCollection.SoftwareInventoryCollection",
35    #    "Members": [
36    #      {
37    #        "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/a3522998"
38    #      },
39    #      {
40    #        "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/a7c79f71"
41    #      },
42    #      {
43    #        "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/ace821ef"
44    #      }
45    #   ],
46    #   "Members@odata.count": 3,
47    #   "Name": "Software Inventory Collection"
48    # }
49
50    ${resp}=  Redfish.Get  /redfish/v1/UpdateService/FirmwareInventory
51
52    Should Be True  ${resp.dict["Members@odata.count"]} >= ${1}
53    Length Should Be  ${resp.dict["Members"]}  ${resp.dict["Members@odata.count"]}
54
55
56Redfish Software Inventory Status Check
57    [Documentation]  Get firmware inventory entries and do health check status.
58    [Tags]  Redfish_Software_Inventory_Status_Check
59
60    ${resp}=  Redfish.Get  /redfish/v1/UpdateService/FirmwareInventory
61
62    # Entries "Members@odata.count": 3,
63    # {'@odata.id': '/redfish/v1/UpdateService/FirmwareInventory/a3522998'}
64    # {'@odata.id': '/redfish/v1/UpdateService/FirmwareInventory/a7c79f71'}
65    # {'@odata.id': '/redfish/v1/UpdateService/FirmwareInventory/ace821ef'}
66
67    :FOR  ${entry}  IN RANGE  0  ${resp.dict["Members@odata.count"]}
68    \  ${resp_resource}=  Redfish.Get  ${resp.dict["Members"][${entry}]["@odata.id"]}
69    # Example:
70    # "Status": {
71    #     "Health": "OK",
72    #     "HealthRollup": "OK",
73    #     "State": "Enabled"
74    # },
75    \  Should Be Equal As Strings  ${resp_resource.dict["Status"]["Health"]}  OK
76    \  Should Be Equal As Strings  ${resp_resource.dict["Status"]["HealthRollup"]}  OK
77    \  Should Be Equal As Strings  ${resp_resource.dict["Status"]["State"]}  Enabled
78
79
80Verify BMC Version Matches With FirmwareInventory
81    [Documentation]  Verify BMC version from FirmwareInventory same as in manager.
82    [Tags]  Verify_BMC_Version_Matches_With_FirmwareInventory
83
84    ${bmc_manager}=  Redfish.Get  /redfish/v1/Managers/bmc
85    ${manager_bmc_version}=  Get BMC Version
86    # Check for manager version and cat /etc/os-release.
87    Should Be Equal As Strings
88    ...  ${bmc_manager.dict["FirmwareVersion"]}  ${manager_bmc_version.strip('"')}
89
90    ${resp}=  Redfish.Get  /redfish/v1/UpdateService/FirmwareInventory
91
92    # Entries "Members@odata.count": 3,
93    # {'@odata.id': '/redfish/v1/UpdateService/FirmwareInventory/a3522998'}
94    # {'@odata.id': '/redfish/v1/UpdateService/FirmwareInventory/a7c79f71'}
95    # {'@odata.id': '/redfish/v1/UpdateService/FirmwareInventory/ace821ef'}
96
97    ${actual_count}=  Evaluate  ${resp.dict["Members@odata.count"]}-1
98    :FOR  ${entry}  IN RANGE  0  ${resp.dict["Members@odata.count"]}
99    \  ${resp_resource}=  Redfish.Get  ${resp.dict["Members"][${entry}]["@odata.id"]}
100    # 3rd comparison of BMC version and verify FirmwareInventory bmc version.
101    # Example:
102    # "Version": 2.7.0-dev-19-g9b44ea7
103    \  Exit For Loop If  '${resp_resource.dict["Version"]}' == '${manager_bmc_version.strip('"')}'
104    \  Run Keyword If  '${entry}' == '${actual_count}'  Fail
105    ...  BMC version not there in Firmware Inventory
106
107
108Verify UpdateService Supports TransferProtocol TFTP
109    [Documentation]  Verify update service supported values have TFTP protocol.
110    [Tags]  Verify_UpdateService_Supports_TransferProtocol_TFTP
111
112    # Example:
113    #   "Actions": {
114    #     "#UpdateService.SimpleUpdate": {
115    #       "TransferProtocol@Redfish.AllowableValues": [
116    #         "TFTP"
117    #       ],
118    #       "target": "/redfish/v1/UpdateService/Actions/UpdateService.SimpleUpdate"
119    #     }
120    #  },
121
122    ${allowable_values}=  Redfish.Get Attribute  /redfish/v1/UpdateService  Actions
123
124    Rvalid Value  allowable_values["#UpdateService.SimpleUpdate"]["TransferProtocol@Redfish.AllowableValues"][0]  valid_values=['TFTP']
125    Rvalid Value  allowable_values["#UpdateService.SimpleUpdate"]["target"]  valid_values=['/redfish/v1/UpdateService/Actions/UpdateService.SimpleUpdate']
126
127
128Verify Redfish BIOS Version
129    [Documentation]  Get host firmware version from system inventory.
130    [Tags]  Verify_Redfish_BIOS_Version
131
132    ${bios_version}=  Redfish.Get Attribute  /redfish/v1/Systems/system/  BiosVersion
133    ${pnor_version}=  Get PNOR Version
134    Should Be Equal  ${pnor_version}  ${bios_version}
135
136
137*** Keywords ***
138
139Test Setup Execution
140    [Documentation]  Do test case setup tasks.
141
142    Redfish.Login
143
144
145Test Teardown Execution
146    [Documentation]  Do the post test teardown.
147
148    FFDC On Test Case Fail
149    Redfish.Logout
150