blob: d7fde9141f2a0371c2a24c21f727be44e2252144 [file] [log] [blame]
Chris Austenb29d2e82016-06-07 12:25:35 -05001*** Settings ***
2Library Collections
3Library String
4Library RequestsLibrary.RequestsKeywords
5Library OperatingSystem
Sandhya Somashekar839a0c22019-01-31 05:05:43 -06006Resource resource.robot
George Keishingeaa73b72018-07-30 09:30:16 -05007Library disable_warning_urllib.py
Michael Walshad66c952018-10-04 15:12:47 -05008Library utils.py
Steven Sombarb3489242018-12-13 15:59:02 -06009Library gen_misc.py
Sridevi Ramesheadeef02019-01-17 08:56:18 -060010Library var_funcs.py
George Keishingeaa73b72018-07-30 09:30:16 -050011Resource rest_response_code.robot
Chris Austenb29d2e82016-06-07 12:25:35 -050012
13*** Variables ***
Michael Walsha6723f22016-11-22 11:12:01 -060014# Assign default value to QUIET for programs which may not define it.
15${QUIET} ${0}
Chris Austenb29d2e82016-06-07 12:25:35 -050016
Sridevi Ramesheadeef02019-01-17 08:56:18 -060017${XAUTH_TOKEN} ${EMPTY}
18
Chris Austenb29d2e82016-06-07 12:25:35 -050019*** Keywords ***
20OpenBMC Get Request
manasarm604b8cd2018-01-29 12:14:20 +053021 [Documentation] Do REST GET request and return the result.
22 # Example result data:
23 # Response code:200, Content:{
24 # "data": [
25 # "/xyz/openbmc_project/state/host0",
26 # "/xyz/openbmc_project/state/chassis0",
27 # "/xyz/openbmc_project/state/bmc0"
28 # ],
29 # "message": "200 OK",
30 # "status": "ok"
31 # }
George Keishing41c44cf2017-11-15 08:02:59 -060032 [Arguments] ${uri} ${timeout}=30 ${quiet}=${QUIET} &{kwargs}
manasarm604b8cd2018-01-29 12:14:20 +053033 # Description of argument(s):
34 # uri The URI to establish connection with
35 # (e.g. '/xyz/openbmc_project/software/').
36 # timeout Timeout in seconds to establish connection with URI.
37 # quiet If enabled, turns off logging to console.
38 # kwargs Any additional arguments to be passed directly to the
39 # Get Request call. For example, the caller might
40 # set kwargs as follows:
41 # ${kwargs}= Create Dictionary allow_redirect=${True}.
Michael Walshf00edee2016-12-09 14:10:26 -060042
Sridevi Ramesheadeef02019-01-17 08:56:18 -060043 Initialize OpenBMC ${timeout} quiet=${quiet}
44
Chris Austenb29d2e82016-06-07 12:25:35 -050045 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
Sridevi Ramesheadeef02019-01-17 08:56:18 -060046 ${headers}= Create Dictionary Content-Type=application/octet-stream
47 ... X-Auth-Token=${XAUTH_TOKEN} Accept=application/octet-stream
48 Set To Dictionary ${kwargs} headers ${headers}
Michael Walsha6723f22016-11-22 11:12:01 -060049 Run Keyword If '${quiet}' == '${0}' Log Request method=Get
50 ... base_uri=${base_uri} args=&{kwargs}
Michael Walsha6723f22016-11-22 11:12:01 -060051 ${ret}= Get Request openbmc ${base_uri} &{kwargs} timeout=${timeout}
52 Run Keyword If '${quiet}' == '${0}' Log Response ${ret}
George Keishing08540c02017-07-19 09:42:50 -050053 Delete All Sessions
Chris Austenb29d2e82016-06-07 12:25:35 -050054 [Return] ${ret}
55
56OpenBMC Post Request
manasarm604b8cd2018-01-29 12:14:20 +053057 [Documentation] Do REST POST request and return the result.
58 # Example result data:
59 # <Response [200]>
Michael Walsha6723f22016-11-22 11:12:01 -060060 [Arguments] ${uri} ${timeout}=10 ${quiet}=${QUIET} &{kwargs}
manasarm604b8cd2018-01-29 12:14:20 +053061 # Description of argument(s):
62 # uri The URI to establish connection with
63 # (e.g. '/xyz/openbmc_project/software/').
64 # timeout Timeout in seconds to establish connection with URI.
65 # quiet If enabled, turns off logging to console.
66 # kwargs Any additional arguments to be passed directly to the
67 # Post Request call. For example, the caller might
68 # set kwargs as follows:
69 # ${kwargs}= Create Dictionary allow_redirect=${True}.
Michael Walsha6723f22016-11-22 11:12:01 -060070
Michael Walshf00edee2016-12-09 14:10:26 -060071 Initialize OpenBMC ${timeout} quiet=${quiet}
Chris Austenb29d2e82016-06-07 12:25:35 -050072 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
Sridevi Ramesheadeef02019-01-17 08:56:18 -060073 ${headers}= Create Dictionary Content-Type=application/json
74 ... X-Auth-Token=${XAUTH_TOKEN}
Chris Austenb29d2e82016-06-07 12:25:35 -050075 set to dictionary ${kwargs} headers ${headers}
Michael Walsha6723f22016-11-22 11:12:01 -060076 Run Keyword If '${quiet}' == '${0}' Log Request method=Post
77 ... base_uri=${base_uri} args=&{kwargs}
Michael Walsha6723f22016-11-22 11:12:01 -060078 ${ret}= Post Request openbmc ${base_uri} &{kwargs} timeout=${timeout}
79 Run Keyword If '${quiet}' == '${0}' Log Response ${ret}
George Keishing08540c02017-07-19 09:42:50 -050080 Delete All Sessions
Chris Austenb29d2e82016-06-07 12:25:35 -050081 [Return] ${ret}
82
83OpenBMC Put Request
manasarm604b8cd2018-01-29 12:14:20 +053084 [Documentation] Do REST PUT request on the resource identified by the URI.
Rahul Maheshwari79c12942016-10-17 09:39:17 -050085 [Arguments] ${uri} ${timeout}=10 &{kwargs}
manasarm604b8cd2018-01-29 12:14:20 +053086 # Description of argument(s):
87 # uri The URI to establish connection with
88 # (e.g. '/xyz/openbmc_project/software/').
89 # timeout Timeout in seconds to establish connection with URI.
90 # kwargs Arguments passed to the REST call.
91 # kwargs Any additional arguments to be passed directly to the
92 # Put Request call. For example, the caller might
93 # set kwargs as follows:
94 # ${kwargs}= Create Dictionary allow_redirect=${True}.
Michael Walshf00edee2016-12-09 14:10:26 -060095
96 Initialize OpenBMC ${timeout}
Chris Austenb29d2e82016-06-07 12:25:35 -050097 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
98 ${headers}= Create Dictionary Content-Type=application/json
Sridevi Ramesheadeef02019-01-17 08:56:18 -060099 ... X-Auth-Token=${XAUTH_TOKEN}
Chris Austenb29d2e82016-06-07 12:25:35 -0500100 set to dictionary ${kwargs} headers ${headers}
101 Log Request method=Put base_uri=${base_uri} args=&{kwargs}
Michael Walsha6723f22016-11-22 11:12:01 -0600102 ${ret}= Put Request openbmc ${base_uri} &{kwargs} timeout=${timeout}
Chris Austenb29d2e82016-06-07 12:25:35 -0500103 Log Response ${ret}
George Keishing08540c02017-07-19 09:42:50 -0500104 Delete All Sessions
Chris Austenb29d2e82016-06-07 12:25:35 -0500105 [Return] ${ret}
106
107OpenBMC Delete Request
manasarm604b8cd2018-01-29 12:14:20 +0530108 [Documentation] Do REST request to delete the resource identified by the
109 ... URI.
Rahul Maheshwari79c12942016-10-17 09:39:17 -0500110 [Arguments] ${uri} ${timeout}=10 &{kwargs}
manasarm604b8cd2018-01-29 12:14:20 +0530111 # Description of argument(s):
112 # uri The URI to establish connection with
113 # (e.g. '/xyz/openbmc_project/software/').
114 # timeout Timeout in seconds to establish connection with URI.
115 # kwargs Any additional arguments to be passed directly to the
116 # Delete Request call. For example, the caller might
117 # set kwargs as follows:
118 # ${kwargs}= Create Dictionary allow_redirect=${True}.
Michael Walshf00edee2016-12-09 14:10:26 -0600119
120 Initialize OpenBMC ${timeout}
Chris Austenb29d2e82016-06-07 12:25:35 -0500121 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600122 ${headers}= Create Dictionary Content-Type=application/json
123 ... X-Auth-Token=${XAUTH_TOKEN}
124 Set To Dictionary ${kwargs} headers ${headers}
125 Log Request method=Delete base_uri=${base_uri} args=&{kwargs}
George Keishing0e7c3a02017-04-17 05:01:14 -0500126 ${ret}= Delete Request openbmc ${base_uri} &{kwargs} timeout=${timeout}
Chris Austenb29d2e82016-06-07 12:25:35 -0500127 Log Response ${ret}
George Keishing08540c02017-07-19 09:42:50 -0500128 Delete All Sessions
Chris Austenb29d2e82016-06-07 12:25:35 -0500129 [Return] ${ret}
130
131Initialize OpenBMC
manasarm604b8cd2018-01-29 12:14:20 +0530132 [Documentation] Do a REST login connection within specified time.
George Keishing1cdc6dd2017-04-24 15:31:03 -0500133 [Arguments] ${timeout}=20 ${quiet}=${1}
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600134 ... ${rest_username}=${REST_USERNAME}
135 ... ${rest_password}=${REST_PASSWORD}
Michael Walshf00edee2016-12-09 14:10:26 -0600136
George Keishing1cdc6dd2017-04-24 15:31:03 -0500137 # Description of argument(s):
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600138 # timeout REST login attempt time out.
139 # quiet Suppress console log if set.
140 # rest_username The REST username.
141 # rest_password The REST password.
142
143 ${bmcweb_status}= Run Keyword And Return Status BMC Web Login Request
144 ... ${timeout} ${rest_username} ${rest_password}
145
146 Return From Keyword If ${bmcweb_status} == ${True}
George Keishing1cdc6dd2017-04-24 15:31:03 -0500147
George Keishing1cdc6dd2017-04-24 15:31:03 -0500148 # This will retry at 20 second interval.
149 Wait Until Keyword Succeeds 40 sec 20 sec
150 ... Post Login Request ${timeout} ${quiet}
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600151 ... ${rest_username} ${rest_password}
152
153
154BMC Web Login Request
155 [Documentation] Do BMC web-based login.
156 [Arguments] ${timeout}=20 ${rest_username}=${REST_USERNAME}
157 ... ${rest_password}=${REST_PASSWORD}
158
159 # Description of argument(s):
160 # timeout REST login attempt time out.
161 # rest_username The REST username.
162 # rest_password The REST password.
163
164 Create Session openbmc ${AUTH_URI} timeout=${timeout}
165
166 ${headers}= Create Dictionary Content-Type=application/json
167 @{credentials}= Create List ${rest_username} ${rest_password}
168 ${data}= Create Dictionary data=@{credentials}
169 ${resp}= Post Request openbmc /login data=${data} headers=${headers}
170 Should Be Equal As Strings ${resp.status_code} ${HTTP_OK}
171
172 ${processed_token_data}=
173 ... Evaluate re.split(r'[;,]', '${resp.headers["Set-Cookie"]}') modules=re
174 ${result}= Key Value List To Dict ${processed_token_data} delim==
175
176 # Example result data:
177 # 'XSRF-TOKEN=hQuOyDJFEIbrN4aOg2CT; Secure,
178 # SESSION=c4wloTiETumSxPI9nLeg; Secure; HttpOnly'
179 Set Global Variable ${XAUTH_TOKEN} ${result['session']}
180
George Keishing1cdc6dd2017-04-24 15:31:03 -0500181
182Post Login Request
manasarm604b8cd2018-01-29 12:14:20 +0530183 [Documentation] Do REST login request.
George Keishing1cdc6dd2017-04-24 15:31:03 -0500184 [Arguments] ${timeout}=20 ${quiet}=${1}
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600185 ... ${rest_username}=${REST_USERNAME}
186 ... ${rest_password}=${REST_PASSWORD}
George Keishing1cdc6dd2017-04-24 15:31:03 -0500187
188 # Description of argument(s):
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600189 # timeout REST login attempt time out.
190 # quiet Suppress console log if set.
191 # rest_username The REST username.
192 # rest_password The REST password.
George Keishing1cdc6dd2017-04-24 15:31:03 -0500193
194 Create Session openbmc ${AUTH_URI} timeout=${timeout} max_retries=3
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600195
Michael Walsha6723f22016-11-22 11:12:01 -0600196 ${headers}= Create Dictionary Content-Type=application/json
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600197 @{credentials}= Create List ${rest_username} ${rest_password}
Michael Walsha6723f22016-11-22 11:12:01 -0600198 ${data}= create dictionary data=@{credentials}
Michael Walshf00edee2016-12-09 14:10:26 -0600199 ${status} ${resp}= Run Keyword And Ignore Error Post Request openbmc
200 ... /login data=${data} headers=${headers}
201
202 Should Be Equal ${status} PASS msg=${resp}
203 Should Be Equal As Strings ${resp.status_code} ${HTTP_OK}
Chris Austenb29d2e82016-06-07 12:25:35 -0500204
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600205
George Keishinge8225522017-03-31 09:21:13 -0500206Log Out OpenBMC
manasarm604b8cd2018-01-29 12:14:20 +0530207 [Documentation] Log out of the openbmc REST session.
George Keishinge8225522017-03-31 09:21:13 -0500208
209 ${headers}= Create Dictionary Content-Type=application/json
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600210 ... X-Auth-Token=${XAUTH_TOKEN}
George Keishinge8225522017-03-31 09:21:13 -0500211 ${data}= Create dictionary data=@{EMPTY}
212
213 # If there is no active sesion it will throw the following exception
214 # "Non-existing index or alias 'openbmc'"
215 ${resp}= Post Request openbmc
216 ... /logout data=${data} headers=${headers}
217
218 Should Be Equal As Strings ${resp.status_code} ${HTTP_OK}
219 ... msg=${resp}
220
Chris Austenb29d2e82016-06-07 12:25:35 -0500221Log Request
manasarm604b8cd2018-01-29 12:14:20 +0530222 [Documentation] Log the specific REST URI, method name on the console.
Chris Austenb29d2e82016-06-07 12:25:35 -0500223 [Arguments] &{kwargs}
Michael Walsha6723f22016-11-22 11:12:01 -0600224 ${msg}= Catenate SEPARATOR= URI: ${AUTH_URI} ${kwargs["base_uri"]}
225 ... , method: ${kwargs["method"]} , args: ${kwargs["args"]}
Chris Austenb29d2e82016-06-07 12:25:35 -0500226 Logging ${msg} console=True
227
228Log Response
manasarm604b8cd2018-01-29 12:14:20 +0530229 [Documentation] Log the response code on the console.
Chris Austenb29d2e82016-06-07 12:25:35 -0500230 [Arguments] ${resp}
Michael Walsha6723f22016-11-22 11:12:01 -0600231 ${msg}= Catenate SEPARATOR= Response code: ${resp.status_code}
232 ... , Content: ${resp.content}
Chris Austenb29d2e82016-06-07 12:25:35 -0500233 Logging ${msg} console=True
234
235Logging
manasarm604b8cd2018-01-29 12:14:20 +0530236 [Documentation] Log the specified message on the console.
Chris Austenb29d2e82016-06-07 12:25:35 -0500237 [Arguments] ${msg} ${console}=default False
238 Log ${msg} console=True
239
240Read Attribute
manasarm604b8cd2018-01-29 12:14:20 +0530241 [Documentation] Retrieve attribute value from URI and return result.
242 # Example result data for the attribute 'FieldModeEnabled' in
243 # "/xyz/openbmc_project/software/attr/" :
244 # 0
Gunnar Mills38032802016-12-12 13:43:40 -0600245 [Arguments] ${uri} ${attr} ${timeout}=10 ${quiet}=${QUIET}
manasarmc505e382018-02-05 14:05:48 +0530246 ... ${expected_value}=${EMPTY}
manasarm604b8cd2018-01-29 12:14:20 +0530247 # Description of argument(s):
248 # uri URI of the object that the attribute lives on
249 # (e.g. '/xyz/openbmc_project/software/').
250 # attr Name of the attribute (e.g. 'FieldModeEnabled').
251 # timeout Timeout for the REST call.
252 # quiet If enabled, turns off logging to console.
manasarmc505e382018-02-05 14:05:48 +0530253 # expected_value If this argument is not empty, the retrieved value
254 # must match this value.
manasarm604b8cd2018-01-29 12:14:20 +0530255
Steven Sombarb3489242018-12-13 15:59:02 -0600256 # Make sure uri ends with slash.
257 ${uri}= Add Trailing Slash ${uri}
258
259 ${resp}= OpenBMC Get Request ${uri}attr/${attr} timeout=${timeout}
Michael Walsha6723f22016-11-22 11:12:01 -0600260 ... quiet=${quiet}
Michael Walsh9cd61932017-01-17 16:11:02 -0600261 Should Be Equal As Strings ${resp.status_code} ${HTTP_OK}
Chris Austenb29d2e82016-06-07 12:25:35 -0500262 ${content}= To Json ${resp.content}
manasarmc505e382018-02-05 14:05:48 +0530263 Run Keyword If '${expected_value}' != '${EMPTY}'
264 ... Should Be Equal As Strings ${expected_value} ${content["data"]}
Gunnar Millsc9ea9362016-12-13 16:21:13 -0600265 [Return] ${content["data"]}
Chris Austenb29d2e82016-06-07 12:25:35 -0500266
Charles Paul Hoferf45e5ee2017-10-04 12:15:48 -0500267
Chris Austenb29d2e82016-06-07 12:25:35 -0500268Write Attribute
Charles Paul Hoferf45e5ee2017-10-04 12:15:48 -0500269 [Documentation] Write a D-Bus attribute with REST.
270 [Arguments] ${uri} ${attr} ${timeout}=10 ${verify}=${FALSE}
271 ... ${expected_value}=${EMPTY} &{kwargs}
272
273 # Description of argument(s):
274 # uri URI of the object that the attribute lives on
275 # (e.g. '/xyz/openbmc_project/software/').
276 # attr Name of the attribute (e.g. 'FieldModeEnabled').
277 # timeout Timeout for the REST call.
278 # verify If set to ${TRUE}, the attribute will be read back to
279 # ensure that its value is set to ${verify_attr}.
280 # expected_value Only used if verify is set to ${TRUE}. The value that
281 # ${attr} should be set to. This defaults to
282 # ${kwargs['data']. There are cases where the caller
283 # expects some other value in which case this value can
284 # be explicitly specified.
285 # kwargs Arguments passed to the REST call. This should always
286 # contain the value to set the property to at the 'data'
287 # key (e.g. data={"data": 1}).
288
George Keishingdf3e65f2018-12-18 13:06:56 -0600289 # Make sure uri ends with slash.
290 ${uri}= Add Trailing Slash ${uri}
291
Charles Paul Hoferf45e5ee2017-10-04 12:15:48 -0500292 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
George Keishingdf3e65f2018-12-18 13:06:56 -0600293 ${resp}= Openbmc Put Request ${base_uri}attr/${attr}
Michael Walsha6723f22016-11-22 11:12:01 -0600294 ... timeout=${timeout} &{kwargs}
Charles Paul Hoferf45e5ee2017-10-04 12:15:48 -0500295 Should Be Equal As Strings ${resp.status_code} ${HTTP_OK}
296
297 # Verify the attribute was set correctly if the caller requested it.
298 Return From Keyword If ${verify} == ${FALSE}
299
300 ${expected_value}= Set Variable If '${expected_value}' == '${EMPTY}'
Charles Paul Hofer00401e72017-10-31 11:42:30 -0500301 ... ${kwargs['data']['data']} ${expected_value}
Charles Paul Hoferf45e5ee2017-10-04 12:15:48 -0500302 ${value}= Read Attribute ${uri} ${attr}
303 Should Be Equal ${value} ${expected_value}
304
Chris Austenb29d2e82016-06-07 12:25:35 -0500305Read Properties
manasarm604b8cd2018-01-29 12:14:20 +0530306 [Documentation] Read data part of the URI object and return result.
307 # Example result data:
308 # [u'/xyz/openbmc_project/software/cf7bf9d5',
309 # u'/xyz/openbmc_project/software/5ecb8b2c',
310 # u'/xyz/openbmc_project/software/active',
311 # u'/xyz/openbmc_project/software/functional']
George Keishing335f5362017-06-30 15:11:20 -0500312 [Arguments] ${uri} ${timeout}=10 ${quiet}=${QUIET}
manasarm604b8cd2018-01-29 12:14:20 +0530313 # Description of argument(s):
314 # uri URI of the object
315 # (e.g. '/xyz/openbmc_project/software/').
316 # timeout Timeout for the REST call.
317 # quiet If enabled, turns off logging to console.
318
George Keishing335f5362017-06-30 15:11:20 -0500319 ${resp}= OpenBMC Get Request ${uri} timeout=${timeout} quiet=${quiet}
320 Should Be Equal As Strings ${resp.status_code} ${HTTP_OK}
Michael Walshad66c952018-10-04 15:12:47 -0500321 ${content}= To Json Ordered ${resp.content}
322
George Keishing335f5362017-06-30 15:11:20 -0500323 [Return] ${content["data"]}
Chris Austenb29d2e82016-06-07 12:25:35 -0500324
325Call Method
manasarm604b8cd2018-01-29 12:14:20 +0530326 [Documentation] Invoke the specific REST service method.
Gunnar Mills38032802016-12-12 13:43:40 -0600327 [Arguments] ${uri} ${method} ${timeout}=10 ${quiet}=${QUIET} &{kwargs}
manasarm604b8cd2018-01-29 12:14:20 +0530328 # Description of arguments:
329 # uri The URI to establish connection with
330 # (e.g. '/xyz/openbmc_project/software/').
331 # timeout Timeout in seconds to establish connection with URI.
332 # quiet If enabled, turns off logging to console.
333 # kwargs Arguments passed to the REST call.
Michael Walsha6723f22016-11-22 11:12:01 -0600334
Chris Austenb29d2e82016-06-07 12:25:35 -0500335 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
George Keishing5c231a82019-02-05 09:02:04 -0600336 ${resp}= OpenBmc Post Request ${base_uri}action/${method}
Michael Walsha6723f22016-11-22 11:12:01 -0600337 ... timeout=${timeout} quiet=${quiet} &{kwargs}
Gunnar Millsc9ea9362016-12-13 16:21:13 -0600338 [Return] ${resp}
Saqib Khanbb8b63f2017-05-24 10:58:01 -0500339
Sushil Singh47f80132019-08-27 04:53:24 -0500340
Saqib Khanbb8b63f2017-05-24 10:58:01 -0500341Upload Image To BMC
Sushil Singh47f80132019-08-27 04:53:24 -0500342 [Documentation] Upload image to BMC via REST and return status code.
343 [Arguments] ${uri} ${timeout}=10 ${quiet}=${1}
Sushil Singhc08df052020-03-30 00:39:22 -0500344 ... ${valid_status_codes}=[${HTTP_OK}, ${HTTP_ACCEPTED}] &{kwargs}
Saqib Khanbb8b63f2017-05-24 10:58:01 -0500345
346 # Description of argument(s):
Sushil Singh47f80132019-08-27 04:53:24 -0500347 # uri URI for uploading image via REST e.g.
348 # "/upload/image".
349 # timeout Time allocated for the REST command to
350 # return status (specified in Robot
351 # Framework Time Format e.g. "3 mins").
352 # quiet If enabled, turns off logging to console.
353 # valid_status_codes A list of status codes that are valid for
354 # the REST post command. This can be
355 # specified as a string the evaluates to a
356 # python object (e.g. [${HTTP_OK}]).
357 # kwargs A dictionary keys/values to be passed
358 # directly to Post Request.
Saqib Khanbb8b63f2017-05-24 10:58:01 -0500359
360 Initialize OpenBMC ${timeout} quiet=${quiet}
361 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
362 ${headers}= Create Dictionary Content-Type=application/octet-stream
Sridevi Ramesheadeef02019-01-17 08:56:18 -0600363 ... X-Auth-Token=${XAUTH_TOKEN} Accept=application/octet-stream
Saqib Khanbb8b63f2017-05-24 10:58:01 -0500364 Set To Dictionary ${kwargs} headers ${headers}
365 Run Keyword If '${quiet}' == '${0}' Log Request method=Post
366 ... base_uri=${base_uri} args=&{kwargs}
367 ${ret}= Post Request openbmc ${base_uri} &{kwargs} timeout=${timeout}
368 Run Keyword If '${quiet}' == '${0}' Log Response ${ret}
Sushil Singh47f80132019-08-27 04:53:24 -0500369 Valid Value ret.status_code ${valid_status_codes}
George Keishing08540c02017-07-19 09:42:50 -0500370 Delete All Sessions
Sushil Singh47f80132019-08-27 04:53:24 -0500371
372 [Return] ${ret.status_code}
373
George Keishingf4a43972020-06-29 03:55:38 -0500374
375Redfish Login
376 [Documentation] Do BMC web-based login.
377 [Arguments] ${timeout}=20 ${rest_username}=${REST_USERNAME}
378 ... ${rest_password}=${REST_PASSWORD} ${kwargs}=${EMPTY}
379
380 # Description of argument(s):
381 # timeout REST login attempt time out.
382 # rest_username The REST username.
383 # rest_password The REST password.
384 # kwargs Any additional arguments to be passed directly to the
385 # Get Request call. For example, the caller might
386 # set kwargs as follows:
387 # ${kwargs}= Create Dictionary allow_redirect=${True}.
388
George Keishing566daaf2020-07-02 06:18:50 -0500389 Create Session redfish ${AUTH_URI} timeout=${timeout}
George Keishingf4a43972020-06-29 03:55:38 -0500390 ${headers}= Create Dictionary Content-Type=application/json
391 ${data}= Set Variable If '${kwargs}' == '${EMPTY}'
392 ... {"UserName":"${rest_username}", "Password":"${rest_password}"}
393 ... {"UserName":"${rest_username}", "Password":"${rest_password}", ${kwargs}}
394
George Keishing566daaf2020-07-02 06:18:50 -0500395 ${resp}= Post Request redfish /redfish/v1/SessionService/Sessions
George Keishingf4a43972020-06-29 03:55:38 -0500396 ... data=${data} headers=${headers}
397 Should Be Equal As Strings ${resp.status_code} ${HTTP_CREATED}
398
George Keishing0f94f6f2020-06-30 08:02:43 -0500399 ${content}= To JSON ${resp.content}
400
George Keishingf4a43972020-06-29 03:55:38 -0500401 Set Global Variable ${XAUTH_TOKEN} ${resp.headers["X-Auth-Token"]}
402
George Keishing0f94f6f2020-06-30 08:02:43 -0500403 [Return] ${content}
George Keishing566daaf2020-07-02 06:18:50 -0500404
405
406Redfish Post Request
407 [Documentation] Do REST POST request and return the result.
408 [Arguments] ${uri} ${timeout}=10 ${quiet}=${QUIET} &{kwargs}
409
410 # Description of argument(s):
411 # uri The URI to establish connection with
412 # (e.g. '/xyz/openbmc_project/software/').
413 # timeout Timeout in seconds to establish connection with URI.
414 # quiet If enabled, turns off logging to console.
415 # kwargs Any additional arguments to be passed directly to the
416 # Post Request call. For example, the caller might
417 # set kwargs as follows:
418 # ${kwargs}= Create Dictionary allow_redirect=${True}.
419
420 ${base_uri}= Catenate SEPARATOR= ${DBUS_PREFIX} ${uri}
421 ${headers}= Create Dictionary Content-Type=application/json X-Auth-Token=${XAUTH_TOKEN}
422 Set To Dictionary ${kwargs} headers ${headers}
423 Run Keyword If '${quiet}' == '${0}' Log Request method=Post base_uri=${base_uri} args=&{kwargs}
424 ${resp}= Post Request redfish ${base_uri} &{kwargs} timeout=${timeout}
425 Run Keyword If '${quiet}' == '${0}' Log Response ${resp}
426
427 [Return] ${resp}