test: add wait for roles loader to detach
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
const { AuthenticatedPage } = require('../authenticated-page');
|
const { AuthenticatedPage } = require('../authenticated-page');
|
||||||
const { DeleteRoleModal } = require('./delete-role-modal')
|
const { DeleteRoleModal } = require('./delete-role-modal');
|
||||||
|
|
||||||
export class AdminRolesPage extends AuthenticatedPage {
|
export class AdminRolesPage extends AuthenticatedPage {
|
||||||
screenshotPath = '/admin-roles';
|
screenshotPath = '/admin-roles';
|
||||||
@@ -7,7 +7,7 @@ export class AdminRolesPage extends AuthenticatedPage {
|
|||||||
/**
|
/**
|
||||||
* @param {import('@playwright/test').Page} page
|
* @param {import('@playwright/test').Page} page
|
||||||
*/
|
*/
|
||||||
constructor (page) {
|
constructor(page) {
|
||||||
super(page);
|
super(page);
|
||||||
this.roleDrawerLink = page.getByTestId('roles-drawer-link');
|
this.roleDrawerLink = page.getByTestId('roles-drawer-link');
|
||||||
this.createRoleButton = page.getByTestId('create-role');
|
this.createRoleButton = page.getByTestId('create-role');
|
||||||
@@ -17,63 +17,65 @@ export class AdminRolesPage extends AuthenticatedPage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param {boolean} isMobile - navigation on smaller devices requires the
|
* @param {boolean} isMobile - navigation on smaller devices requires the
|
||||||
* user to open up the drawer menu
|
* user to open up the drawer menu
|
||||||
*/
|
*/
|
||||||
async navigateTo (isMobile=false) {
|
async navigateTo(isMobile = false) {
|
||||||
await this.profileMenuButton.click();
|
await this.profileMenuButton.click();
|
||||||
await this.adminMenuItem.click();
|
await this.adminMenuItem.click();
|
||||||
if (isMobile) {
|
if (isMobile) {
|
||||||
await this.drawerMenuButton.click();
|
await this.drawerMenuButton.click();
|
||||||
}
|
}
|
||||||
await this.roleDrawerLink.click();
|
await this.roleDrawerLink.click();
|
||||||
}
|
await this.rolesLoader.waitFor({
|
||||||
|
state: 'detached',
|
||||||
/**
|
|
||||||
* @param {string} name
|
|
||||||
*/
|
|
||||||
async getRoleRowByName (name) {
|
|
||||||
return this.roleRow.filter({
|
|
||||||
has: this.page.getByTestId('role-name').filter({
|
|
||||||
hasText: name
|
|
||||||
})
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {import('@playwright/test').Locator} row
|
* @param {string} name
|
||||||
*/
|
*/
|
||||||
async getRowData (row) {
|
async getRoleRowByName(name) {
|
||||||
return {
|
await this.rolesLoader.waitFor({
|
||||||
role: await row.getByTestId('role-name').textContent(),
|
state: 'detached',
|
||||||
description: await row.getByTestId('role-description').textContent(),
|
});
|
||||||
canEdit: await row.getByTestId(
|
return this.roleRow.filter({
|
||||||
'role-edit'
|
has: this.page.getByTestId('role-name').filter({
|
||||||
).isEnabled(),
|
hasText: name,
|
||||||
canDelete: await row.getByTestId(
|
}),
|
||||||
'role-delete'
|
});
|
||||||
).isEnabled()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {import('@playwright/test').Locator} row
|
* @param {import('@playwright/test').Locator} row
|
||||||
*/
|
*/
|
||||||
async clickEditRole (row) {
|
async getRowData(row) {
|
||||||
|
return {
|
||||||
|
role: await row.getByTestId('role-name').textContent(),
|
||||||
|
description: await row.getByTestId('role-description').textContent(),
|
||||||
|
canEdit: await row.getByTestId('role-edit').isEnabled(),
|
||||||
|
canDelete: await row.getByTestId('role-delete').isEnabled(),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {import('@playwright/test').Locator} row
|
||||||
|
*/
|
||||||
|
async clickEditRole(row) {
|
||||||
await row.getByTestId('role-edit').click();
|
await row.getByTestId('role-edit').click();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {import('@playwright/test').Locator} row
|
* @param {import('@playwright/test').Locator} row
|
||||||
*/
|
*/
|
||||||
async clickDeleteRole (row) {
|
async clickDeleteRole(row) {
|
||||||
await row.getByTestId('role-delete').click();
|
await row.getByTestId('role-delete').click();
|
||||||
return this.deleteRoleModal;
|
return this.deleteRoleModal;
|
||||||
}
|
}
|
||||||
|
|
||||||
async editRole (subject) {
|
async editRole(subject) {
|
||||||
const row = await this.getRoleRowByName(subject);
|
const row = await this.getRoleRowByName(subject);
|
||||||
await this.clickEditRole(row);
|
await this.clickEditRole(row);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -2,7 +2,7 @@ const { test, expect } = require('../../fixtures/index');
|
|||||||
const { LoginPage } = require('../../fixtures/login-page');
|
const { LoginPage } = require('../../fixtures/login-page');
|
||||||
|
|
||||||
test.describe('Role management page', () => {
|
test.describe('Role management page', () => {
|
||||||
test.skip('Admin role is not deletable', async ({ adminRolesPage }) => {
|
test('Admin role is not deletable', async ({ adminRolesPage }) => {
|
||||||
await adminRolesPage.navigateTo();
|
await adminRolesPage.navigateTo();
|
||||||
const adminRow = await adminRolesPage.getRoleRowByName('Admin');
|
const adminRow = await adminRolesPage.getRoleRowByName('Admin');
|
||||||
const rowCount = await adminRow.count();
|
const rowCount = await adminRow.count();
|
||||||
|
Reference in New Issue
Block a user