1*** Settings ***
2
3Documentation       Test dump functionality of OpenBMC.
4
5Resource            ../../lib/openbmc_ffdc.robot
6Resource            ../../lib/rest_client.robot
7Resource            ../../lib/dump_utils.robot
8Resource            ../../lib/boot_utils.robot
9Resource            ../../lib/utils.robot
10Resource            ../../lib/state_manager.robot
11Library             ../../lib/bmc_ssh_utils.py
12
13Suite Setup         Suite Setup Execution
14Test Setup          Open Connection And Log In
15Test Teardown       Test Teardown Execution
16
17*** Test Cases ***
18
19Verify Dump After Host Watchdog Error Injection
20    [Documentation]  Inject host watchdog error and verify whether dump is generated.
21    [Tags]  Verify_Dump_After_Host_Watchdog_Error_Injection
22
23    Redfish Power On
24
25    Run Keyword And Ignore Error  Redfish Delete All BMC Dumps
26
27    # Enable auto reboot
28    Set Auto Reboot  ${1}
29
30    Set Watchdog Interval Using Busctl  2000
31
32    Wait Until Keyword Succeeds  300 sec  20 sec  Is Host Rebooted
33
34    #Get dump details
35    @{dump_entry_list}=  Read Properties  ${DUMP_ENTRY_URI}
36
37    # Verifying that there is only one dump
38    ${length}=  Get length  ${dump_entry_list}
39    Should Be Equal As Integers  ${length}  ${1}
40
41    # Get dump id
42    ${value}=  Get From List  ${dump_entry_list}  0
43    @{split_value}=  Split String  ${value}  /
44    ${dump_id}=  Get From List  ${split_value}  -1
45
46    # Max size for dump is 200k = 200x1024
47    ${dump_size}=  Read Attribute  ${DUMP_ENTRY_URI}${dump_id}  Size
48    Should Be True  0 < ${dump_size} < 204800
49
50
51Verify Download BMC Dump
52    [Documentation]  Verify that a BMC dump can be downloaded to the local machine.
53    [Tags]  Verify_Download_BMC_Dump
54
55    ${dump_id}=  Create User Initiated BMC Dump Via Redfish
56    ${dump_dict}=  Get Dump Dict
57    ${bmc_dump_name}=  Fetch From Right  ${dump_dict['${dump_id}']}  /
58    ${bmc_dump_checksum}  ${stderr}  ${rc}=  BMC Execute Command
59    ...  md5sum ${dump_dict['${dump_id}']}|awk '{print$1}'
60    ${bmc_dump_size}  ${stderr}  ${rc}=  BMC Execute Command
61    ...  stat -c "%s" ${dump_dict['${dump_id}']}
62
63    ${response}=  OpenBMC Get Request  ${DUMP_DOWNLOAD_URI}${dump_id}
64    ...  quiet=${1}
65    Should Be Equal As Strings  ${response.status_code}  ${HTTP_OK}
66    Create Binary File  ${EXECDIR}${/}dumps   ${response.content}
67    Run  tar -xvf ${EXECDIR}${/}dumps
68    ${download_dump_name}=  Fetch From Left  ${bmc_dump_name}  .
69    ${download_dump_checksum}=  Run  md5sum ${EXECDIR}/dumps|awk '{print$1}'
70    ${download_dump_size}=  Run  stat -c "%s" ${EXECDIR}${/}dumps
71
72    OperatingSystem.Directory Should Exist  ${EXECDIR}/${download_dump_name}
73    ...  msg=Created dump name and downloaded dump name don't match.
74    Should Be Equal As Strings  ${bmc_dump_checksum}  ${download_dump_checksum}
75    Should Be Equal As Strings  ${bmc_dump_size}  ${download_dump_size}
76
77    Run  rm -rf ${EXECDIR}${/}${download_dump_name};rm ${EXECDIR}${/}dumps
78
79
80*** Keywords ***
81
82Suite Setup Execution
83    [Documentation]  Do initial suite setup tasks.
84
85    ${resp}=  OpenBMC Get Request  ${DUMP_URI}
86    Run Keyword If  '${resp.status_code}' == '${HTTP_NOT_FOUND}'
87    ...  Run Keywords  Set Suite Variable  ${DUMP_URI}  /xyz/openbmc_project/dump/  AND
88    ...  Set Suite Variable  ${DUMP_ENTRY_URI}  /xyz/openbmc_project/dump/entry/
89
90
91Test Teardown Execution
92    [Documentation]  Do the post test teardown.
93
94    Wait Until Keyword Succeeds  3 min  15 sec  Verify No Dump In Progress
95    FFDC On Test Case Fail
96    Delete All BMC Dump
97    Close All Connections
98