mirror of
https://github.com/rocky-linux/os-autoinst-distri-rocky.git
synced 2024-11-22 05:01:25 +00:00
FreeIPA: handle unexpected auto-login to webUI
There are cases where we get logged back into the FreeIPA web UI automatically by a stale kerberos ticket or something. If we're logged in as the *right* user, let's just treat this as a soft failure and continue with the test. Signed-off-by: Adam Williamson <awilliam@redhat.com>
This commit is contained in:
parent
46a41d8d67
commit
669df14566
@ -34,17 +34,27 @@ sub add_user {
|
|||||||
# it's at a console ready to start Firefox.
|
# it's at a console ready to start Firefox.
|
||||||
sub start_webui {
|
sub start_webui {
|
||||||
my ($user, $password) = @_;
|
my ($user, $password) = @_;
|
||||||
|
# if we logged in as 'admin' we should land on the admin 'Active
|
||||||
|
# users' screen, otherwise we should land on the user's own page
|
||||||
|
my $user_screen = "freeipa_webui_user";
|
||||||
|
$user_screen = "freeipa_webui_users" if ($user eq 'admin');
|
||||||
|
|
||||||
# https://bugzilla.redhat.com/show_bug.cgi?id=1439429
|
# https://bugzilla.redhat.com/show_bug.cgi?id=1439429
|
||||||
assert_script_run "sed -i -e 's,enable_xauth=1,enable_xauth=0,g' /usr/bin/startx";
|
assert_script_run "sed -i -e 's,enable_xauth=1,enable_xauth=0,g' /usr/bin/startx";
|
||||||
type_string "startx /usr/bin/firefox -width 1024 -height 768 https://ipa001.domain.local\n";
|
type_string "startx /usr/bin/firefox -width 1024 -height 768 https://ipa001.domain.local\n";
|
||||||
wait_still_screen 5;
|
wait_still_screen 5;
|
||||||
assert_screen "freeipa_webui_login";
|
# softfail on kerberos ticket bugs meaning we get auto-logged in
|
||||||
type_safely $user;
|
# as the requested user when we don't expect to be
|
||||||
wait_screen_change { send_key "tab"; };
|
if (check_screen $user_screen, 5) {
|
||||||
type_safely $password;
|
record_soft_failure "already logged in to web UI";
|
||||||
send_key "ret";
|
}
|
||||||
# if we logged in as 'admin' we should land on the admin 'Active
|
else {
|
||||||
# users' screen, otherwise we should land on the user's own page
|
assert_screen "freeipa_webui_login", 5;
|
||||||
$user eq 'admin' ? assert_screen "freeipa_webui_users" : assert_screen "freeipa_webui_user";
|
type_safely $user;
|
||||||
|
wait_screen_change { send_key "tab"; };
|
||||||
|
type_safely $password;
|
||||||
|
send_key "ret";
|
||||||
|
assert_screen $user_screen;
|
||||||
|
}
|
||||||
wait_still_screen 3;
|
wait_still_screen 3;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user