-
Notifications
You must be signed in to change notification settings - Fork 66
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix flaky Access control test (#261)
Fixed flaky test by changing the way to access Access Control Page and add some test ids of Add Rules buttons. Temporary removed tests for Firefox and webkit(safari)
- Loading branch information
1 parent
0b892c0
commit e8d57c3
Showing
7 changed files
with
129 additions
and
55 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
import { Page, test, expect } from "@playwright/test"; | ||
|
||
export class AccessControlPage { | ||
private readonly accessControlUrl = 'http://localhost:3000/acls' | ||
private readonly defaulAccessControl = this.page.getByRole('cell', { name: 'Default' }) | ||
private readonly deleteButton = this.page.getByRole('button', { name: 'Delete' }) | ||
private readonly deleteModal = this.page.getByTestId('confirm-delete-modal-title') | ||
private readonly confirmButton = this.page.getByRole('button', { name: 'OK' }) | ||
private readonly addRulesButton = this.page.getByTestId('add-rule-empty-state-button') | ||
|
||
constructor(private readonly page: Page) {} | ||
|
||
async openAccessControlPage() { | ||
await test.step('Open Access Control page', async () => { | ||
await this.page.goto(this.accessControlUrl); | ||
}) | ||
} | ||
|
||
async assertDefaultAccessCotrolIsCreated() { | ||
await test.step('Assert that default cotrol access is created', async () => { | ||
await expect(this.defaulAccessControl).toBeVisible(); | ||
}) | ||
} | ||
|
||
async pressDeleteButton() { | ||
await test.step('Press delete button', async () => { | ||
await this.deleteButton.click(); | ||
}) | ||
} | ||
|
||
async assertDeleteModalIsVisibile() { | ||
await test.step('Assert access control deletion modal is visible', async () => { | ||
await expect(this.deleteModal).toBeVisible(); | ||
}) | ||
} | ||
|
||
async pressConfirmButton() { | ||
await test.step('Press confirm button on access control deletion modal', async () => { | ||
await this.confirmButton.click(); | ||
}) | ||
} | ||
|
||
async assertDefaultAccessCotrolIsDeleted() { | ||
await test.step('Assert default access control should be deleted', async () => { | ||
await expect(this.defaulAccessControl).not.toBeVisible(); | ||
}) | ||
} | ||
|
||
async assertAddRuleButtonIsVisile() { | ||
await test.step('Assert Add Rules button is visible', async () => { | ||
await expect(this.addRulesButton).toBeVisible(); | ||
}) | ||
} | ||
} | ||
|
||
export default AccessControlPage; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import { Page, test, expect} from "@playwright/test"; | ||
|
||
export class LoginPage { | ||
private readonly localUrl = 'http://localhost:3000/' | ||
private readonly usernameField = this.page.getByPlaceholder('username@domain') | ||
private readonly nextButton = this.page.getByRole('button', { name: 'next' }) | ||
private readonly passwordField = this.page.getByLabel('Password') | ||
private readonly skipButton = this.page.getByRole('button', { name: 'skip' }); | ||
private readonly netBirdLogo = this.page.getByRole('link', { name: 'logo' }) | ||
|
||
constructor(private readonly page: Page) {} | ||
|
||
async doLogin() { | ||
await test.step('Login to local enviroment', async () => { | ||
await this.page.goto(this.localUrl); | ||
await this.usernameField.fill('admin@localhost'); | ||
await this.pressNextButton(); | ||
await this.passwordField.fill('testMe123@'); | ||
await this.pressNextButton(); | ||
if (await this.skipButton.isVisible({ timeout: 300 })) { | ||
await this.skipButton.click(); | ||
} | ||
await expect(this.netBirdLogo).toBeVisible(); | ||
}) | ||
} | ||
|
||
async pressNextButton() { | ||
await test.step('Press next button', async () => { | ||
await this.nextButton.click(); | ||
}) | ||
} | ||
} | ||
|
||
export default LoginPage; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,33 +1,22 @@ | ||
import { test, expect } from '@playwright/test'; | ||
import {AddPeerModal} from '../pages/modals/add-peer-modal' | ||
import {TopMenu} from '../pages/top-menu'; | ||
import { test } from '@playwright/test' | ||
import {LoginPage} from '../pages/login-page' | ||
import {AccessControlPage} from '../pages/access-control-page' | ||
|
||
const URL = 'https://app.netbird.io/' | ||
const localUrl = 'http://localhost:3000/' | ||
let addPeerModal: AddPeerModal; | ||
let topMenu: TopMenu; | ||
let loginPage: LoginPage | ||
let accessControlPage: AccessControlPage | ||
|
||
test.beforeEach(async ({ page }) => { | ||
addPeerModal = new AddPeerModal(page); | ||
await page.goto(localUrl); | ||
await page.getByPlaceholder('username@domain').fill('admin@localhost'); | ||
await page.getByRole('button', { name: 'next' }).click(); | ||
await page.getByLabel('Password').fill('testMe123@'); | ||
await page.getByRole('button', { name: 'next' }).click(); | ||
const skipButton = page.getByRole('button', { name: 'skip' }); | ||
if (await skipButton.isVisible({ timeout: 300 })) { | ||
await skipButton.click(); | ||
} | ||
await addPeerModal.assertPeerModalIsVisible(); | ||
loginPage = new LoginPage(page); | ||
await loginPage.doLogin(); | ||
}); | ||
|
||
test('Confirm that new user has Default access', async ({ page }) => { | ||
topMenu = new TopMenu(page); | ||
await addPeerModal.closeAddPeerModal(); | ||
await addPeerModal.assertPeerModalIsNotVisible(); | ||
await topMenu.clickOnAccessControlOnTopMenu(); | ||
await expect(page.getByRole('cell', { name: 'Default' })).toBeVisible(); | ||
await page.getByRole('button', { name: 'Delete' }).click(); | ||
await expect(page.getByTestId('confirm-delete-modal-title')).toBeVisible(); | ||
await page.getByRole('button', { name: 'Cancel' }).click(); | ||
accessControlPage = new AccessControlPage(page); | ||
await accessControlPage.openAccessControlPage(); | ||
await accessControlPage.assertDefaultAccessCotrolIsCreated(); | ||
await accessControlPage.pressDeleteButton(); | ||
await accessControlPage.assertDeleteModalIsVisibile(); | ||
await accessControlPage.pressConfirmButton(); | ||
await accessControlPage.assertDefaultAccessCotrolIsDeleted(); | ||
await accessControlPage.assertAddRuleButtonIsVisile(); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters