0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-13 21:30:30 -05:00

refactor(test): add expectNavigation() (#4254)

This commit is contained in:
Gao Sun 2023-07-27 16:04:28 +08:00 committed by GitHub
parent 0158e9e30c
commit a427ea05c3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 35 additions and 33 deletions

View file

@ -5,7 +5,7 @@ import {
consoleUsername, consoleUsername,
logtoConsoleUrl as logtoConsoleUrlString, logtoConsoleUrl as logtoConsoleUrlString,
} from '#src/constants.js'; } from '#src/constants.js';
import { appendPathname } from '#src/utils.js'; import { appendPathname, expectNavigation } from '#src/utils.js';
/** /**
* NOTE: This test suite assumes test cases will run sequentially (which is Jest default). * NOTE: This test suite assumes test cases will run sequentially (which is Jest default).
@ -17,23 +17,20 @@ describe('smoke testing for console admin account creation and sign-in', () => {
const logtoConsoleUrl = new URL(logtoConsoleUrlString); const logtoConsoleUrl = new URL(logtoConsoleUrlString);
it('can open with app element and navigate to welcome page', async () => { it('can open with app element and navigate to welcome page', async () => {
await page.goto(logtoConsoleUrl.href); await expectNavigation(page.goto(logtoConsoleUrl.href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toMatchElement('#app'); await expect(page).toMatchElement('#app');
expect(page.url()).toBe(new URL('console/welcome', logtoConsoleUrl).href); expect(page.url()).toBe(new URL('console/welcome', logtoConsoleUrl).href);
}); });
it('can register a new admin account and automatically sign in', async () => { it('can register a new admin account and automatically sign in', async () => {
await expect(page).toClick('button', { text: 'Create account' }); await expectNavigation(expect(page).toClick('button', { text: 'Create account' }));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
expect(page.url()).toBe(new URL('register', logtoConsoleUrl).href); expect(page.url()).toBe(new URL('register', logtoConsoleUrl).href);
await expect(page).toFill('input[name=identifier]', consoleUsername); await expect(page).toFill('input[name=identifier]', consoleUsername);
await expect(page).toClick('button[name=submit]'); await expectNavigation(expect(page).toClick('button[name=submit]'));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
expect(page.url()).toBe(appendPathname('/register/password', logtoConsoleUrl).href); expect(page.url()).toBe(appendPathname('/register/password', logtoConsoleUrl).href);
await expect(page).toFillForm('form', { await expect(page).toFillForm('form', {
@ -41,8 +38,7 @@ describe('smoke testing for console admin account creation and sign-in', () => {
confirmPassword: consolePassword, confirmPassword: consolePassword,
}); });
await expect(page).toClick('button[name=submit]'); await expectNavigation(expect(page).toClick('button[name=submit]'));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
expect(page.url()).toBe(new URL('console/get-started', logtoConsoleUrl).href); expect(page.url()).toBe(new URL('console/get-started', logtoConsoleUrl).href);
}); });
@ -53,10 +49,11 @@ describe('smoke testing for console admin account creation and sign-in', () => {
// Try awaiting for 500ms before clicking sign-out button // Try awaiting for 500ms before clicking sign-out button
await page.waitForTimeout(500); await page.waitForTimeout(500);
await expect(page).toClick( await expectNavigation(
'.ReactModalPortal div[class$=dropdownContainer] div[class$=dropdownItem]:last-child' expect(page).toClick(
'.ReactModalPortal div[class$=dropdownContainer] div[class$=dropdownItem]:last-child'
)
); );
await page.waitForNavigation({ waitUntil: 'networkidle0' });
expect(page.url()).toBe(new URL('sign-in', logtoConsoleUrl).href); expect(page.url()).toBe(new URL('sign-in', logtoConsoleUrl).href);
}); });
@ -64,14 +61,12 @@ describe('smoke testing for console admin account creation and sign-in', () => {
it('can sign in to admin console again', async () => { it('can sign in to admin console again', async () => {
const initialHref = appendPath(logtoConsoleUrl, 'console', 'applications').href; const initialHref = appendPath(logtoConsoleUrl, 'console', 'applications').href;
// Should be able to redirect back after sign-in // Should be able to redirect back after sign-in
await page.goto(initialHref); await expectNavigation(page.goto(initialHref));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toFillForm('form', { await expect(page).toFillForm('form', {
identifier: consoleUsername, identifier: consoleUsername,
password: consolePassword, password: consolePassword,
}); });
await expect(page).toClick('button[name=submit]'); await expectNavigation(expect(page).toClick('button[name=submit]'));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
expect(page.url()).toBe(initialHref); expect(page.url()).toBe(initialHref);

View file

@ -2,6 +2,7 @@ import { logtoConsoleUrl as logtoConsoleUrlString } from '#src/constants.js';
import { goToAdminConsole } from '#src/ui-helpers/index.js'; import { goToAdminConsole } from '#src/ui-helpers/index.js';
import { import {
appendPathname, appendPathname,
expectNavigation,
formatPhoneNumberToInternational, formatPhoneNumberToInternational,
generateEmail, generateEmail,
generateName, generateName,
@ -19,8 +20,7 @@ describe('user management', () => {
}); });
it('navigates to user management page on clicking sidebar menu', async () => { it('navigates to user management page on clicking sidebar menu', async () => {
await page.goto(appendPathname('/console/users', logtoConsoleUrl).href); await expectNavigation(page.goto(appendPathname('/console/users', logtoConsoleUrl).href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toMatchElement( await expect(page).toMatchElement(
'div[class$=main] div[class$=headline] div[class$=titleEllipsis]', 'div[class$=main] div[class$=headline] div[class$=titleEllipsis]',
@ -73,8 +73,7 @@ describe('user management', () => {
}); });
it('fails to create user if no identifier is provided', async () => { it('fails to create user if no identifier is provided', async () => {
await page.goto(appendPathname('/console/users', logtoConsoleUrl).href); await expectNavigation(page.goto(appendPathname('/console/users', logtoConsoleUrl).href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toClick('div[class$=main] div[class$=headline] > button'); await expect(page).toClick('div[class$=main] div[class$=headline] > button');
await expect(page).toClick('button[type=submit]'); await expect(page).toClick('button[type=submit]');
@ -84,8 +83,7 @@ describe('user management', () => {
}); });
it('fails to create user if any of the identifiers are existed', async () => { it('fails to create user if any of the identifiers are existed', async () => {
await page.goto(appendPathname('/console/users', logtoConsoleUrl).href); await expectNavigation(page.goto(appendPathname('/console/users', logtoConsoleUrl).href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
// Conflicted email // Conflicted email
await expect(page).toClick('div[class$=main] div[class$=headline] > button'); await expect(page).toClick('div[class$=main] div[class$=headline] > button');

View file

@ -1,6 +1,6 @@
import { logtoConsoleUrl as logtoConsoleUrlString } from '#src/constants.js'; import { logtoConsoleUrl as logtoConsoleUrlString } from '#src/constants.js';
import { goToAdminConsole } from '#src/ui-helpers/index.js'; import { goToAdminConsole } from '#src/ui-helpers/index.js';
import { appendPathname } from '#src/utils.js'; import { appendPathname, expectNavigation } from '#src/utils.js';
await page.setViewport({ width: 1280, height: 720 }); await page.setViewport({ width: 1280, height: 720 });
@ -22,8 +22,7 @@ describe('webhooks', () => {
}); });
it('navigates to webhooks page on clicking sidebar menu', async () => { it('navigates to webhooks page on clicking sidebar menu', async () => {
await page.goto(appendPathname('/console/webhooks', logtoConsoleUrl).href); await expectNavigation(page.goto(appendPathname('/console/webhooks', logtoConsoleUrl).href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toMatchElement( await expect(page).toMatchElement(
'div[class$=main] div[class$=headline] div[class$=titleEllipsis]', 'div[class$=main] div[class$=headline] div[class$=titleEllipsis]',
@ -52,8 +51,7 @@ describe('webhooks', () => {
}); });
it('fails to create webhook if no event is provided', async () => { it('fails to create webhook if no event is provided', async () => {
await page.goto(appendPathname('/console/webhooks', logtoConsoleUrl).href); await expectNavigation(page.goto(appendPathname('/console/webhooks', logtoConsoleUrl).href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toClick('div[class$=main] div[class$=headline] > button'); await expect(page).toClick('div[class$=main] div[class$=headline] > button');
await expect(page).toFill('input[name=name]', 'hook_name'); await expect(page).toFill('input[name=name]', 'hook_name');
@ -65,8 +63,7 @@ describe('webhooks', () => {
}); });
it('fails to create webhook if endpoint url is not an HTTPS url', async () => { it('fails to create webhook if endpoint url is not an HTTPS url', async () => {
await page.goto(appendPathname('/console/webhooks', logtoConsoleUrl).href); await expectNavigation(page.goto(appendPathname('/console/webhooks', logtoConsoleUrl).href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
await expect(page).toClick('div[class$=main] div[class$=headline] > button'); await expect(page).toClick('div[class$=main] div[class$=headline] > button');
await expect(page).toClick('span[class$=label]', { text: 'Create new account' }); await expect(page).toClick('span[class$=label]', { text: 'Create new account' });

View file

@ -3,18 +3,17 @@ import {
consoleUsername, consoleUsername,
logtoConsoleUrl as logtoConsoleUrlString, logtoConsoleUrl as logtoConsoleUrlString,
} from '#src/constants.js'; } from '#src/constants.js';
import { expectNavigation } from '#src/utils.js';
export const goToAdminConsole = async () => { export const goToAdminConsole = async () => {
const logtoConsoleUrl = new URL(logtoConsoleUrlString); const logtoConsoleUrl = new URL(logtoConsoleUrlString);
await page.goto(logtoConsoleUrl.href); await expectNavigation(page.goto(logtoConsoleUrl.href));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
if (page.url() === new URL('sign-in', logtoConsoleUrl).href) { if (page.url() === new URL('sign-in', logtoConsoleUrl).href) {
await expect(page).toFillForm('form', { await expect(page).toFillForm('form', {
identifier: consoleUsername, identifier: consoleUsername,
password: consolePassword, password: consolePassword,
}); });
await expect(page).toClick('button[name=submit]'); await expectNavigation(expect(page).toClick('button[name=submit]'));
await page.waitForNavigation({ waitUntil: 'networkidle0' });
} }
}; };

View file

@ -64,3 +64,16 @@ export const getAccessTokenPayload = (accessToken: string): Record<string, unkno
export const appendPathname = (pathname: string, baseUrl: URL) => export const appendPathname = (pathname: string, baseUrl: URL) =>
new URL(path.join(baseUrl.pathname, pathname), baseUrl); new URL(path.join(baseUrl.pathname, pathname), baseUrl);
/**
* Run an action and simultaneously wait for navigation to complete. This is
* useful for actions that trigger navigation, such as clicking a link or
* submitting a form.
*/
export const expectNavigation = async <T>(action: Promise<T>): Promise<T> => {
const [result] = await Promise.all([
action,
page.waitForNavigation({ waitUntil: 'networkidle0' }),
]);
return result;
};