From 4f154cb016079cc8e4e2f8d88896e227fac42750 Mon Sep 17 00:00:00 2001 From: Dzmitry Lemechko Date: Tue, 31 Oct 2023 13:40:25 +0100 Subject: [PATCH] [security_page] improve force logout --- .../functional/page_objects/security_page.ts | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/x-pack/test/functional/page_objects/security_page.ts b/x-pack/test/functional/page_objects/security_page.ts index 5b0a9a679840a..bb127df565ccd 100644 --- a/x-pack/test/functional/page_objects/security_page.ts +++ b/x-pack/test/functional/page_objects/security_page.ts @@ -41,6 +41,8 @@ export class SecurityPageObject extends FtrService { private readonly monacoEditor = this.ctx.getService('monacoEditor'); private readonly es = this.ctx.getService('es'); + delay = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms)); + public loginPage = Object.freeze({ login: async (username?: string, password?: string, options: LoginOptions = {}) => { if (!(await this.isLoginFormVisible())) { @@ -316,7 +318,7 @@ export class SecurityPageObject extends FtrService { await this.waitForLoginPage(); } else { this.log.debug('Waiting for logout to complete'); - await this.retry.waitFor('Waiting for logout to complete', async () => { + await this.retry.waitFor('logout to complete', async () => { // There are cases when browser/Kibana would like users to confirm that they want to navigate away from the // current page and lose the state (e.g. unsaved changes) via native alert dialog. const alert = await this.browser.getAlert(); @@ -324,12 +326,19 @@ export class SecurityPageObject extends FtrService { await alert.accept(); } + await this.retry.waitFor('URL redirects to finish', async () => { + const urlBefore = await this.browser.getCurrentUrl(); + await this.delay(1000); + const urlAfter = await this.browser.getCurrentUrl(); + return urlAfter === urlBefore; + }); + + const currentUrl = await this.browser.getCurrentUrl(); if (this.config.get('serverless')) { // Logout might trigger multiple redirects, but in the end we expect the Cloud login page - this.log.debug('Wait 5 sec for Cloud login page to be displayed'); - return await this.find.existsByDisplayedByCssSelector('.login-form-password', 5000); + return currentUrl.includes('/login') || currentUrl.includes('/projects'); } else { - return !(await this.browser.getCurrentUrl()).includes('/logout'); + return !currentUrl.includes('/logout'); } }); }