| *** Settings *** |
| Documentation Code update utility |
| |
| Resource ../../lib/rest_client.robot |
| Resource ../../lib/connection_client.robot |
| Resource ../../lib/utils.robot |
| Library OperatingSystem |
| |
| *** Variables *** |
| |
| # Fix old org path locally for non-witherspoon system. |
| ${ORG_OPENBMC_BASE_URI} /org/openbmc/ |
| ${ORG_CONTROL_FLASH} ${ORG_OPENBMC_BASE_URI}control/flash/ |
| ${BMC_UPD_METHOD} ${ORG_CONTROL_FLASH}bmc/action/update |
| ${BMC_PREP_METHOD} ${ORG_CONTROL_FLASH}bmc/action/PrepareForUpdate |
| ${BMC_UPD_ATTR} ${ORG_CONTROL_FLASH}bmc |
| ${HOST_SETTING} ${ORG_OPENBMC_BASE_URI}settings/host0 |
| |
| *** Keywords *** |
| |
| Preserve BMC Network Setting |
| [Documentation] Preserve Network setting |
| |
| ${policy}= Set Variable ${1} |
| ${value}= Create Dictionary data=${policy} |
| Write Attribute ${BMC_UPD_ATTR} preserve_network_settings data=${value} |
| ${data}= Read Properties ${BMC_UPD_ATTR} |
| Should Be Equal As Strings |
| ... ${data['preserve_network_settings']} ${True} |
| ... msg=False indicates network is not preserved. |
| |
| |
| Activate BMC Flash Image |
| [Documentation] Activate and verify the update status. |
| ... The status could be either one of these: |
| ... 'Deferred for mounted filesystem. reboot BMC to apply.' |
| ... 'Image ready to apply.' |
| |
| @{img_path}= Create List /tmp/flashimg |
| ${data}= Create Dictionary data=@{img_path} |
| ${resp}= OpenBMC Post Request ${BMC_UPD_METHOD} data=${data} |
| ... timeout=${30} |
| Should Be Equal As Strings ${resp.status_code} ${HTTP_OK} |
| |
| ${data}= Read Properties ${BMC_UPD_ATTR} |
| Should Be Equal As Strings ${data["filename"]} /tmp/flashimg |
| Should Contain ${data['status']} to apply |
| |
| |
| Prepare For Update |
| [Documentation] Switch to update mode in progress. This method calls |
| ... the Abort method to remove the pending update if there |
| ... is any before code activation. |
| |
| ${data}= Create Dictionary data=@{EMPTY} |
| ${resp}= Openbmc Post Request ${BMC_PREP_METHOD} data=${data} |
| |
| # Update method will reset the BMC, adding delay for reboot to |
| # come into force. |
| Sleep 10s |
| |
| |
| SCP Tar Image File to BMC |
| [Documentation] Copy BMC tar image to BMC. |
| [Arguments] ${image_file_path} |
| |
| # Description of argument(s): |
| # image_file_path Downloaded BMC tar file image path. |
| |
| Open Connection for SCP |
| Open Connection And Log In |
| Loop SCP Retry ${image_file_path} |
| |
| |
| Loop SCP Retry |
| [Documentation] Try transferring the file 4 times. |
| [Arguments] ${image_file_path} |
| |
| # Description of argument(s): |
| # image_file_path Downloaded BMC tar file image path. |
| |
| : FOR ${index} IN RANGE 0 4 |
| \ ${status}= Retry SCP ${image_file_path} |
| \ Exit For Loop If '${status}' == '${True}' |
| |
| |
| Retry SCP |
| [Documentation] Delete the incomplete file and scp file. |
| [Arguments] ${image_file_path} |
| |
| # Description of argument(s): |
| # image_file_path Downloaded BMC tar file image path. |
| |
| ${targ_file_path}= Set Variable /tmp/flashimg |
| |
| # Example output: |
| # root@witherspoon:~# ls -lh /tmp/flashimg |
| # -rwxr-xr-x 1 root root 32.0M Jun 29 01:12 /tmp/flashimg |
| BMC Execute Command rm -f /tmp/flashimg |
| scp.Put File ${image_file_path} ${targ_file_path} |
| |
| ${file_size} ${stderr} ${rc}= BMC Execute Command |
| ... ls -lh ${targ_file_path} |
| ${status}= Run Keyword And Return Status |
| ... Should Contain ${file_size} 32.0M msg=Incomplete file transfer. |
| [return] ${status} |
| |
| |
| Check If File Exist |
| [Documentation] Verify that the file exists on this machine. |
| [Arguments] ${filepath} |
| |
| # Description of argument(s): |
| # filepath The path of the file whose existence is to be checked. |
| |
| Log \n PATH: ${filepath} |
| OperatingSystem.File Should Exist ${filepath} |
| ... msg=${filepath} doesn't exist [ ERROR ] |
| |
| Set Global Variable ${FILE_PATH} ${filepath} |
| |
| |
| System Readiness Test |
| [Documentation] Verify ping and REST authenticatec for the target |
| ... system. |
| |
| ${l_status}= Run Keyword and Return Status |
| ... Verify Ping and REST Authentication |
| Run Keyword If '${l_status}' == '${False}' |
| ... Fail msg=System not in ideal state to use [ERROR] |
| |
| |
| Validate BMC Version |
| [Documentation] Get BMC version from /etc/os-release and compare. |
| [Arguments] ${version} |
| |
| # Description of argument(s): |
| # version Software version (e.g. "v1.99.8-41-g86a4abc"). |
| |
| Open Connection And Log In |
| ${cmd}= Set Variable grep ^VERSION_ID= /etc/os-release | cut -f 2 -d '=' |
| ${output} ${stderr} ${rc}= BMC Execute Command ${cmd} |
| Should Be Equal As Strings ${version} ${output[1:-1]} |
| |
| |
| Trigger Warm Reset via Reboot |
| [Documentation] Execute reboot command on the remote BMC and |
| ... returns immediately. This keyword "Start Command" |
| ... returns nothing and does not wait for the command |
| ... execution to be finished. |
| |
| Open Connection And Log In |
| |
| Start Command /sbin/reboot |
| |
| |
| Set Policy Setting |
| [Documentation] Set the given test policy |
| [Arguments] ${policy} |
| |
| # Description of argument(s): |
| # policy Policy value to set (e.g. ${RESTORE_LAST_STATE}, |
| # ${ALWAYS_POWER_ON}, or ${ALWAYS_POWER_OFF}). |
| |
| ${valueDict}= Create Dictionary data=${policy} |
| Write Attribute ${HOST_SETTING} power_policy data=${valueDict} |
| ${currentPolicy}= Read Attribute ${HOST_SETTING} power_policy |
| Should Be Equal ${currentPolicy} ${policy} |