1*** Settings ***
2
3Documentation       eSEL's Test cases.
4
5Resource            ../../../lib/ipmi_client.robot
6Resource            ../../../lib/openbmc_ffdc.robot
7Resource            ../../../lib/utils.robot
8Resource            ../../../lib/boot_utils.robot
9Resource            ../../../lib/esel_utils.robot
10Resource            ../../../lib/boot_utils.robot
11Variables           ../../../data/variables.py
12
13Suite Setup         Suite Setup Execution
14Suite Teardown      Suite Teardown Execution
15Test Setup          Test Setup Execution
16Test Teardown       FFDC On Test Case Fail
17
18Force Tags  eSEL_Logging
19
20*** Variables ***
21
22${stack_mode}       skip
23
24${LOGGING_SERVICE}  xyz.openbmc_project.Logging.service
25
26${ESEL_DATA}        ESEL=00 00 df 00 00 00 00 20 00 04 12 35 6f aa 00 00
27
28*** Test Cases ***
29
30Verify eSEL Using Redfish
31    [Documentation]  Generate eSEL log and verify using redfish.
32    [Tags]  Verify_eSEL_Using_Redfish
33
34    Create eSEL
35    Event Log Should Exist
36
37
38Verify eSEL Entries Using Redfish
39    [Documentation]  Verify that eSEL entries have data.
40    [Tags]  Verify_eSEL_Entries_Using_Redfish
41
42    Create eSEL
43    Redfish.Login
44    Verify eSEL Entries
45
46
47# TODO: openbmc/openbmc-test-automation#1789
48Verify eSEL Description And EntryID Using REST
49    [Documentation]  Create eSEL log and verify "Description" and "EntryID"
50    ...  are not empty via REST.
51    [Tags]  Verify_eSEL_Description_And_EntryID_Using_REST
52
53    # {
54    # "AdditionalData": [
55    #     "CALLOUT_INVENTORY_PATH=",
56    #     "ESEL=00 00 df 00 00 00 00 20 00 04 12 35 6f aa 00 00",
57    #     "_PID=1175"
58    # ],
59    # "Description": "An error was detected with the base platform,
60    #  but was not able to be deciphered. Contact your next level of support.",
61    # "EventID": "FQPSPAA0011M",
62    # "Id": 1,
63    # "Message": "org.open_power.Host.Error.Event",
64    # "Resolved": 0,
65    # "Severity": "xyz.openbmc_project.Logging.Entry.Level.Error",
66    # "Timestamp": 1524233022072,
67    # "associations": [
68    #    [
69    #        "callout",
70    #        "fault",
71    #        ""
72    #    ]
73    # ]
74
75    Create eSEL
76
77    ${elog_entry}=  Get URL List  ${BMC_LOGGING_ENTRY}
78    ${desc}=  Read Attribute  ${elog_entry[0]}  Description
79    Should Not Be Empty  ${desc}  msg=${desc} is not populated.
80
81    ${event_id}=  Read Attribute  ${elog_entry[0]}  EventID
82    Should Not Be Equal  ${event_id}  ${None}
83    ...  msg=${event_id} is populated default "None".
84
85
86Verify Multiple eSEL Using Redfish
87    [Documentation]  Generate multiple eSEL log and verify using redfish
88    [Tags]  Verify_Multiple_eSEL_Using_Redfish
89
90    Create eSEL
91    Create eSEL
92    ${entries}=  Count eSEL Entries
93    Should Be Equal As Integers  ${entries}  ${2}
94    ...  msg=Expecting 2 eSELs but found ${entries}.
95
96
97# TODO: openbmc/openbmc-test-automation#1789
98Check eSEL AdditionalData
99    [Documentation]  Generate eSEL log and verify AdditionalData is
100    ...              not empty.
101    [Tags]  Check_eSEL_AdditionalData
102
103    Create eSEL
104    ${elog_entry}=  Get URL List  ${BMC_LOGGING_ENTRY}
105    ${resp}=  OpenBMC Get Request  ${elog_entry[0]}
106    Should Be Equal As Strings  ${resp.status_code}  ${HTTP_OK}
107    ${jsondata}=  To JSON  ${resp.content}
108    # "/xyz/openbmc_project/logging/entry/1": {
109    #    "Timestamp": 1487743771812,
110    #    "AdditionalData": [],
111    #    "Message": "org.open_power.Error.Host.Event.Event",
112    #    "Id": 1,
113    #    "Severity": "xyz.openbmc_project.Logging.Entry.Level.Emergency"
114    # }
115    Should Not Be Empty  ${jsondata["data"]["AdditionalData"]}
116
117
118Test Wrong Reservation_ID
119    [Documentation]  This testcase is to test BMC can handle multi-requestor's
120    ...              oem partial add command with incorrect reservation id.
121    ...              It simulates sending partial add command with fake content
122    ...              and wrong Reservation ID. This command will be rejected.
123    [Tags]  Test_Wrong_Reservation_ID
124
125    ${rev_id_1}=   Run Inband IPMI Raw Command  0x0a 0x42
126    ${rev_id_ls}=   Get Substring   ${rev_id_1}   1   3
127    ${rev_id_ms}=   Get Substring   ${rev_id_1}   -2
128    Run Inband IPMI Raw Command   0x0a 0x42
129    ${output}=  Check IPMI OEMpartialadd Reject
130    ...  0x3a 0xf0 0x${rev_id_ls} 0x${rev_id_ms} 0 0 0 0 0 1 2 3 4 5 6 7 8 9 0xa 0xb 0xc 0xd 0xe 0xf
131    Should Contain   ${output}   Reservation cancelled
132
133Test Correct Reservation_ID
134    [Documentation]  This testcase is to test BMC can handle multi-requestor's
135    ...              oem partial add command with correct reservation id. It
136    ...              simulates sending partial add command with fake content
137    ...              and correct Reservation ID. This command will be accepted.
138    [Tags]  Test_Correct_Reservation_ID
139
140    Run Inband IPMI Raw Command  0x0a 0x42
141    ${rev_id_2}=    Run Inband IPMI Raw Command  0x0a 0x42
142    ${rev_id_ls}=   Get Substring   ${rev_id_2}   1   3
143    ${rev_id_ms}=   Get Substring   ${rev_id_2}   -2
144    ${output}=  Check IPMI OEMpartialadd Accept
145    ...  0x3a 0xf0 0x${rev_id_ls} 0x${rev_id_ms} 0 0 0 0 0 1 2 3 4 5 6 7 8 9 0xa 0xb 0xc 0xd 0xe 0xf
146    Should Be Empty    ${output}
147
148
149*** Keywords ***
150
151
152Suite Teardown Execution
153    [Documentation]  Cleanup test logs and connection.
154    Close All Connections
155    Redfish.Logout
156
157
158Restart Logging Service
159    [Documentation]  Restart Logging to clear eSEL log.
160    ${MainPID}  ${stderr}=  Execute Command
161    ...  systemctl restart ${LOGGING_SERVICE}  return_stderr=True
162    Should Be Empty  ${stderr}
163
164    Sleep  10s  reason=Wait for service to restart properly.
165
166
167Run IPMI Command Returned
168    [Documentation]  Run the IPMI command and return the output.
169    [Arguments]    ${args}
170    ${output_1}=    Execute Command   /tmp/ipmitool -I dbus raw ${args}
171    [Return]    ${output_1}
172
173
174Check IPMI OEMpartialadd Reject
175    [Documentation]  Check if IPMI rejects the OEM partial add command.
176    [Arguments]    ${args}
177    Login To OS Host  ${OS_HOST}  ${OS_USERNAME}  ${OS_PASSWORD}
178    ${stdout}  ${stderr}  ${output_2}=  Execute Command  ipmitool raw ${args}
179    ...        return_stdout=True  return_stderr=True  return_rc=True
180    [Return]  ${stderr}
181
182
183Test Setup Execution
184   [Documentation]  Do test case setup tasks.
185
186    Redfish.Login
187    Redfish Purge Event Log
188
189
190Suite Setup Execution
191    [Documentation]  Validates input parameters & check if HOST OS is up.
192
193    Should Not Be Empty
194    ...   ${OS_HOST}  msg=You must provide DNS name/IP of the OS host.
195    Should Not Be Empty
196    ...   ${OS_USERNAME}  msg=You must provide OS host user name.
197    Should Not Be Empty
198    ...   ${OS_PASSWORD}  msg=You must provide OS host user password.
199
200    # Boot to OS.
201    Redfish Power On
202
203    Redfish.Login
204    Redfish Purge Event Log
205
206    Login To OS Host  ${OS_HOST}  ${OS_USERNAME}  ${OS_PASSWORD}
207    Open Connection And Log In
208
209
210Check IPMI OEMpartialadd Accept
211    [Documentation]  Check if IPMI accepts the OEM partial add command.
212    [Arguments]    ${args}
213    Login To OS Host  ${OS_HOST}  ${OS_USERNAME}  ${OS_PASSWORD}
214    ${stdout}  ${stderr}  ${output_3}=  Execute Command  ipmitool raw ${args}
215    ...         return_stdout=True  return_stderr=True  return_rc=True
216    Should Be Equal  ${output_3}  ${0}  msg=${stderr}
217    [Return]  ${stderr}
218
219
220Event Log Should Exist
221    [Documentation]  Event log entries should exist.
222
223    ${elogs}=  Get Event Logs
224    Should Not Be Empty  ${elogs}  msg=System event log entry is not empty.
225