blob: c865308efaeb661fd75d75739468781e14ce282b [file] [log] [blame]
Prashanth Kattifa699cf2020-04-06 10:13:33 -05001*** Settings ***
2Documentation Connections and authentication module stability tests.
3
4Resource ../lib/bmc_redfish_resource.robot
5Resource ../lib/bmc_network_utils.robot
6Resource ../lib/openbmc_ffdc.robot
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -05007Resource ../lib/resource.robot
8Resource ../lib/utils.robot
9Resource ../lib/connection_client.robot
shrsuman123b844a872021-12-21 05:49:41 -060010Resource ../gui/lib/gui_resource.robot
Prashanth Kattifa699cf2020-04-06 10:13:33 -050011Library ../lib/bmc_network_utils.py
12
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -050013Library SSHLibrary
Prashanth Kattifa699cf2020-04-06 10:13:33 -050014Library Collections
Prashanth Kattiee26d5e2021-05-21 00:38:31 -050015Library XvfbRobot
16Library OperatingSystem
George Keishing47d1e8e2022-02-17 10:38:49 -060017Library SeleniumLibrary 120 120
Prashanth Kattiee26d5e2021-05-21 00:38:31 -050018Library Telnet 30 Seconds
19Library Screenshot
20
shrsuman123a8ca2962022-01-07 03:30:08 -060021
22Suite Setup Redfish.Logout
23
Prashanth Kattiee26d5e2021-05-21 00:38:31 -050024Variables ../gui/data/gui_variables.py
Prashanth Kattifa699cf2020-04-06 10:13:33 -050025
26*** Variables ***
27
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -050028${iterations} 10000
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -050029${loop_iteration} ${1000}
George Keishing23afcc52022-04-07 03:18:08 -050030${hostname} testhostname
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -050031${MAX_UNAUTH_PER_IP} ${5}
Prashanth Kattiee26d5e2021-05-21 00:38:31 -050032${bmc_url} https://${OPENBMC_HOST}
33
Prashanth Kattifa699cf2020-04-06 10:13:33 -050034
35*** Test Cases ***
36
37Test Patch Without Auth Token Fails
38 [Documentation] Send patch method without auth token and verify it throws an error.
George Keishing966a4c52020-05-13 10:53:58 -050039 [Tags] Test_Patch_Without_Auth_Token_Fails
Prashanth Kattifa699cf2020-04-06 10:13:33 -050040
Anves Kumar rayankula816d3ce2021-06-13 23:55:41 -050041 ${active_channel_config}= Get Active Channel Config
42 ${ethernet_interface}= Set Variable ${active_channel_config['${CHANNEL_NUMBER}']['name']}
43
44 Redfish.Patch ${REDFISH_NW_ETH_IFACE}${ethernet_interface} body={'HostName': '${hostname}'}
Prashanth Kattifa699cf2020-04-06 10:13:33 -050045 ... valid_status_codes=[${HTTP_UNAUTHORIZED}, ${HTTP_FORBIDDEN}]
46
47
48Flood Patch Without Auth Token And Check Stability Of BMC
49 [Documentation] Flood patch method without auth token and check BMC stability.
50 [Tags] Flood_Patch_Without_Auth_Token_And_Check_Stability_Of_BMC
George Keishing23afcc52022-04-07 03:18:08 -050051
52 @{fail_list}= Create List
Prashanth Kattifa699cf2020-04-06 10:13:33 -050053
Anves Kumar rayankula816d3ce2021-06-13 23:55:41 -050054 ${active_channel_config}= Get Active Channel Config
55 ${ethernet_interface}= Set Variable ${active_channel_config['${CHANNEL_NUMBER}']['name']}
56
George Keishing23afcc52022-04-07 03:18:08 -050057 FOR ${iter} IN RANGE ${1} ${iterations} + 1
58 Log To Console ${iter}th iteration Patch Request without valid session token
59 # Expected valid fail status response code.
60 Redfish.Patch ${REDFISH_NW_ETH_IFACE}${ethernet_interface} body={'HostName': '${hostname}'}
61 ... valid_status_codes=[${HTTP_UNAUTHORIZED}, ${HTTP_FORBIDDEN}]
Prashanth Kattifa699cf2020-04-06 10:13:33 -050062
63 # Every 100th iteration, check BMC allows patch with auth token.
George Keishing23afcc52022-04-07 03:18:08 -050064 ${status}= Run Keyword If ${iter} % 100 == 0 Run Keyword And Return Status
65 ... Login And Configure Hostname ${REDFISH_NW_ETH_IFACE}${ethernet_interface}
66 Run Keyword If ${status} == False Append To List ${fail_list} ${iter}
Prashanth Kattifa699cf2020-04-06 10:13:33 -050067 END
68 ${verify_count}= Evaluate ${iterations}/100
George Keishing23afcc52022-04-07 03:18:08 -050069 ${fail_count}= Get Length ${fail_list}
Prashanth Kattifa699cf2020-04-06 10:13:33 -050070
George Keishing23afcc52022-04-07 03:18:08 -050071 Should Be Equal As Integers ${fail_count} ${0}
72 ... msg=Patch operation failed ${fail_count} times in ${verify_count} attempts; fails at iterations ${fail_list}
Prashanth Kattifa699cf2020-04-06 10:13:33 -050073
74
George Keishing4fb89c12022-01-06 22:29:33 -060075Verify User Cannot Login After 5 Non-Logged In Sessions
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -050076 [Documentation] User should not be able to login when there
77 ... are 5 non-logged in sessions.
78 [Tags] Verify_User_Cannot_Login_After_5_Non-Logged_In_Sessions
79
George Keishing23afcc52022-04-07 03:18:08 -050080 FOR ${iter} IN RANGE ${0} ${MAX_UNAUTH_PER_IP}
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -050081 SSHLibrary.Open Connection ${OPENBMC_HOST}
82 Start Process ssh ${OPENBMC_USERNAME}@${OPENBMC_HOST} shell=True
83 END
84
85 SSHLibrary.Open Connection ${OPENBMC_HOST}
86 ${status}= Run Keyword And Return Status SSHLibrary.Login ${OPENBMC_USERNAME} ${OPENBMC_PASSWORD}
Prashanth Katti91e59712020-04-14 08:12:09 -050087
Anvesh Kumar Rayankula85df1372020-04-28 05:01:14 -050088 Should Be Equal ${status} ${False}
89
90
Prashanth Katti91e59712020-04-14 08:12:09 -050091Test Post Without Auth Token Fails
92 [Documentation] Send post method without auth token and verify it throws an error.
93 [Tags] Test_Post_Without_Auth_Token_Fails
94
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -050095 ${user_info}= Create Dictionary
96 ... UserName=test_user Password=TestPwd123 RoleId=Operator Enabled=${True}
Prashanth Katti91e59712020-04-14 08:12:09 -050097 Redfish.Post /redfish/v1/AccountService/Accounts/ body=&{user_info}
98 ... valid_status_codes=[${HTTP_UNAUTHORIZED}, ${HTTP_FORBIDDEN}]
99
100
101Flood Post Without Auth Token And Check Stability Of BMC
102 [Documentation] Flood post method without auth token and check BMC stability.
103 [Tags] Flood_Post_Without_Auth_Token_And_Check_Stability_Of_BMC
104
George Keishing23afcc52022-04-07 03:18:08 -0500105 @{fail_list}= Create List
106
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -0500107 ${user_info}= Create Dictionary
108 ... UserName=test_user Password=TestPwd123 RoleId=Operator Enabled=${True}
Prashanth Katti91e59712020-04-14 08:12:09 -0500109
George Keishing23afcc52022-04-07 03:18:08 -0500110 FOR ${iter} IN RANGE ${1} ${iterations} + 1
111 Log To Console ${iter}th iteration Post Request without valid session token
112 # Expected valid fail status response code.
113 Redfish.Post /redfish/v1/AccountService/Accounts/ body=&{user_info}
114 ... valid_status_codes=[${HTTP_UNAUTHORIZED}, ${HTTP_FORBIDDEN}]
Prashanth Katti91e59712020-04-14 08:12:09 -0500115
116 # Every 100th iteration, check BMC allows post with auth token.
George Keishing23afcc52022-04-07 03:18:08 -0500117 ${status}= Run Keyword If ${iter} % 100 == 0 Run Keyword And Return Status
Prashanth Katti91e59712020-04-14 08:12:09 -0500118 ... Login And Create User
George Keishing23afcc52022-04-07 03:18:08 -0500119 Run Keyword If ${status} == False Append To List ${fail_list} ${iter}
Prashanth Katti91e59712020-04-14 08:12:09 -0500120 END
121 ${verify_count}= Evaluate ${iterations}/100
George Keishing23afcc52022-04-07 03:18:08 -0500122 ${fail_count}= Get Length ${fail_list}
Prashanth Katti91e59712020-04-14 08:12:09 -0500123
George Keishing23afcc52022-04-07 03:18:08 -0500124 Should Be Equal As Integers ${fail_count} ${0}
125 ... msg=Post operation failed ${fail_count} times in ${verify_count} attempts; fails at iterations ${fail_list}
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -0500126
127
128Make Large Number Of Wrong SSH Login Attempts And Check Stability
129 [Documentation] Check BMC stability with large number of SSH wrong login requests.
130 [Tags] Make_Large_Number_Of_Wrong_SSH_Login_Attempts_And_Check_Stability
131 [Setup] Set Account Lockout Threshold
132 [Teardown] FFDC On Test Case Fail
133
134 SSHLibrary.Open Connection ${OPENBMC_HOST}
135 @{ssh_status_list}= Create List
George Keishing23afcc52022-04-07 03:18:08 -0500136 FOR ${iter} IN RANGE ${loop_iteration}
137 Log To Console ${iter}th iteration
138 ${invalid_password}= Catenate ${OPENBMC_PASSWORD}${iter}
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -0500139 Run Keyword and Ignore Error
140 ... Open Connection And Log In ${OPENBMC_USERNAME} ${invalid_password}
141
142 # Every 100th iteration Login with correct credentials
George Keishing23afcc52022-04-07 03:18:08 -0500143 ${status}= Run keyword If ${iter} % ${100} == ${0} Run Keyword And Return Status
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -0500144 ... Open Connection And Log In ${OPENBMC_USERNAME} ${OPENBMC_PASSWORD}
145 Run Keyword If ${status} == ${False} Append To List ${ssh_status_list} ${status}
146 SSHLibrary.Close Connection
147 END
148
149 ${valid_login_count}= Evaluate ${iterations}/100
150 ${fail_count}= Get Length ${ssh_status_list}
151 Should Be Equal ${fail_count} ${0}
152 ... msg= Login Failed ${fail_count} times in ${valid_login_count} attempts.
Prashanth Katti91e59712020-04-14 08:12:09 -0500153
154
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500155Test Stability On Large Number Of Wrong Login Attempts To GUI
156 [Documentation] Test stability on large number of wrong login attempts to GUI.
157 [Tags] Test_Stability_On_Large_Number_Of_Wrong_Login_Attempts_To_GUI
158
159 @{status_list}= Create List
160
161 # Open headless browser.
162 Start Virtual Display
163 ${browser_ID}= Open Browser ${bmc_url} alias=browser1
164 Set Window Size 1920 1080
165
166 Go To ${bmc_url}
167
George Keishing23afcc52022-04-07 03:18:08 -0500168 FOR ${iter} IN RANGE ${1} ${iterations} + 1
169 Log To Console ${iter}th login
George Keishingfef9aa92022-04-08 08:45:42 -0500170 Run Keyword And Ignore Error Login to GUI With Incorrect Credentials
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500171
172 # Every 100th iteration, check BMC GUI is responsive.
George Keishing23afcc52022-04-07 03:18:08 -0500173 ${status}= Run Keyword If ${iter} % 100 == 0 Run Keyword And Return Status
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500174 ... Open Browser ${bmc_url}
175 Append To List ${status_list} ${status}
George Keishing47d1e8e2022-02-17 10:38:49 -0600176 Run Keyword If '${status}' == 'True'
177 ... Run Keywords Close Browser AND Switch Browser browser1
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500178 END
179
180 ${fail_count}= Count Values In List ${status_list} False
181 Run Keyword If ${fail_count} > ${0} FAIL Could not open BMC GUI ${fail_count} times
182
shrsuman123b844a872021-12-21 05:49:41 -0600183Test BMC GUI Stability On Continuous Refresh Of GUI Home Page
184 [Documentation] Login to BMC GUI and keep refreshing home page and verify stability
185 ... by login at times in another browser.
186 [Tags] Test_BMC_GUI_Stability_On_Continuous_Refresh_Of_GUI_Home_Page
187 [Teardown] Close All Browsers
188
189 @{failed_list}= Create List
190
191 # Open headless browser.
192 Start Virtual Display
193 ${browser_ID}= Open Browser ${bmc_url} alias=browser1
194 Set Window Size 1920 1080
195 Login GUI
196
197 FOR ${iter} IN RANGE ${iterations}
198 Log To Console ${iter}th Refresh of home page
199
200 Refresh GUI
201 Continue For Loop If ${iter}%100 != 0
202
203 # Every 100th iteration, check BMC GUI is responsive.
204 ${status}= Run Keyword And Return Status
205 ... Run Keywords Launch Browser And Login GUI AND Logout GUI
206 Run Keyword If '${status}' == 'False' Append To List ${failed_list} ${iter}
207 ... ELSE IF '${status}' == 'True'
208 ... Run Keywords Close Browser AND Switch Browser browser1
209 END
210 Log ${failed_list}
211 ${fail_count}= Get Length ${failed_list}
212 Run Keyword If ${fail_count} > ${0} FAIL Could not open BMC GUI ${fail_count} times
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500213
shrsuman1232b8bfca2021-11-18 05:14:23 -0600214Test BMCweb Stability On Continuous Redfish Login Attempts With Invalid Credentials
215 [Documentation] Make invalid credentials Redfish login attempts continuously and
216 ... verify bmcweb stability by login to Redfish with valid credentials.
217 [Tags] Test_BMCweb_Stability_On_Continuous_Redfish_Login_Attempts_With_Invalid_Credentials
218
219 Invalid Credentials Redfish Login Attempts
220
221Test User Delete Operation Without Session Token And Expect Failure
222 [Documentation] Try to delete an object without valid session token and verifies it throws
223 ... an unauthorised error.
224 [Tags] Test_User_Delete_Operation_Without_Session_Token_And_Expect_Failure
225 [Setup] Redfish.Logout
226
227 Redfish.Delete /redfish/v1/AccountService/Accounts/test_user
228 ... valid_status_codes=[${HTTP_UNAUTHORIZED}]
229
230
231Test Bmcweb Stability On Continuous Redfish Delete Operation Request Without Session Token
232 [Documentation] Send delete object request without valid session token continuously and
233 ... verify bmcweb stability by sending delete request with valid session token.
234 [Tags] Test_Bmcweb_Stability_On_Continuous_Redfish_Delete_Operation_Request_Without_Session_Token
235
236 @{failed_iter_list}= Create List
237
238 FOR ${iter} IN RANGE ${iterations}
239 Log To Console ${iter}th Redfish Delete Object Request without valid session token
240
241 Run Keyword And Ignore Error
242 ... Redfish.Delete /redfish/v1/AccountService/Accounts/test_user
243 Continue For Loop If ${iter}%100 != 0
244
245 # Every 100th iteration, check delete operation with valid session token.
246 ${status}= Run Keyword And Return Status
247 ... Login And Delete User
248 Run Keyword If '${status}' == 'False' Append To List ${failed_iter_list} ${iter}
249 END
250 Log ${failed_iter_list}
251 ${fail_count}= Get Length ${failed_iter_list}
252 Run Keyword If ${fail_count} > ${0} FAIL Could not do Redfish delete operation ${fail_count} times
253
Prashanth Kattifa699cf2020-04-06 10:13:33 -0500254*** Keywords ***
255
256Login And Configure Hostname
257 [Documentation] Login and configure hostname
George Keishing23afcc52022-04-07 03:18:08 -0500258 [Arguments] ${ethernet_interface_uri}
Prashanth Kattifa699cf2020-04-06 10:13:33 -0500259 [Teardown] Redfish.Logout
260
George Keishing23afcc52022-04-07 03:18:08 -0500261 # Description of argument(s):
262 # ethernet_interface_uri Network interface URI path.
263
Prashanth Kattifa699cf2020-04-06 10:13:33 -0500264 Redfish.Login
265
George Keishing23afcc52022-04-07 03:18:08 -0500266 Redfish.Patch ${ethernet_interface_uri} body={'HostName': '${hostname}'}
Prashanth Kattifa699cf2020-04-06 10:13:33 -0500267 ... valid_status_codes=[${HTTP_OK}, ${HTTP_NO_CONTENT}]
268
Prashanth Katti91e59712020-04-14 08:12:09 -0500269
270Login And Create User
271 [Documentation] Login and create user
272
shrsuman1232b8bfca2021-11-18 05:14:23 -0600273 [Teardown] Run Keywords Redfish.Delete /redfish/v1/AccountService/Accounts/test_user
274 ... AND Redfish.Logout
275
276 Redfish.Login
277
278 ${user_info}= Create Dictionary
279 ... UserName=test_user Password=TestPwd123 RoleId=Operator Enabled=${True}
280 Redfish.Post /redfish/v1/AccountService/Accounts/ body=&{user_info}
281 ... valid_status_codes=[${HTTP_OK}, ${HTTP_CREATED}]
282
283Login And Delete User
284 [Documentation] Login create and delete user
285
Prashanth Katti91e59712020-04-14 08:12:09 -0500286 [Teardown] Redfish.Logout
287
288 Redfish.Login
289
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -0500290 ${user_info}= Create Dictionary
291 ... UserName=test_user Password=TestPwd123 RoleId=Operator Enabled=${True}
292 Redfish.Post /redfish/v1/AccountService/Accounts/ body=&{user_info}
shrsuman1232b8bfca2021-11-18 05:14:23 -0600293 ... valid_status_codes=[${HTTP_OK}, ${HTTP_CREATED}]
294 Redfish.Delete /redfish/v1/AccountService/Accounts/test_user
Anvesh Kumar Rayankula3cddd032020-03-26 04:16:13 -0500295
296Set Account Lockout Threshold
297 [Documentation] Set user account lockout threshold.
298
299 [Teardown] Redfish.Logout
300
301 Redfish.Login
302 Redfish.Patch /redfish/v1/AccountService body=[('AccountLockoutThreshold', 0)]
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500303
304
305Login to GUI With Incorrect Credentials
George Keishing0aeb54f2022-04-11 10:26:34 -0500306 [Documentation] Attempt to login to GUI as root, providing incorrect password argument.
Prashanth Kattiee26d5e2021-05-21 00:38:31 -0500307
308 Input Text ${xpath_textbox_username} root
309 Input Password ${xpath_textbox_password} incorrect_password
310 Click Button ${xpath_login_button}
shrsuman1232b8bfca2021-11-18 05:14:23 -0600311
312Invalid Credentials Redfish Login Attempts
313 [Documentation] Continuous invalid credentials login attempts to Redfish and
314 ... login to Redfish with valid credentials at times and get failed login attempts.
315 [Arguments] ${login_username}=${OPENBMC_USERNAME} ${login_password}=${OPENBMC_PASSWORD}
316
317 # Description of argument(s):
318 # login_username username for login user.
319 # login_password password for login user.
320
321 @{failed_iter_list}= Create List
322
323 FOR ${iter} IN RANGE ${iterations}
324 Log To Console ${iter}th Redfish login with invalid credentials
325 Run Keyword And Ignore Error Redfish.Login ${login_username} incorrect_password
326 Continue For Loop If ${iter}%100 != 0
327
328 # Every 100th iteration, check Redfish is responsive.
329 ${status}= Run Keyword And Return Status
330 ... Redfish.Login ${login_username} ${login_password}
331 Run Keyword If '${status}' == 'False' Append To List ${failed_iter_list} ${iter}
332 Redfish.Logout
333 END
334 Log ${failed_iter_list}
335 ${fail_count}= Get Length ${failed_iter_list}
336 Run Keyword If ${fail_count} > ${0} FAIL Could not Login to Redfish ${fail_count} times