| Sridevi Ramesh | 87cfb9e | 2025-06-10 02:06:46 -0500 | [diff] [blame] | 1 | *** Settings *** | 
|  | 2 | Documentation   Utility file for system Vital Product Data (VPD) using vpdtool. | 
|  | 3 |  | 
|  | 4 | Library         ../../lib/vpd_utils.py | 
|  | 5 | Variables       ../../data/vpd_variables.py | 
|  | 6 | Resource        ../../lib/boot_utils.robot | 
|  | 7 |  | 
|  | 8 |  | 
|  | 9 | *** Variables *** | 
|  | 10 |  | 
|  | 11 | ${DR_WRITE_VALUE}              XYZ Component | 
|  | 12 | ${PN_WRITE_VALUE}              XYZ1234 | 
|  | 13 | ${SN_WRITE_VALUE}              ABCD12345678 | 
|  | 14 | @{fields}                      PN  SN  LocationCode | 
|  | 15 | @{vpd_fields}                  PN  SN | 
|  | 16 |  | 
|  | 17 |  | 
|  | 18 | *** Keywords *** | 
|  | 19 |  | 
|  | 20 | Verify VPD Component Read Operation | 
|  | 21 | [Documentation]  Verify reading VPD details of given component via vpdtool. | 
|  | 22 | [Arguments]  ${component} | 
|  | 23 | # Description of arguments: | 
|  | 24 | # component       VDP component (e.g. /system/chassis/motherboard/vdd_vrm1). | 
|  | 25 |  | 
|  | 26 | ${vpd_records}=  Vpdtool  -o -O ${component} | 
|  | 27 |  | 
|  | 28 | # Example output from 'Vpdtool  -o -O /system/chassis/motherboard/vdd_vrm1': | 
|  | 29 | #  [/system/chassis/motherboard/vdd_vrm1]: | 
|  | 30 | #    [DR]:                                         CPU POWER CARD | 
|  | 31 | #    [type]:                                       xyz.openbmc_project.Inventory.Item.Vrm | 
|  | 32 | #    [CC]:                                         E123 | 
|  | 33 | #    [FN]:                                         F123456 | 
|  | 34 | #    [LocationCode]:                               ABCD.XY1.1234567-P0 | 
|  | 35 | #    [SN]:                                         YL2E32010000 | 
|  | 36 | #    [PN]:                                         PN12345 | 
|  | 37 |  | 
|  | 38 | ${vpdtool_res}=  Set To Dictionary  ${vpd_records}[${component}] | 
|  | 39 | FOR  ${vpd_field}  IN  @{fields} | 
|  | 40 | ${match_key_exists}=  Run Keyword And Return Status | 
|  | 41 | ...  Dictionary Should Contain Key  ${vpdtool_res}  ${vpd_field} | 
|  | 42 | IF  '${match_key_exists}' == 'True' | 
|  | 43 | #  drive components busctl field response in ascii due to that checking only locationcode. | 
|  | 44 | IF  'drive' in '${component}' | 
|  | 45 | ${vpd_field}=  Set Variable  LocationCode | 
|  | 46 | END | 
|  | 47 | # Skip check if VPD field is empty. | 
|  | 48 | IF  '${vpd_records['${component}']['${vpd_field}']}' == ''  CONTINUE | 
|  | 49 |  | 
|  | 50 | # Get VPD field values via busctl. | 
|  | 51 | ${busctl_field}=  Set Variable If | 
|  | 52 | ...  '${vpd_field}' == 'LocationCode'  com.ibm.ipzvpd.Location LocationCode | 
|  | 53 | ...  '${vpd_field}' == 'PN'  xyz.openbmc_project.Inventory.Decorator.Asset PartNumber | 
|  | 54 | ...  '${vpd_field}' == 'SN'  xyz.openbmc_project.Inventory.Decorator.Asset SerialNumber | 
|  | 55 | ${cmd}=  Catenate  ${CMD_GET_PROPERTY_INVENTORY} | 
|  | 56 | ...  /xyz/openbmc_project/inventory${component} ${busctl_field} | 
|  | 57 | ${cmd_output}=  BMC Execute Command  ${cmd} | 
|  | 58 | # Check whether the vpdtool response and busctl response matching. | 
|  | 59 | Valid Value  vpd_records['${component}']['${vpd_field}'] | 
|  | 60 | ...  ['${cmd_output[0].split('"')[1].strip('"')}'] | 
|  | 61 | ELSE | 
|  | 62 | CONTINUE | 
|  | 63 | END | 
|  | 64 | END | 
|  | 65 |  | 
|  | 66 |  | 
|  | 67 | Verify VPD Field Read Operation | 
|  | 68 | [Documentation]  Verify reading all VPD fields for given component via vpdtool. | 
|  | 69 | [Arguments]  ${component} | 
|  | 70 | # Description of arguments: | 
|  | 71 | # component       VDP component (e.g. /system/chassis/motherboard/vdd_vrm1). | 
|  | 72 |  | 
|  | 73 | ${vpd_records}=  Vpdtool  -o -O ${component} | 
|  | 74 | ${vpdtool_res}=  Set To Dictionary  ${vpd_records}[${component}] | 
|  | 75 | FOR  ${field}  IN  @{vpd_fields} | 
|  | 76 | ${match_key_exists}=  Run Keyword And Return Status | 
|  | 77 | ...  Dictionary Should Contain Key  ${vpdtool_res}  ${field} | 
|  | 78 | IF  '${match_key_exists}' == 'True' | 
|  | 79 | ${vpd_records}=  Vpdtool  -r -O ${component} -R VINI -K ${field} | 
|  | 80 | # Skip check if field value is empty. | 
|  | 81 | IF  '${vpd_records['${component}']['${field}']}' == ''  CONTINUE | 
|  | 82 |  | 
|  | 83 | ${busctl_field}=  Set Variable If | 
|  | 84 | ...  '${field}' == 'PN'  xyz.openbmc_project.Inventory.Decorator.Asset PartNumber | 
|  | 85 | ...  '${field}' == 'SN'  xyz.openbmc_project.Inventory.Decorator.Asset SerialNumber | 
|  | 86 | ${cmd}=  Catenate  ${CMD_GET_PROPERTY_INVENTORY} | 
|  | 87 | ...  /xyz/openbmc_project/inventory${component} ${busctl_field} | 
|  | 88 | ${cmd_output}=  BMC Execute Command  ${cmd} | 
|  | 89 |  | 
|  | 90 | # Check vpdtool response and busctl response for the component field. | 
|  | 91 | Valid Value  vpd_records['${component}']['${field}'] | 
|  | 92 | ...  ['${cmd_output[0].split('"')[1].strip('"')}'] | 
|  | 93 | ELSE | 
|  | 94 | CONTINUE | 
|  | 95 | END | 
|  | 96 | END | 
|  | 97 |  | 
|  | 98 |  | 
|  | 99 | Verify VPD Field Write Operation | 
|  | 100 | [Documentation]  Verify writing VPD fields for given component via vpdtool. | 
|  | 101 | [Arguments]  ${component}  ${field} | 
|  | 102 | [Teardown]  Restore VPD Value  ${component}  ${field}  ${old_field_value} | 
|  | 103 |  | 
|  | 104 | # Description of arguments: | 
|  | 105 | # component       VPD component (e.g. /system/chassis/motherboard/vdd_vrm1). | 
|  | 106 | # field           VPD component field (e.g. PN, SN) | 
|  | 107 |  | 
|  | 108 | ${vpd_records}=  Vpdtool  -r -O ${component} -R VINI -K ${field} | 
|  | 109 | Set Test Variable  ${old_field_value}  ${vpd_records['${component}']['${field}']} | 
|  | 110 |  | 
|  | 111 | ${write_value}=  Set Variable If | 
|  | 112 | ...  '${field}' == 'DR'  ${DR_WRITE_VALUE} | 
|  | 113 | ...  '${field}' == 'PN'  ${PN_WRITE_VALUE} | 
|  | 114 | ...  '${field}' == 'SN'  ${SN_WRITE_VALUE} | 
|  | 115 |  | 
|  | 116 | Vpdtool  -w -O ${component} -R VINI -K ${field} --value ${write_value} | 
|  | 117 |  | 
|  | 118 | Verify VPD Field Value  ${component}  ${field} | 
|  | 119 |  | 
|  | 120 |  | 
|  | 121 | Restore VPD Value | 
|  | 122 | [Documentation]  Restore VPD's field value of given component. | 
|  | 123 | [Arguments]  ${component}  ${field}  ${value} | 
|  | 124 | # Description of arguments: | 
|  | 125 | # component       VPD component (e.g. /system/chassis/motherboard/vdd_vrm1). | 
|  | 126 | # field           VPD component field (e.g. PN, SN) | 
|  | 127 | # value           VPD value to be restore. | 
|  | 128 |  | 
|  | 129 | Vpdtool  -w -O ${component} -R VINI -K ${field} --value ${value} | 
|  | 130 |  | 
|  | 131 |  | 
|  | 132 | Verify VPD Field Value | 
|  | 133 | [Documentation]  Verify VPD field value via vpdtool. | 
|  | 134 | [Arguments]  ${component}  ${field} | 
|  | 135 | # Description of arguments: | 
|  | 136 | # component       VDP component (e.g. /system/chassis/motherboard/vdd_vrm1). | 
|  | 137 | # field           VPD field (e.g. DR, SN, PN) | 
|  | 138 |  | 
|  | 139 | Redfish OBMC Reboot (off)  stack_mode=normal | 
|  | 140 | ${vpd_records}=  Vpdtool  -r -O ${component} -R VINI -K ${field} | 
|  | 141 |  | 
|  | 142 | ${busctl_field}=  Set Variable If | 
|  | 143 | ...  '${field}' == 'DR'  xyz.openbmc_project.Inventory.Item PrettyName | 
|  | 144 | ...  '${field}' == 'PN'  xyz.openbmc_project.Inventory.Decorator.Asset PartNumber | 
|  | 145 | ...  '${field}' == 'SN'  xyz.openbmc_project.Inventory.Decorator.Asset SerialNumber | 
|  | 146 |  | 
|  | 147 | ${cmd}=  Catenate  ${CMD_GET_PROPERTY_INVENTORY} /xyz/openbmc_project/inventory${component} | 
|  | 148 | ...  ${busctl_field} | 
|  | 149 | ${cmd_output}=  BMC Execute Command  ${cmd} | 
|  | 150 |  | 
|  | 151 | Valid Value  vpd_records['${component}']['${field}']  ['${cmd_output[0].split('"')[1].strip('"')}'] | 
|  | 152 |  | 
|  | 153 |  | 
|  | 154 | Verify VPD Data Via Vpdtool | 
|  | 155 | [Documentation]  Get VPD details of given component via vpdtool and verify it | 
|  | 156 | ...              using busctl command. | 
|  | 157 | [Arguments]  ${component}  ${field} | 
|  | 158 | # Description of arguments: | 
|  | 159 | # component       VPD component (e.g. System,Chassis etc). | 
|  | 160 | # field           VPD field (e.g. Serialnumber,LocationCode etc). | 
|  | 161 |  | 
|  | 162 | ${component_url}=  Set Variable If | 
|  | 163 | ...  '${component}' == 'System'  /system | 
|  | 164 |  | 
|  | 165 | # Get VPD details of given component via vpd-tool. | 
|  | 166 | ${vpd_records}=  Vpdtool  -o -O ${component_url} | 
|  | 167 |  | 
|  | 168 | # Get VPD details of given component via busctl command. | 
|  | 169 | ${busctl_field}=  Set Variable If | 
|  | 170 | ...  '${field}' == 'LocationCode'  com.ibm.ipzvpd.Location LocationCode | 
|  | 171 | ...  '${field}' == 'Model'  xyz.openbmc_project.Inventory.Decorator.Asset Model | 
|  | 172 | ...  '${field}' == 'SerialNumber'  xyz.openbmc_project.Inventory.Decorator.Asset SerialNumber | 
|  | 173 |  | 
|  | 174 | ${cmd}=  Catenate  ${CMD_GET_PROPERTY_INVENTORY} /xyz/openbmc_project/inventory/system | 
|  | 175 | ...  ${busctl_field} | 
|  | 176 | ${cmd_output}=  BMC Execute Command  ${cmd} | 
|  | 177 | # Example of cmd_output: | 
|  | 178 | #   [0]:                                            s "ABCD.XY1.1234567-P0" | 
|  | 179 | #   [1]: | 
|  | 180 | #   [2]:                                            0 | 
|  | 181 |  | 
|  | 182 | # Cross check vpdtool output with busctl response. | 
|  | 183 | Should Be Equal As Strings  ${vpd_records["/system"]["${field}"]} | 
|  | 184 | ...  ${cmd_output[0].split('"')[1].strip('"')} |