1*** Settings ***
2Documentation     Update the PNOR code on a target BMC.
3...               Execution Method:
4...               python -m robot -v OPENBMC_HOST:<hostname>
5...               -v DELETE_OLD_PNOR_IMAGES:<"true" or "false">
6...               -v IMAGE_FILE_PATH:<path/*.tar>
7...               -v ALTERNATE_IMAGE_FILE_PATH:<path/*.tar>
8...               host_code_update.robot
9...
10...               Code update method BMC
11...               Update work flow sequence:
12...                 - Upload image via REST
13...                 - Verify that the file exists on the BMC
14...                 - Check that software "Activation" is set to "Ready"
15...                 - Set "Requested Activation" to "Active"
16...                 - Wait for code update to complete
17...                 - Verify the new version
18
19Library           ../../lib/bmc_ssh_utils.py
20Library           ../../lib/code_update_utils.py
21Library           ../../lib/gen_robot_keyword.py
22Variables         ../../data/variables.py
23Resource          ../../lib/boot_utils.robot
24Resource          code_update_utils.robot
25Resource          ../../lib/code_update_utils.robot
26Resource          ../../lib/openbmc_ffdc.robot
27Resource          ../../lib/state_manager.robot
28Resource          ../../lib/dump_utils.robot
29
30Test Teardown     Code Update Test Teardown
31
32Force Tags        Host_Code_Update
33
34*** Variables ***
35
36${QUIET}                         ${1}
37${IMAGE_FILE_PATH}               ${EMPTY}
38${DELETE_OLD_PNOR_IMAGES}        false
39${DELETE_OLD_GUARD_FILE}         false
40${ALTERNATE_IMAGE_FILE_PATH}     ${EMPTY}
41${SKIP_UPDATE_IF_ACTIVE}         false
42${cache_files_dir_path}          /var/lib/phosphor-software-manager/pnor/prsv/
43
44*** Test Cases ***
45
46REST Host Code Update
47    [Documentation]  Do a PNOR code update by uploading image on BMC via REST.
48    # 1. Delete error logs if there is any.
49    # 1. Do code update.
50    # 2. Do post update the following:
51    #    - Collect FFDC if error log exist and delete error logs.
52    [Tags]  REST_Host_Code_Update
53    [Setup]  Code Update Setup
54
55    Run Keyword And Ignore Error  List Installed Images  Host
56
57    Upload And Activate Image  ${IMAGE_FILE_PATH}
58    ...  skip_if_active=${SKIP_UPDATE_IF_ACTIVE}
59    OBMC Reboot (off)
60
61
62Post Update Boot To OS
63    [Documentation]  Boot the host OS
64    [Tags]  Post_Update_Boot_To_OS
65    [Setup]  Start SOL Console Logging
66    [Teardown]  Run Keywords  Stop SOL Console Logging
67    ...         AND  Code Update Test Teardown
68
69    Run Keyword If  '${PREV_TEST_STATUS}' == 'FAIL'
70    ...  Fail  Code update failed. No need to boot to OS.
71    Delete All Error Logs
72    REST Power On
73    Verify Running Host Image  ${IMAGE_FILE_PATH}
74
75
76Test Boot With No VPD Cache
77    [Documentation]  After having done a PNOR update and
78    ...  booted the OS in the tests above, remove the cached
79    ...  VPD files and verify that the OS can still boot.
80    [Tags]  Test_Boot_With_No_VPD_Cache
81    [Setup]  Start SOL Console Logging
82    [Teardown]  Run Keywords  Stop SOL Console Logging
83    ...         AND  Code Update Test Teardown
84
85    ${num_vpd_files}  ${stderr}  ${rc}=  BMC Execute Command
86    ...  ls ${cache_files_dir_path} | grep VPD -c
87    # Typically, vpd files = "CVPD DJVPD MVPD NVRAM".
88    Should Be Equal As Integers  ${num_vpd_files}  ${3}
89    ...  msg=Missing VPD files at ${cache_files_dir_path}.
90
91    # Delete the *VPD* files.
92    BMC Execute Command  rm -f ${xxx_dir_path}*VPD*
93
94    REST Power On
95
96    # After powering-on the system, the VPD files should be present.
97    ${num_vpd_files}  ${stderr}  ${rc}=  BMC Execute Command
98    ...  ls ${cache_files_dir_path} | grep VPD -c
99    Should Be Equal As Integers  ${num_vpd_files}  ${3}
100    ...  msg=Three VPD files expected at ${cache_files_dir_path}.
101
102    # Power off.  The next test case will boot the OS with the new VPD files.
103    REST Power Off
104
105
106REST Host Code Update While OS Is Running
107    [Documentation]  Do a PNOR code update while the host is running.
108    [Tags]  REST_Host_Code_Update_While_OS_Is_Running
109    [Teardown]  Run Keywords  REST Power Off  stack_mode=skip
110    ...         AND  Code Update Test Teardown
111
112    Run Keyword If  '${PREV_TEST_STATUS}' == 'FAIL'
113    ...  Fail  Cannot boot the OS.
114
115    REST Power On  stack_mode=skip
116    Upload And Activate Image
117    ...  ${ALTERNATE_IMAGE_FILE_PATH}  skip_if_active=true
118    REST Power On  stack_mode=normal
119    Verify Running Host Image  ${ALTERNATE_IMAGE_FILE_PATH}
120
121Host Image Priority Attribute Test
122    [Documentation]  Set "Priority" attribute.
123    [Tags]  Host_Image_Priority_Attribute_Test
124    [Template]  Temporarily Set PNOR Attribute
125
126    # Property        Value
127    Priority          ${0}
128    Priority          ${1}
129    Priority          ${127}
130    Priority          ${255}
131
132
133Host Set Priority To Invalid Values
134    [Documentation]  Attempt to set the priority of an image to an invalid
135    ...              value and expect an error.
136    [Tags]  Host_Set_Priority_To_Invalid_Values
137    [Template]  Set Priority To Invalid Value And Expect Error
138
139    # Version Type              Priority
140    ${VERSION_PURPOSE_HOST}    ${-1}
141    ${VERSION_PURPOSE_HOST}    ${256}
142
143
144Set RequestedActivation To None
145    [Documentation]  Set the RequestedActivation of the image to None and
146    ...              verify that it is in fact set to None.
147    [Tags]  Set_RequestedActivation_To_None
148
149    ${software_objects}=  Get Software Objects
150    Set Host Software Property  @{software_objects}[0]  RequestedActivation
151    ...  ${REQUESTED_NONE}
152    ${software_properties}=  Get Host Software Property  @{software_objects}[0]
153    Should Be Equal As Strings  &{software_properties}[RequestedActivation]
154    ...  ${REQUESTED_NONE}
155
156
157Set RequestedActivation And Activation To Invalid Value
158    [Documentation]  Set the RequestedActivation and Activation propreties of
159    ...              the image to an invalid value and verify that it was not
160    ...              changed.
161    [Template]  Set Property To Invalid Value And Verify No Change
162    [Tags]  Set_RequestedActivation_And_Activation_To_Invalid_Value
163
164    # Property              Version Type
165    RequestedActivation     ${VERSION_PURPOSE_HOST}
166    Activation              ${VERSION_PURPOSE_HOST}
167
168
169Upload And Activate Multiple Host Images
170    [Documentation]  Upload another PNOR image and verify that its state is
171    ...              different from all others.
172    [Tags]  Upload_And_Activate_Multiple_Host_Images
173    [Template]  Activate Image And Verify No Duplicate Priorities
174    [Setup]  Upload And Activate Multiple BMC Images Setup
175
176    # Image File Path              Image Purpose
177    ${ALTERNATE_IMAGE_FILE_PATH}   ${VERSION_PURPOSE_HOST}
178
179
180Set Same Priority For Multiple Host Images
181    [Documentation]  Attempt to set the priority to be the same for two PNOR
182    ...              images and verify that the priorities are not the same.
183    [Tags]  Set_Same_Priority_For_Multiple_Host_Images
184
185    Run Keyword If  '${PREV_TEST_STATUS}' == 'FAIL'
186    ...  Fail  Activation of alternate image failed. Cannot set priority.
187    Set Same Priority For Multiple Images  ${VERSION_PURPOSE_HOST}
188
189
190Delete Host Image
191    [Documentation]  Delete a PNOR image from the BMC and PNOR flash chip.
192    [Tags]  Delete_Host_Image
193    [Setup]  Initiate Host PowerOff
194
195    ${software_objects}=  Get Software Objects
196    ...  version_type=${VERSION_PURPOSE_HOST}
197    ${num_images}=  Get Length  ${software_objects}
198    Should Be True  0 < ${num_images}
199    ...  msg=There are no PNOR images on the BMC to delete.
200    Delete Image And Verify  @{software_objects}[0]  ${VERSION_PURPOSE_HOST}
201
202
203Verify Host Update When Host Reboot During Activation In Progress
204    [Documentation]  Attempt to reboot the host while an image is activating.
205    [Tags]  Verify_Host_Update_When_Host_Reboot_During_Activation_In_Progress
206
207    Upload And Activate Image  ${IMAGE_FILE_PATH}
208    REST Power On
209    Delete All Error Logs
210
211    ${version_id}=  Upload And Activate Image  ${ALTERNATE_IMAGE_FILE_PATH}
212    ...  wait=${0}
213
214    ${resp}=  OpenBMC Get Request  ${SOFTWARE_VERSION_URI}${version_id}
215    Should Be Equal As Strings  ${resp.status_code}  ${HTTP_OK}
216
217    # Reboot Host during activation.
218    Host Reboot
219
220    Wait For Activation State Change  ${version_id}  ${ACTIVATING}
221
222    # New image priority should be 0.
223    ${new_host_properties}=
224    ...  Get Host Software Property  ${SOFTWARE_VERSION_URI}${version_id}
225    Should Be Equal As Integers  ${new_host_properties["Priority"]}  ${0}
226
227    # Reboot host to boot up with the new host image version.
228    Host Reboot
229    Verify Running Host Image  ${ALTERNATE_IMAGE_FILE_PATH}
230
231
232*** Keywords ***
233
234Temporarily Set PNOR Attribute
235    [Documentation]  Update the PNOR attribute value.
236    [Arguments]  ${attribute_name}  ${attribute_value}
237
238    # Description of argument(s):
239    # attribute_name    Host software attribute name (e.g. "Priority").
240    # attribute_value   Value to be written.
241
242    ${image_ids}=  Get Software Objects
243    ${init_host_properties}=  Get Host Software Property  ${image_ids[0]}
244    ${initial_priority}=  Set Variable  ${init_host_properties["Priority"]}
245
246    Set Host Software Property  ${image_ids[0]}  ${attribute_name}
247    ...  ${attribute_value}
248
249    ${cur_host_properties}=  Get Host Software Property  ${image_ids[0]}
250    Should Be Equal As Integers  ${cur_host_properties["Priority"]}
251    ...  ${attribute_value}
252
253    # Revert to to initial value.
254    Set Host Software Property
255    ...  ${image_ids[0]}  ${attribute_name}  ${initial_priority}
256
257
258Code Update Setup
259    [Documentation]  Do code update test case setup.
260    # - Clean up all existing BMC dumps.
261    # - Clean up all currently install PNOR images.
262
263    Run Keyword And Ignore Error  Smart Power Off
264    Run Key  Delete All Dumps  ignore=1
265    Run Key  Delete All Error Logs  ignore=1
266    Run Keyword If  'true' == '${DELETE_OLD_PNOR_IMAGES}'
267    ...  Delete All PNOR Images
268    Run Keyword If  'true' == '${DELETE_OLD_GUARD_FILE}'  BMC Execute Command
269    ...  rm -f /var/lib/phosphor-software-manager/pnor/prsv/GUARD
270
271    BMC Execute Command  rm -rf /tmp/images/*
272    BMC Execute Command  systemctl restart xyz.openbmc_project.Software.BMC.Updater.service xyz.openbmc_project.Software.Version.service xyz.openbmc_project.Software.Download.service
273
274Upload And Activate Multiple BMC Images Setup
275    [Documentation]  Check that the ALTERNATE_FILE_PATH variable is set.
276
277    Should Not Be Empty  ${ALTERNATE_IMAGE_FILE_PATH}
278    Delete All PNOR Images
279    Upload And Activate Image  ${IMAGE_FILE_PATH}  skip_if_active=true
280
281Get PNOR Extended Version
282    [Documentation]  Return the PNOR extended version.
283    [Arguments]  ${manifest_path}
284
285    # Description of argument(s):
286    # manifest_path  Path of the MANIFEST file
287    #                (e.g. "/tmp/images/abc123/MANIFEST").
288
289    ${version}= BMC Execute Command
290    ...  grep extended_version= ${manifest_path}
291    [return] ${version.split(",")}
292
293
294Code Update Test Teardown
295    [Documentation]  Do code update test case teardown.
296    # 1. Collect FFDC if test case failed.
297    # 2. Collect FFDC if test PASS but error log exists.
298
299    FFDC On Test Case Fail
300    Run Keyword If  '${TEST_STATUS}' == 'PASS'  Check Error And Collect FFDC
301