1*** Settings ***
2Documentation    Test BMC Manager functionality.
3Resource         ../../lib/resource.robot
4Resource         ../../lib/bmc_redfish_resource.robot
5Resource         ../../lib/common_utils.robot
6Resource         ../../lib/openbmc_ffdc.robot
7Resource         ../../lib/boot_utils.robot
8Resource         ../../lib/open_power_utils.robot
9Resource         ../../lib/bmc_network_utils.robot
10Library          ../../lib/gen_robot_valid.py
11
12Test Setup       Test Setup Execution
13Test Teardown    Test Teardown Execution
14
15
16*** Variables ***
17
18${SYSTEM_SHUTDOWN_TIME}    ${5}
19
20# Strings to check from journald.
21${REBOOT_REGEX}    ^\-- Reboot --
22
23*** Test Cases ***
24
25Verify Redfish BMC Firmware Version
26    [Documentation]  Get firmware version from BMC manager.
27    [Tags]  Verify_Redfish_BMC_Firmware_Version
28
29    Redfish.Login
30    ${resp}=  Redfish.Get  /redfish/v1/Managers/bmc
31    Should Be Equal As Strings  ${resp.status}  ${HTTP_OK}
32    ${bmc_version}=  Get BMC Version
33    Should Be Equal As Strings
34    ...  ${resp.dict["FirmwareVersion"]}  ${bmc_version.strip('"')}
35
36
37Verify Redfish BMC Manager Properties
38    [Documentation]  Verify BMC managers resource properties.
39    [Tags]  Verify_Redfish_BMC_Manager_Properties
40
41    Redfish.Login
42    ${resp}=  Redfish.Get  /redfish/v1/Managers/bmc
43    Should Be Equal As Strings  ${resp.status}  ${HTTP_OK}
44    # Example:
45    #  "Description": "Baseboard Management Controller"
46    #  "Id": "bmc"
47    #  "Model": "OpenBmc",
48    #  "Name": "OpenBmc Manager",
49    #  "UUID": "xxxxxxxx-xxx-xxx-xxx-xxxxxxxxxxxx"
50    #  "PowerState": "On"
51
52    Should Be Equal As Strings
53    ...  ${resp.dict["Description"]}  Baseboard Management Controller
54    Should Be Equal As Strings  ${resp.dict["Id"]}  bmc
55    Should Be Equal As Strings  ${resp.dict["Model"]}  OpenBmc
56    Should Be Equal As Strings  ${resp.dict["Name"]}  OpenBmc Manager
57    Should Not Be Empty  ${resp.dict["UUID"]}
58    Should Be Equal As Strings  ${resp.dict["PowerState"]}  On
59
60
61Verify MAC Address Property Is Populated
62    [Documentation]  Verify BMC managers resource properties.
63    [Tags]  Verify_MAC_Address_Property_Is_Populated
64
65    # Get OrderedDict from the BMC which contains active ethernet channel.
66    # Example: ([('1', {'name': 'eth0',
67    #                   'is_valid': True,
68    #                   'active_sessions': 0,
69    #                   'channel_info': {'medium_type': 'lan-802.3',
70    #                                    'protocol_type': 'ipmb-1.0',
71    #                                    'session_supported': 'multi-session',
72    #                                    'is_ipmi': True
73    #                                   }
74    #                  }
75    #          )])
76
77    ${active_channel_config}=  Get Active Channel Config
78
79    FOR  ${channel_number}  IN  @{active_channel_config.keys()}
80        Log Dictionary  ${active_channel_config["${channel_number}"]}
81
82        # Get ethernet valid paths in redfish.
83        # Example: ['/redfish/v1/Managers/bmc/EthernetInterfaces']
84        ${eth_interface}=  redfish_utils.Get Endpoint Path List
85        ...  /redfish/v1/Managers/  EthernetInterfaces
86
87        # Get the MACAddress attrivute value with the 'name': 'eth0'.
88        # Example: /redfish/v1/Managers/bmc/EthernetInterfaces/eth0
89        ${redfish_mac_addr}=  Redfish.Get Attribute
90        ...  ${eth_interface[0]}/${active_channel_config["${channel_number}"]["name"]}
91        ...  MACAddress
92    END
93
94    Rprint Vars  redfish_mac_addr  fmt=terse
95    Valid Value  redfish_mac_addr
96
97    ${ipaddr_mac_addr}=  Get BMC MAC Address List
98    Rprint Vars  ipaddr_mac_addr  fmt=terse
99
100    List Should Contain Value  ${ipaddr_mac_addr}  ${redfish_mac_addr}
101
102
103Redfish BMC Manager GracefulRestart When Host Off
104    [Documentation]  BMC graceful restart when host is powered off.
105    [Tags]  Redfish_BMC_Manager_GracefulRestart_When_Host_Off
106
107    # "Actions": {
108    # "#Manager.Reset": {
109    #  "ResetType@Redfish.AllowableValues": [
110    #    "GracefulRestart"
111    #  ],
112    #  "target": "/redfish/v1/Managers/bmc/Actions/Manager.Reset"
113    # }
114
115    ${test_file_path}=  Set Variable  /tmp/before_bmcreboot
116    BMC Execute Command  touch ${test_file_path}
117
118    Redfish OBMC Reboot (off)
119
120    BMC Execute Command  if [ -f ${test_file_path} ] ; then false ; fi
121    Verify BMC RTC And UTC Time Drift
122
123    # Check for journald persistency post reboot.
124    Check For Regex In Journald  ${REBOOT_REGEX}  error_check=${1}
125
126
127Verify Boot Count After BMC Reboot
128    [Documentation]  Verify boot count increments on BMC reboot.
129    [Tags]  Verify_Boot_Count_After_BMC_Reboot
130
131    Set BMC Boot Count  ${0}
132    Redfish OBMC Reboot (off)
133    ${boot_count}=  Get BMC Boot Count
134    Should Be Equal  ${boot_count}  ${1}  msg=Boot count is not incremented.
135
136
137Redfish BMC Manager GracefulRestart When Host Booted
138    [Documentation]  BMC graceful restart when host is running.
139    [Tags]  Redfish_BMC_Manager_GracefulRestart_When_Host_Booted
140
141    Redfish OBMC Reboot (run)
142
143    # TODO: Replace OCC state check with redfish property when available.
144    Verify OCC State
145
146
147*** Keywords ***
148
149Test Setup Execution
150    [Documentation]  Do test case setup tasks.
151
152    redfish.Login
153
154
155Test Teardown Execution
156    [Documentation]  Do the post test teardown.
157
158    FFDC On Test Case Fail
159    redfish.Logout
160