blob: d2e12c34dc33ee3d4285a539885c8b9338d654b9 [file] [log] [blame]
Rahul Maheshwari51dee262019-03-06 23:36:21 -06001*** Settings ***
2Documentation Test IPMI and Redfish combinations for user management.
3
4Resource ../../lib/resource.robot
5Resource ../../lib/bmc_redfish_resource.robot
6Resource ../../lib/openbmc_ffdc.robot
7Resource ../../lib/ipmi_client.robot
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -05008Library ../lib/ipmi_utils.py
Rahul Maheshwari51dee262019-03-06 23:36:21 -06009
10Test Setup Test Setup Execution
11Test Teardown Test Teardown Execution
12
Sridevi Rameshcf0c8b02025-09-17 06:22:35 -050013Test Teardown IPMI_Redfish_User
Rahul Maheshwari51dee262019-03-06 23:36:21 -060014
15*** Variables ***
16
17${valid_password} 0penBmc1
Rahul Maheshwaricf2336e2019-03-15 00:49:13 -050018${valid_password2} 0penBmc2
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -050019${admin_level_priv} 4
20${operator_level_priv} 3
Rahul Maheshwari7b7ba222022-08-21 23:29:43 -050021${readonly_level_priv} 2
Sridevi Ramesh5f352dc2025-06-26 10:13:19 -050022${user_count} 0
George Keishingdc7d6892022-07-07 14:28:32 -050023${ipmi_max_num_users} ${15}
ganesanb45102292023-03-28 11:13:29 +000024${max_num_users} ${15}
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -040025${empty_name_pattern} ^User Name\\s.*\\s:\\s$
Rahul Maheshwari51dee262019-03-06 23:36:21 -060026
Sridevi Ramesh5f352dc2025-06-26 10:13:19 -050027*** Test Cases ***
Rahul Maheshwari51dee262019-03-06 23:36:21 -060028
29Create Admin Redfish User And Verify Login Via IPMI
30 [Documentation] Create user using redfish and verify via IPMI.
31 [Tags] Create_Admin_Redfish_User_And_Verify_Login_Via_IPMI
32
33 ${random_username}= Generate Random String 8 [LETTERS]
34 Set Test Variable ${random_username}
35
36 ${payload}= Create Dictionary
37 ... UserName=${random_username} Password=${valid_password}
38 ... RoleId=Administrator Enabled=${True}
39 Redfish.Post /redfish/v1/AccountService/Accounts body=&{payload}
40 ... valid_status_codes=[${HTTP_CREATED}]
41
Sushma M M97fccae2020-07-27 14:55:19 -050042 # Delay added for created new user password to get set.
43 Sleep 5s
44
Rahul Maheshwari51dee262019-03-06 23:36:21 -060045 Verify IPMI Username And Password ${random_username} ${valid_password}
46
47
Rahul Maheshwaricf2336e2019-03-15 00:49:13 -050048Update User Password Via Redfish And Verify Using IPMI
49 [Documentation] Update user password via Redfish and verify using IPMI.
50 [Tags] Update_User_Password_Via_Redfish_And_Verify_Using_IPMI
51
52 # Create user using Redfish.
53 ${random_username}= Generate Random String 8 [LETTERS]
54 Set Test Variable ${random_username}
55
56 ${payload}= Create Dictionary
57 ... UserName=${random_username} Password=${valid_password}
58 ... RoleId=Administrator Enabled=${True}
59 Redfish.Post /redfish/v1/AccountService/Accounts body=&{payload}
60 ... valid_status_codes=[${HTTP_CREATED}]
61
62 # Update user password using Redfish.
63 ${payload}= Create Dictionary Password=${valid_password2}
64 Redfish.Patch /redfish/v1/AccountService/Accounts/${random_username} body=&{payload}
65
66 # Verify that IPMI command works with new password and fails with older password.
67 Verify IPMI Username And Password ${random_username} ${valid_password2}
68
Anusha Dathatri652fc742020-02-05 05:14:21 -060069 Run Keyword And Expect Error *Error: Unable to establish IPMI*
Rahul Maheshwaricf2336e2019-03-15 00:49:13 -050070 ... Verify IPMI Username And Password ${random_username} ${valid_password}
71
72
Rahul Maheshwariff63ac02019-03-29 10:25:21 -050073Update User Privilege Via Redfish And Verify Using IPMI
74 [Documentation] Update user privilege via Redfish and verify using IPMI.
75 [Tags] Update_User_Privilege_Via_Redfish_And_Verify_Using_IPMI
76
77 # Create user using Redfish with admin privilege.
78 ${random_username}= Generate Random String 8 [LETTERS]
79 Set Test Variable ${random_username}
80
81 ${payload}= Create Dictionary
82 ... UserName=${random_username} Password=${valid_password}
83 ... RoleId=Administrator Enabled=${True}
84 Redfish.Post /redfish/v1/AccountService/Accounts body=&{payload}
85 ... valid_status_codes=[${HTTP_CREATED}]
86
87 # Update user privilege to operator using Redfish.
88 ${payload}= Create Dictionary RoleId=Operator
89 Redfish.Patch /redfish/v1/AccountService/Accounts/${random_username} body=&{payload}
90
91 # Verify new user privilege level via IPMI.
Tony Leec317c982020-05-20 15:46:35 +080092 ${resp}= Run IPMI Standard Command user list ${CHANNEL_NUMBER}
Rahul Maheshwariff63ac02019-03-29 10:25:21 -050093
94 # Example of response data:
95 # ID Name Callin Link Auth IPMI Msg Channel Priv Limit
96 # 1 root false true true ADMINISTRATOR
97 # 2 OAvCxjMv false true true OPERATOR
98 # 3 true false false NO ACCESS
99 # ..
100 # ..
101 # 15 true false false NO ACCESS
102
103 ${user_info}=
104 ... Get Lines Containing String ${resp} ${random_username}
105 Should Contain ${user_info} OPERATOR
106
107
Rahul Maheshwaricf2336e2019-03-15 00:49:13 -0500108Delete User Via Redfish And Verify Using IPMI
109 [Documentation] Delete user via redfish and verify using IPMI.
110 [Tags] Delete_User_Via_Redfish_And_Verify_Using_IPMI
111
112 # Create user using Redfish.
113 ${random_username}= Generate Random String 8 [LETTERS]
114 Set Test Variable ${random_username}
115
116 ${payload}= Create Dictionary
117 ... UserName=${random_username} Password=${valid_password}
118 ... RoleId=Administrator Enabled=${True}
119 Redfish.Post /redfish/v1/AccountService/Accounts body=&{payload}
120 ... valid_status_codes=[${HTTP_CREATED}]
121
122 # Delete user using Redfish.
123 Redfish.Delete /redfish/v1/AccountService/Accounts/${random_username}
124
125 # Verify that IPMI command fails with deleted user.
Anusha Dathatri652fc742020-02-05 05:14:21 -0600126 Run Keyword And Expect Error *Error: Unable to establish IPMI*
Rahul Maheshwaricf2336e2019-03-15 00:49:13 -0500127 ... Verify IPMI Username And Password ${random_username} ${valid_password}
128
129
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500130Create IPMI User And Verify Login Via Redfish
131 [Documentation] Create user using IPMI and verify user login via Redfish.
132 [Tags] Create_IPMI_User_And_Verify_Login_Via_Redfish
133
134 ${username} ${userid}= IPMI Create Random User Plus Password And Privilege
135 ... ${valid_password} ${admin_level_priv}
136
Anusha Dathatri4d894652020-02-12 04:08:10 -0600137 Redfish.Logout
138
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500139 # Verify user login using Redfish.
140 Redfish.Login ${username} ${valid_password}
Anusha Dathatri4d894652020-02-12 04:08:10 -0600141 Redfish.Logout
142
143 Redfish.Login
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500144
145
146Update User Password Via IPMI And Verify Using Redfish
147 [Documentation] Update user password using IPMI and verify user
148 ... login via Redfish.
149 [Tags] Update_User_Password_Via_IPMI_And_Verify_Using_Redfish
150
151 ${username} ${userid}= IPMI Create Random User Plus Password And Privilege
152 ... ${valid_password} ${admin_level_priv}
153
154 # Update user password using IPMI.
155 Run IPMI Standard Command
156 ... user set password ${userid} ${valid_password2}
157
Anusha Dathatri4d894652020-02-12 04:08:10 -0600158 Redfish.Logout
159
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500160 # Verify that user login works with new password using Redfish.
161 Redfish.Login ${username} ${valid_password2}
Anusha Dathatri4d894652020-02-12 04:08:10 -0600162 Redfish.Logout
163
164 Redfish.Login
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500165
166
Rahul Maheshwari7b7ba222022-08-21 23:29:43 -0500167Update User Privilege To Operator Via IPMI And Verify Using Redfish
168 [Documentation] Update user privilege to operator via IPMI and verify using Redfish.
169 [Tags] Update_User_Privilege_To_Operator_Via_IPMI_And_Verify_Using_Redfish
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500170 # Create user using IPMI with admin privilege.
171 ${username} ${userid}= IPMI Create Random User Plus Password And Privilege
172 ... ${valid_password} ${admin_level_priv}
173
174 # Change user privilege to opetrator using IPMI.
175 Run IPMI Standard Command
Tony Lee69ed33e2020-05-20 17:15:02 +0800176 ... user priv ${userid} ${operator_level_priv} ${CHANNEL_NUMBER}
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500177
178 # Verify new user privilege level via Redfish.
179 ${privilege}= Redfish_Utils.Get Attribute
180 ... /redfish/v1/AccountService/Accounts/${username} RoleId
181 Should Be Equal ${privilege} Operator
182
183
Rahul Maheshwari7b7ba222022-08-21 23:29:43 -0500184Update User Privilege To Readonly Via IPMI And Verify Using Redfish
185 [Documentation] Update user privilege to readonly via IPMI and verify using Redfish.
186 [Tags] Update_User_Privilege_To_Readonly_Via_IPMI_And_Verify_Using_Redfish
187
188 # Create user using IPMI with admin privilege.
189 ${username} ${userid}= IPMI Create Random User Plus Password And Privilege
190 ... ${valid_password} ${admin_level_priv}
191
192 # Change user privilege to readonly using IPMI.
193 Run IPMI Standard Command
194 ... user priv ${userid} ${readonly_level_priv} ${CHANNEL_NUMBER}
195
196 # Verify new user privilege level via Redfish.
197 ${privilege}= Redfish_Utils.Get Attribute
198 ... /redfish/v1/AccountService/Accounts/${username} RoleId
199 Should Be Equal ${privilege} ReadOnly
200
201
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500202Delete User Via IPMI And Verify Using Redfish
203 [Documentation] Delete user using IPMI and verify error while doing
204 ... user login with deleted user via Redfish.
205 [Tags] Delete_User_Via_IPMI_And_Verify_Using_Redfish
206
207 ${username} ${userid}= IPMI Create Random User Plus Password And Privilege
208 ... ${valid_password} ${admin_level_priv}
209
210 # Delete IPMI User.
211 Run IPMI Standard Command user set name ${userid} ""
212
213 # Verify that Redfish login fails with deleted user.
214 Run Keyword And Expect Error *InvalidCredentialsError*
215 ... Redfish.Login ${username} ${valid_password}
216
217
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500218Verify Failure To Exceed Max Number Of Users
Sridevi Ramesh5f352dc2025-06-26 10:13:19 -0500219 [Documentation] Verify failure attempting to exceed the max number of
220 ... user accounts.
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500221 [Tags] Verify_Failure_To_Exceed_Max_Number_Of_Users
nagarjunb132d29a2022-07-29 09:02:47 +0000222 [Teardown] Run Keywords Test Teardown Execution
223 ... AND Delete Users Via Redfish ${username_list}
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500224
225 # Get existing user count.
Sridevi Ramesh5f352dc2025-06-26 10:13:19 -0500226 ${existing_user_count}= Get User Count Of Not IPMI Account Type
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500227
228 ${payload}= Create Dictionary Password=${valid_password}
229 ... RoleId=Administrator Enabled=${True}
230
Ashwini Chandrappadfd48012022-04-06 06:33:37 -0500231 @{username_list}= Create List
232
ganesanb45102292023-03-28 11:13:29 +0000233 # Create users to reach maximum users count (i.e. 15 users).
Sridevi Ramesh5f352dc2025-06-26 10:13:19 -0500234 FOR ${INDEX} IN RANGE ${existing_user_count} ${max_num_users}
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500235 ${random_username}= Generate Random String 8 [LETTERS]
236 Set To Dictionary ${payload} UserName ${random_username}
237 Redfish.Post ${REDFISH_ACCOUNTS_URI} body=&{payload}
238 ... valid_status_codes=[${HTTP_CREATED}]
Ashwini Chandrappadfd48012022-04-06 06:33:37 -0500239 Append To List ${username_list} /redfish/v1/AccountService/Accounts/${random_username}
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500240 END
241
Ashwini Chandrappadfd48012022-04-06 06:33:37 -0500242 # Verify error while creating 16th user.
Rahul Maheshwari3e61ce62019-06-18 02:09:01 -0500243 ${random_username}= Generate Random String 8 [LETTERS]
244 Set To Dictionary ${payload} UserName ${random_username}
245 Redfish.Post ${REDFISH_ACCOUNTS_URI} body=&{payload}
246 ... valid_status_codes=[${HTTP_BAD_REQUEST}]
247
248
Anusha Dathatri9ecaaf42020-01-20 04:50:13 -0600249Create IPMI User Without Any Privilege And Verify Via Redfish
250 [Documentation] Create user using IPMI without privilege and verify via redfish.
251 [Tags] Create_IPMI_User_Without_Any_Privilege_And_Verify_Via_Redfish
252
253 ${username} ${userid}= IPMI Create Random User Plus Password And Privilege
254 ... ${valid_password}
255
256 # Verify new user privilege level via Redfish.
257 ${privilege}= Redfish_Utils.Get Attribute
258 ... /redfish/v1/AccountService/Accounts/${username} RoleId
kothais42b2e302023-11-03 06:56:08 +0000259 Valid Value privilege ['ReadOnly']
Anusha Dathatri9ecaaf42020-01-20 04:50:13 -0600260
Rahul Maheshwari51dee262019-03-06 23:36:21 -0600261*** Keywords ***
262
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500263IPMI Create Random User Plus Password And Privilege
264 [Documentation] Create random IPMI user with given password and privilege
265 ... level.
Anusha Dathatri9ecaaf42020-01-20 04:50:13 -0600266 [Arguments] ${password} ${privilege}=0
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500267
268 # Description of argument(s):
269 # password Password to be assigned for the user.
270 # privilege Privilege level for the user (e.g. "1", "2", "3", etc.).
271
272 # Create IPMI user.
273 ${random_username}= Generate Random String 8 [LETTERS]
274 Set Suite Variable ${random_username}
275
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -0400276 ${random_userid}= Find Free User Id
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500277 IPMI Create User ${random_userid} ${random_username}
278
279 # Set given password for newly created user.
280 Run IPMI Standard Command
281 ... user set password ${random_userid} ${password}
282
283 # Enable IPMI user.
284 Run IPMI Standard Command user enable ${random_userid}
285
286 # Set given privilege and enable IPMI messaging for newly created user.
George Keishing79fc7f02025-05-02 00:37:49 +0530287 IF '${privilege}' != '0'
288 Set Channel Access ${random_userid} ipmi=on privilege=${privilege}
289 END
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500290
George Keishing409df052024-01-17 22:36:14 +0530291 RETURN ${random_username} ${random_userid}
Rahul Maheshwari75e91fe2019-03-29 05:32:28 -0500292
293
nagarjunb132d29a2022-07-29 09:02:47 +0000294Delete Users Via Redfish
295 [Documentation] Delete all the users via redfish from given list.
296 [Arguments] ${user_list}
297
298 # Description of argument(s):
299 # user_list List of user which are to be deleted.
300
301 Redfish.Login
302
303 FOR ${user} IN @{user_list}
304 Redfish.Delete ${user}
305 END
306
307 Redfish.Logout
308
309
Rahul Maheshwari51dee262019-03-06 23:36:21 -0600310Test Setup Execution
311 [Documentation] Do test case setup tasks.
312
313 Redfish.Login
314
315
316Test Teardown Execution
317 [Documentation] Do the post test teardown.
318
319 FFDC On Test Case Fail
320 # Delete the test user.
321 Run Keyword And Ignore Error
322 ... Redfish.Delete /redfish/v1/AccountService/Accounts/${random_username}
323
324 Redfish.Logout
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -0400325
326
327Find Free User Id
328 [Documentation] Find a userid that is not being used.
Sridevi Rameshcf0c8b02025-09-17 06:22:35 -0500329
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -0400330 FOR ${jj} IN RANGE 300
George Keishingdc7d6892022-07-07 14:28:32 -0500331 # IPMI maximum users count (i.e. 15 users).
332 ${random_userid}= Evaluate random.randint(1, ${ipmi_max_num_users}) modules=random
Nagarjun B26499142023-02-16 15:20:14 +0530333 ${access}= Run IPMI Standard Command channel getaccess ${CHANNEL_NUMBER} ${random_userid}
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -0400334
335 ${name_line}= Get Lines Containing String ${access} User Name
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -0400336 ${is_empty}= Run Keyword And Return Status
337 ... Should Match Regexp ${name_line} ${empty_name_pattern}
338
Sridevi Rameshb0a5a6d2025-04-30 07:14:07 -0500339 IF ${is_empty} == ${True} BREAK
Gene Ratzlaffd4cdc112022-05-06 13:17:35 -0400340 END
George Keishing79fc7f02025-05-02 00:37:49 +0530341 IF '${jj}' == '299' Fail msg=A free user ID could not be found.
George Keishing409df052024-01-17 22:36:14 +0530342 RETURN ${random_userid}
Sridevi Ramesh5f352dc2025-06-26 10:13:19 -0500343
344
345Get All User Account Names
346 [Documentation] Get all user account names in list format.
347
348 @{username_list}= Create List
349 ${resp}= Redfish.Get /redfish/v1/AccountService/Accounts/
350 ${current_users}= Get From Dictionary ${resp.dict} Members
351 FOR ${user} IN @{current_users}
352 ${output}= Split String ${user["@odata.id"]} /redfish/v1/AccountService/Accounts/
353 Append To List ${username_list} ${output[1]}
354 END
355 RETURN ${username_list}
356
357
358Get User Count Of Not IPMI Account Type
359 [Documentation] Get user count of not IPMI account type.
360
361 ${username_list}= Get All User Account Names
362 FOR ${user} IN @{username_list}
363 ${resp}= Redfish.Get /redfish/v1/AccountService/Accounts/${user}
364 @{account_type}= Get From Dictionary ${resp.dict} AccountTypes
365 IF "IPMI" not in ${account_type}
366 ${user_count}= Evaluate ${user_count} + 1
367 END
368 END
369 RETURN ${user_count}