blob: e6e18ea2d7f8ea85643160a9b7284a8a83986861 [file] [log] [blame]
George Keishing5e870cd2016-08-24 10:05:47 -05001*** Settings ***
2Documentation Trigger code update to a target BMC.
3... Execution Method :
4... python -m robot -v OPENBMC_HOST:<hostname>
5... -v FILE_PATH:<path/*all.tar> update_bmc.robot
6...
7... Code update method BMC using REST
8... Update work flow sequence:
9... - User input BMC File existence check
10... - Ping Test and REST authentication
George Keishing8db0e1b2016-10-20 13:46:54 -050011... - Set Host Power host setting Policy to RESTORE_LAST_STATE
12... On reboot this policy would ensure the BMC comes
13... online and stays at HOST_POWERED_OFF state.
George Keishingdc5aa58e92016-09-27 01:35:11 -050014... - Issue poweroff
15... - Prepare for Update
George Keishingdc5aa58e92016-09-27 01:35:11 -050016... - Wait for BMC to come online clean
George Keishing1b150202016-09-29 08:51:58 -050017... - Wait for BMC_READY state
George Keishing5e870cd2016-08-24 10:05:47 -050018... - Apply preserve BMC Network setting
19... - SCP image to BMC
20... - Activate the flash image
21... - Warm Reset BMC to activate code
22... - Wait for BMC to come online time out 30 minutes
23... - Version check post update
24
25Resource code_update_utils.robot
George Keishing8db0e1b2016-10-20 13:46:54 -050026Resource ../../lib/boot/boot_resource_master.robot
George Keishing5e870cd2016-08-24 10:05:47 -050027
28*** Variables ***
29
30${FILE_PATH} ${EMPTY}
31
Gunnar Mills7c8923f2016-12-12 21:19:52 -060032*** Test Cases ***
George Keishing5e870cd2016-08-24 10:05:47 -050033
34Initiate Code update BMC
35 [Documentation] BMC code update process initiation
36
37 Check If File Exist ${FILE_PATH}
38 System Readiness Test
George Keishing50787fc2016-09-21 03:44:26 -050039 ${status}= Run Keyword and Return Status
40 ... Validate BMC Version before
41
42 Run Keyword if '${status}' == '${False}'
43 ... Pass Execution Same Driver version installed
44
George Keishingdc5aa58e92016-09-27 01:35:11 -050045 Initiate Power Off
George Keishing8db0e1b2016-10-20 13:46:54 -050046 Set Policy Setting RESTORE_LAST_STATE
George Keishingdc5aa58e92016-09-27 01:35:11 -050047 Prepare For Update
Rahul Maheshwarid0fd8832016-10-14 03:15:51 -050048
49 # Wait time is increased temporary to 10 mins due
50 # to openbmc/openbmc#673
51 Check If BMC is Up 10 min 10 sec
George Keishing5e870cd2016-08-24 10:05:47 -050052
George Keishing8db0e1b2016-10-20 13:46:54 -050053 @{states}= Create List BMC_READY HOST_POWERED_OFF
George Keishing1b150202016-09-29 08:51:58 -050054 Wait Until Keyword Succeeds
George Keishing8db0e1b2016-10-20 13:46:54 -050055 ... 10 min 10 sec Verify BMC State ${states}
George Keishing1b150202016-09-29 08:51:58 -050056
George Keishing2582bee2016-11-17 21:41:49 -060057 # TODO: openbmc/openbmc#815
58 Sleep 1 min
59
George Keishing5e870cd2016-08-24 10:05:47 -050060 Preserve BMC Network Setting
61 SCP Tar Image File to BMC ${FILE_PATH}
62
63 Activate BMC flash image
64
George Keishingb3700812016-08-31 03:03:30 -050065 Run Keyword And Ignore Error Trigger Warm Reset
George Keishingf68c9eb2016-12-01 08:09:58 -060066 # Warm reset adds 3 seconds delay before forcing reboot
67 # To minimize race conditions, we wait for 7 seconds
68 Sleep 7s
George Keishing5e870cd2016-08-24 10:05:47 -050069 ${session_active}= Check If warmReset is Initiated
70 Run Keyword If '${session_active}' == '${True}'
71 ... Trigger Warm Reset via Reboot
72
George Keishingc4d3dc02016-09-19 03:45:55 -050073 Check If BMC is Up 30 min 10 sec
George Keishing5e870cd2016-08-24 10:05:47 -050074 Sleep 1 min
75 Validate BMC Version
Sivas SRRea85d1f2016-11-13 22:44:28 -060076 Wait Until Keyword Succeeds
77 ... 10 min 10 sec Verify BMC State BMC_READY
78
79Test BMC CPU Mem Performance at Ready State
80 Check BMC CPU Performance
81 Check BMC Mem Performance