From a8cb9856ca0c3cc88c5f6f05d5e877ae6a242384 Mon Sep 17 00:00:00 2001 From: Yanick Minder Date: Mon, 11 Nov 2024 15:32:38 +0100 Subject: [PATCH] introduce angular search box --- frontend/cypress/e2e/teammanagement.cy.ts | 32 +++++++------- .../helper/pom-helper/angularSearchBox.ts | 44 +++++++++++++++++++ .../pom-helper/pages/teammanagementPage.ts | 8 +--- 3 files changed, 62 insertions(+), 22 deletions(-) create mode 100644 frontend/cypress/support/helper/pom-helper/angularSearchBox.ts diff --git a/frontend/cypress/e2e/teammanagement.cy.ts b/frontend/cypress/e2e/teammanagement.cy.ts index b84fdb1d9e..9d6d05a90e 100644 --- a/frontend/cypress/e2e/teammanagement.cy.ts +++ b/frontend/cypress/e2e/teammanagement.cy.ts @@ -145,32 +145,32 @@ describe('Team management tests', () => { describe('Search', () => { it('Search user', () => { - teammanagementPage.searchTeam('pa'); - - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Paco Eggimann (peggimann@puzzle.ch)'); - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Paco Egiman (egiman@puzzle.ch)'); - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Robin Papierer (papierer@puzzle.ch)').click(); + teammanagementPage.elements + .teamSearch() + .fill('pa') + .shouldHaveOption('Paco Eggimann (peggimann@puzzle.ch)') + .shouldHaveOption('Paco Egiman (egiman@puzzle.ch)') + .selectOption('Robin Papierer (papierer@puzzle.ch)'); cy.contains('app-member-detail h2', 'Robin Papierer'); }); it('Search team', () => { - teammanagementPage.searchTeam('we are'); - - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'we are cube.³').click(); + teammanagementPage.elements.teamSearch().fill('we are').selectOption('we are cube.³'); cy.contains('app-member-list h2', 'we are cube.³'); }); it('Search mixed', () => { - teammanagementPage.searchTeam('puz'); - - cy.contains('.mat-mdc-autocomplete-panel .mat-mdc-optgroup-label', 'Members'); - cy.contains('.mat-mdc-autocomplete-panel .mat-mdc-optgroup-label', 'Teams'); - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Paco Eggimann (peggimann@puzzle.ch)'); - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Paco Egiman (egiman@puzzle.ch)'); - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Robin Papierer (papierer@puzzle.ch)'); - cy.contains('.mat-mdc-autocomplete-panel mat-option', 'Puzzle ITC'); + teammanagementPage.elements + .teamSearch() + .fill('puz') + .shouldHaveLabel('Members') + .shouldHaveLabel('Teams') + .shouldHaveOption('Paco Eggimann (peggimann@puzzle.ch)') + .shouldHaveOption('Paco Egiman (egiman@puzzle.ch)') + .shouldHaveOption('Robin Papierer (papierer@puzzle.ch)') + .shouldHaveOption('Puzzle ITC'); }); }); diff --git a/frontend/cypress/support/helper/pom-helper/angularSearchBox.ts b/frontend/cypress/support/helper/pom-helper/angularSearchBox.ts new file mode 100644 index 0000000000..f1966bc9ce --- /dev/null +++ b/frontend/cypress/support/helper/pom-helper/angularSearchBox.ts @@ -0,0 +1,44 @@ +import { PageObjectMapperBase } from './pageObjectMapperBase'; + +export default class AngularSearchBox extends PageObjectMapperBase { + selector: string; + + constructor(selector: string) { + super(); + this.selector = selector; + this.validatePage(); + } + + fill(value: string) { + const input = cy.get('input').first(); + input.clear(); + input.type(value); + return this; + } + + shouldHaveOption(option: string) { + cy.contains('.mat-mdc-autocomplete-panel mat-option', option); + return this; + } + + shouldHaveLabel(label: string) { + cy.contains('.mat-mdc-autocomplete-panel .mat-mdc-optgroup-label', label); + return this; + } + + selectOption(option: string) { + cy.contains('.mat-mdc-autocomplete-panel mat-option', option).click(); + } + + getPage() { + return cy.get(this.selector); + } + + static from(selector: string): AngularSearchBox { + return new this(selector); + } + + validatePage(): void { + this.getPage().should('exist'); + } +} diff --git a/frontend/cypress/support/helper/pom-helper/pages/teammanagementPage.ts b/frontend/cypress/support/helper/pom-helper/pages/teammanagementPage.ts index 23b956cb6e..c3f67d8884 100644 --- a/frontend/cypress/support/helper/pom-helper/pages/teammanagementPage.ts +++ b/frontend/cypress/support/helper/pom-helper/pages/teammanagementPage.ts @@ -1,5 +1,6 @@ import { Page } from './page'; import TeamDialog from '../dialogs/teamDialog'; +import AngularSearchBox from '../angularSearchBox'; export default class TeammanagementPage extends Page { elements = { @@ -10,13 +11,12 @@ export default class TeammanagementPage extends Page { memberHeader: () => cy.get('#member-header'), registerMember: () => cy.getByTestId('invite-member'), addTeam: () => cy.getByTestId('add-team'), - teamSearch: () => cy.get('app-team-management-banner').findByTestId('teamManagementSearch'), + teamSearch: () => AngularSearchBox.from('app-team-management-banner [data-testId="teamManagementSearch"]'), }; override validatePage() { this.elements.teammanagement().contains('Teamverwaltung'); this.elements.backToOverview().contains('Zurück zur OKR Übersicht'); - this.elements.teamSearch().should('exist'); this.elements.addTeam().contains('Team erfassen'); this.elements.teamMenu().contains('Alle Teams'); this.elements.memberHeader().contains('Alle Teams'); @@ -42,10 +42,6 @@ export default class TeammanagementPage extends Page { return new TeamDialog(); } - searchTeam(teamName: string): void { - this.elements.teamSearch().type(teamName); - } - getURL(): string { return 'team-management'; }