19f74d3afSCharles Paul Hofer*** Settings *** 29f74d3afSCharles Paul HoferDocumentation Update the PNOR code on a target BMC. 39f74d3afSCharles Paul Hofer... Execution Method: 49f74d3afSCharles Paul Hofer... python -m robot -v OPENBMC_HOST:<hostname> 59f74d3afSCharles Paul Hofer... -v DELETE_OLD_PNOR_IMAGES:<"true" or "false"> 6a5673166SCharles Paul Hofer... -v IMAGE_FILE_PATH:<path/*.tar> 7a5673166SCharles Paul Hofer... -v ALTERNATE_IMAGE_FILE_PATH:<path/*.tar> 8a5673166SCharles Paul Hofer... host_code_update.robot 99f74d3afSCharles Paul Hofer... 109f74d3afSCharles Paul Hofer... Code update method BMC 119f74d3afSCharles Paul Hofer... Update work flow sequence: 129f74d3afSCharles Paul Hofer... - Upload image via REST 139f74d3afSCharles Paul Hofer... - Verify that the file exists on the BMC 149f74d3afSCharles Paul Hofer... - Check that software "Activation" is set to "Ready" 159f74d3afSCharles Paul Hofer... - Set "Requested Activation" to "Active" 169f74d3afSCharles Paul Hofer... - Wait for code update to complete 179f74d3afSCharles Paul Hofer... - Verify the new version 189f74d3afSCharles Paul Hofer 199f74d3afSCharles Paul HoferLibrary ../../lib/bmc_ssh_utils.py 209f74d3afSCharles Paul HoferLibrary ../../lib/code_update_utils.py 219f74d3afSCharles Paul HoferVariables ../../data/variables.py 229f74d3afSCharles Paul HoferResource ../../lib/boot_utils.robot 239f74d3afSCharles Paul HoferResource code_update_utils.robot 249f74d3afSCharles Paul HoferResource ../../lib/code_update_utils.robot 251eb85f57SGeorge KeishingResource ../../lib/openbmc_ffdc.robot 269f74d3afSCharles Paul HoferResource ../../lib/state_manager.robot 271eb85f57SGeorge KeishingResource ../../lib/dump_utils.robot 289f74d3afSCharles Paul Hofer 290071549eSGeorge KeishingTest Teardown Code Update Test Teardown 309f74d3afSCharles Paul Hofer 319f74d3afSCharles Paul Hofer*** Variables *** 329f74d3afSCharles Paul Hofer 339f74d3afSCharles Paul Hofer${QUIET} ${1} 349f74d3afSCharles Paul Hofer${IMAGE_FILE_PATH} ${EMPTY} 359f74d3afSCharles Paul Hofer${DELETE_OLD_PNOR_IMAGES} false 3651b54c08SCharles Paul Hofer${DELETE_OLD_GUARD_FILE} false 37c1fa2bc9SCharles Paul Hofer${ALTERNATE_IMAGE_FILE_PATH} ${EMPTY} 389f74d3afSCharles Paul Hofer 399f74d3afSCharles Paul Hofer*** Test Cases *** 409f74d3afSCharles Paul Hofer 419f74d3afSCharles Paul HoferREST Host Code Update 429f74d3afSCharles Paul Hofer [Documentation] Do a PNOR code update by uploading image on BMC via REST. 430071549eSGeorge Keishing # 1. Delete error logs if there is any. 440071549eSGeorge Keishing # 1. Do code update. 450071549eSGeorge Keishing # 2. Do post update the following: 460071549eSGeorge Keishing # - Collect FFDC if error log exist and delete error logs. 479f74d3afSCharles Paul Hofer [Tags] REST_Host_Code_Update 489f74d3afSCharles Paul Hofer [Setup] Code Update Setup 499f74d3afSCharles Paul Hofer 509f74d3afSCharles Paul Hofer Upload And Activate Image ${IMAGE_FILE_PATH} 519f74d3afSCharles Paul Hofer OBMC Reboot (off) 529f74d3afSCharles Paul Hofer 539f74d3afSCharles Paul Hofer 549f74d3afSCharles Paul HoferPost Update Boot To OS 559f74d3afSCharles Paul Hofer [Documentation] Boot the host OS 569f74d3afSCharles Paul Hofer [Tags] Post_Update_Boot_To_OS 57*da6bace8SGeorge Keishing [Teardown] Run Keywords Stop SOL Console Logging 58*da6bace8SGeorge Keishing ... AND Code Update Test Teardown 599f74d3afSCharles Paul Hofer 609f74d3afSCharles Paul Hofer Run Keyword If '${PREV_TEST_STATUS}' == 'FAIL' 619f74d3afSCharles Paul Hofer ... Fail Code update failed. No need to boot to OS. 629f74d3afSCharles Paul Hofer Start SOL Console Logging 630071549eSGeorge Keishing Delete Error Logs 649f74d3afSCharles Paul Hofer REST Power On 659f74d3afSCharles Paul Hofer 669f74d3afSCharles Paul Hofer 679f74d3afSCharles Paul HoferHost Image Priority Attribute Test 689f74d3afSCharles Paul Hofer [Documentation] Set "Priority" attribute. 699f74d3afSCharles Paul Hofer [Tags] Host_Image_Priority_Attribute_Test 709f74d3afSCharles Paul Hofer [Template] Temporarily Set PNOR Attribute 719f74d3afSCharles Paul Hofer 729f74d3afSCharles Paul Hofer # Property Value 739f74d3afSCharles Paul Hofer Priority ${0} 749f74d3afSCharles Paul Hofer Priority ${1} 759f74d3afSCharles Paul Hofer Priority ${127} 769f74d3afSCharles Paul Hofer 779f74d3afSCharles Paul Hofer 789f74d3afSCharles Paul HoferSet RequestedActivation To None 799f74d3afSCharles Paul Hofer [Documentation] Set the RequestedActivation of the image to None and 809f74d3afSCharles Paul Hofer ... verify that it is in fact set to None. 819f74d3afSCharles Paul Hofer [Tags] Set_RequestedActivation_To_None 829f74d3afSCharles Paul Hofer 839f74d3afSCharles Paul Hofer ${software_objects}= Get Software Objects 849f74d3afSCharles Paul Hofer Set Host Software Property @{software_objects}[0] RequestedActivation 859f74d3afSCharles Paul Hofer ... ${REQUESTED_NONE} 869f74d3afSCharles Paul Hofer ${software_properties}= Get Host Software Property @{software_objects}[0] 879f74d3afSCharles Paul Hofer Should Be Equal As Strings &{software_properties}[RequestedActivation] 889f74d3afSCharles Paul Hofer ... ${REQUESTED_NONE} 899f74d3afSCharles Paul Hofer 909f74d3afSCharles Paul Hofer 919f74d3afSCharles Paul HoferSet RequestedActivation And Activation To Invalid Value 929f74d3afSCharles Paul Hofer [Documentation] Set the RequestedActivation and Activation propreties of 939f74d3afSCharles Paul Hofer ... the image to an invalid value and verify that it was not 949f74d3afSCharles Paul Hofer ... changed. 959f74d3afSCharles Paul Hofer [Template] Set Property To Invalid Value And Verify No Change 969f74d3afSCharles Paul Hofer [Tags] Set_RequestedActivation_And_Activation_To_Invalid_Value 979f74d3afSCharles Paul Hofer 989f74d3afSCharles Paul Hofer # Property Version Type 999f74d3afSCharles Paul Hofer RequestedActivation ${VERSION_PURPOSE_HOST} 1009f74d3afSCharles Paul Hofer Activation ${VERSION_PURPOSE_HOST} 1019f74d3afSCharles Paul Hofer 1029f74d3afSCharles Paul Hofer 103c1fa2bc9SCharles Paul HoferUpload And Activate Multiple Host Images 104c1fa2bc9SCharles Paul Hofer [Documentation] Upload another PNOR image and verify that its state is 105c1fa2bc9SCharles Paul Hofer ... different from all others. 106c1fa2bc9SCharles Paul Hofer [Tags] Upload_And_Activate_Multiple_Host_Images 107c1fa2bc9SCharles Paul Hofer [Template] Activate Image And Verify No Duplicate Priorities 108c1fa2bc9SCharles Paul Hofer [Setup] Upload And Activate Multiple BMC Images Setup 109c1fa2bc9SCharles Paul Hofer 110c1fa2bc9SCharles Paul Hofer # Image File Path Image Purpose 111c1fa2bc9SCharles Paul Hofer ${ALTERNATE_IMAGE_FILE_PATH} ${VERSION_PURPOSE_HOST} 112c1fa2bc9SCharles Paul Hofer 113c1fa2bc9SCharles Paul Hofer 114a5673166SCharles Paul HoferSet Same Priority For Multiple Host Images 115a5673166SCharles Paul Hofer [Documentation] Attempt to set the priority to be the same for two PNOR 116a5673166SCharles Paul Hofer ... images and verify that the priorities are not the same. 117a5673166SCharles Paul Hofer [Tags] Set_Same_Priority_For_Multiple_Host_Images 118a5673166SCharles Paul Hofer 119a5673166SCharles Paul Hofer Run Keyword If '${PREV_TEST_STATUS}' == 'FAIL' 120a5673166SCharles Paul Hofer ... Fail Activation of alternate image failed. Cannot set priority. 121a5673166SCharles Paul Hofer Set Same Priority For Multiple Images ${VERSION_PURPOSE_HOST} 122a5673166SCharles Paul Hofer 123a5673166SCharles Paul Hofer 1249f74d3afSCharles Paul HoferDelete Host Image 1259f74d3afSCharles Paul Hofer [Documentation] Delete a PNOR image from the BMC and PNOR flash chip. 1269f74d3afSCharles Paul Hofer [Tags] Delete_Host_Image 1279f74d3afSCharles Paul Hofer [Setup] Initiate Host PowerOff 1289f74d3afSCharles Paul Hofer 1299f74d3afSCharles Paul Hofer ${software_objects}= Get Software Objects 1309f74d3afSCharles Paul Hofer ... version_type=${VERSION_PURPOSE_HOST} 1319f74d3afSCharles Paul Hofer ${num_images}= Get Length ${software_objects} 1329f74d3afSCharles Paul Hofer Should Be True 0 < ${num_images} 1339f74d3afSCharles Paul Hofer ... msg=There are no PNOR images on the BMC to delete. 1349f74d3afSCharles Paul Hofer Delete Image And Verify @{software_objects}[0] ${VERSION_PURPOSE_HOST} 1359f74d3afSCharles Paul Hofer 1369f74d3afSCharles Paul Hofer 1379f74d3afSCharles Paul Hofer*** Keywords *** 1389f74d3afSCharles Paul Hofer 1399f74d3afSCharles Paul HoferTemporarily Set PNOR Attribute 1409f74d3afSCharles Paul Hofer [Documentation] Update the PNOR attribute value. 1419f74d3afSCharles Paul Hofer [Arguments] ${attribute_name} ${attribute_value} 1429f74d3afSCharles Paul Hofer 1439f74d3afSCharles Paul Hofer # Description of argument(s): 1449f74d3afSCharles Paul Hofer # attribute_name Host software attribute name (e.g. "Priority"). 1459f74d3afSCharles Paul Hofer # attribute_value Value to be written. 1469f74d3afSCharles Paul Hofer 1479f74d3afSCharles Paul Hofer ${image_ids}= Get Software Objects 1489f74d3afSCharles Paul Hofer ${init_host_properties}= Get Host Software Property ${image_ids[0]} 1499f74d3afSCharles Paul Hofer ${initial_priority}= Set Variable ${init_host_properties["Priority"]} 1509f74d3afSCharles Paul Hofer 1519f74d3afSCharles Paul Hofer Set Host Software Property ${image_ids[0]} ${attribute_name} 1529f74d3afSCharles Paul Hofer ... ${attribute_value} 1539f74d3afSCharles Paul Hofer 1549f74d3afSCharles Paul Hofer ${cur_host_properties}= Get Host Software Property ${image_ids[0]} 1559f74d3afSCharles Paul Hofer Should Be Equal As Integers ${cur_host_properties["Priority"]} 1569f74d3afSCharles Paul Hofer ... ${attribute_value} 1579f74d3afSCharles Paul Hofer 1589f74d3afSCharles Paul Hofer # Revert to to initial value. 1599f74d3afSCharles Paul Hofer Set Host Software Property 1609f74d3afSCharles Paul Hofer ... ${image_ids[0]} ${attribute_name} ${initial_priority} 1619f74d3afSCharles Paul Hofer 1629f74d3afSCharles Paul Hofer 1639f74d3afSCharles Paul HoferCode Update Setup 1649f74d3afSCharles Paul Hofer [Documentation] Do code update test case setup. 1651eb85f57SGeorge Keishing # - Clean up all existing BMC dumps. 1661eb85f57SGeorge Keishing # - Clean up all currently install PNOR images. 1679f74d3afSCharles Paul Hofer 16851b54c08SCharles Paul Hofer Initiate Host PowerOff 1691eb85f57SGeorge Keishing Delete All Dumps 1700071549eSGeorge Keishing Delete Error Logs 1719f74d3afSCharles Paul Hofer Run Keyword If 'true' == '${DELETE_OLD_PNOR_IMAGES}' 1729f74d3afSCharles Paul Hofer ... Delete All PNOR Images 17351b54c08SCharles Paul Hofer Run Keyword If 'true' == '${DELETE_OLD_GUARD_FILE}' BMC Execute Command 17451b54c08SCharles Paul Hofer ... rm -f /var/lib/phosphor-software-manager/pnor/prsv/GUARD 1759f74d3afSCharles Paul Hofer 1769f74d3afSCharles Paul Hofer 177c1fa2bc9SCharles Paul HoferUpload And Activate Multiple BMC Images Setup 178c1fa2bc9SCharles Paul Hofer [Documentation] Check that the ALTERNATE_FILE_PATH variable is set. 179c1fa2bc9SCharles Paul Hofer 180c1fa2bc9SCharles Paul Hofer Should Not Be Empty ${ALTERNATE_IMAGE_FILE_PATH} 181c1fa2bc9SCharles Paul Hofer 182c1fa2bc9SCharles Paul Hofer 1839f74d3afSCharles Paul HoferGet PNOR Extended Version 1849f74d3afSCharles Paul Hofer [Documentation] Return the PNOR extended version. 1859f74d3afSCharles Paul Hofer [Arguments] ${manifest_path} 1869f74d3afSCharles Paul Hofer 1879f74d3afSCharles Paul Hofer # Description of argument(s): 1889f74d3afSCharles Paul Hofer # manifest_path Path of the MANIFEST file 1899f74d3afSCharles Paul Hofer # (e.g. "/tmp/images/abc123/MANIFEST"). 1909f74d3afSCharles Paul Hofer 1919f74d3afSCharles Paul Hofer ${version}= BMC Execute Command 1929f74d3afSCharles Paul Hofer ... grep extended_version= ${manifest_path} 1939f74d3afSCharles Paul Hofer [return] ${version.split(",")} 1940071549eSGeorge Keishing 1950071549eSGeorge Keishing 1960071549eSGeorge KeishingCode Update Test Teardown 1970071549eSGeorge Keishing [Documentation] Do code update test case teardown. 1980071549eSGeorge Keishing # 1. Collect FFDC if test case failed. 1990071549eSGeorge Keishing # 2. Collect FFDC if test PASS but error log exists. 2000071549eSGeorge Keishing 2010071549eSGeorge Keishing FFDC On Test Case Fail 2020071549eSGeorge Keishing Run Keyword If '${TEST_STATUS}' == 'PASS' Check Error And Collect FFDC 203