@digital-ai/devops-page-object-release 0.0.82 → 0.0.84
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/dist/main.js +87 -2
- package/dist/main.js.map +1 -1
- package/dist/module.js +87 -2
- package/dist/module.js.map +1 -1
- package/dist/types.d.ts +9 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +3 -3
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":"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","sources":["apps/release/pages/WithPage.ts","apps/release/pages/releases/releaseCreatePage.ts","apps/release/pages/ReleaseHeaderPage.ts","apps/release/pages/ReleasesListPage.ts","apps/release/pages/TriggersPage.ts","apps/release/pages/helper/index.ts","apps/release/pages/common/dateUtil.ts","apps/release/pages/variablePage.ts","apps/release/pages/task-drawer/taskActivity.ts","apps/release/pages/task-drawer/taskAttachments.ts","apps/release/pages/task-drawer/taskAttribute.ts","apps/release/pages/task-drawer/taskCondition.ts","apps/release/pages/task-drawer/taskConfig.ts","apps/release/pages/task-drawer/taskOverview.ts","apps/release/pages/task-drawer/taskScheduling.ts","apps/release/pages/task-drawer/taskHistory.ts","apps/release/pages/task-drawer/taskDrawer.ts","apps/release/pages/releases/releaseGanttPage.ts","apps/release/pages/releases/releasePropertiesPage.ts","apps/release/pages/releases/releaseTeamsAndPermissionsPage.ts","apps/release/pages/releases/releaseTableViewPage.ts","apps/release/pages/common/util.ts","apps/release/pages/releases/ReleasePage.ts","apps/release/pages/ApplicationsPage.ts","apps/release/pages/common/dataRandomGenerator.ts","apps/release/pages/folder/folderDeliveryPage.ts","apps/release/pages/folder/folderGroupPage.ts","apps/release/types/index.ts","apps/release/pages/folder/folderPatternPage.ts","apps/release/pages/folder/folderNotificationPage.ts","apps/release/pages/FolderPage.ts","apps/release/pages/globalVariablePage.ts","apps/release/pages/homePage.ts","apps/release/pages/headerPage.ts","apps/release/pages/managePluginsPage.ts","apps/release/pages/PersonalAccessTokenPage.ts","apps/release/pages/personalSettingsPage.ts","apps/release/pages/users/userModal.ts","apps/release/pages/users/usersPage.ts","apps/release/pages/workflowCatalogPage.ts","apps/release/pages/settingsMenu.ts","apps/release/pages/taskDetails.ts","apps/release/pages/ReleaseCalendarPage.ts","apps/release/pages/ReleaseGroupPage.ts","apps/release/pages/ReleaseGroupTimelinePage.ts","apps/release/pages/releases/ReleaseVariablesPage.ts","apps/release/pages/tasks/taskListPage.ts","apps/release/pages/templates/templatePropertiesPage.ts","apps/release/pages/templates/templateCreatePage.ts","apps/release/pages/templates/templateTriggerPage.ts","apps/release/pages/templates/templateVaraiablePage.ts","apps/release/pages/templates/templatePage.ts","apps/release/pages/templateListPage.ts","apps/release/pages/users/rolesModal.ts","apps/release/pages/users/rolesPage.ts","apps/release/pages/systemSettings/risksProfilePage.ts","apps/release/pages/systemSettings/advancedSettingsPage.ts","apps/release/pages/systemSettings/experimentalSettingsPage.ts","apps/release/pages/systemSettings/taskSettingsPage.ts","apps/release/pages/systemSettings/reportsSettingsPage.ts","apps/release/pages/systemSettings/releaseAndTriggersPage.ts","apps/release/pages/notificationPage.ts","apps/release/pages/systemSettings/notificationSettingsPage.ts","apps/release/pages/systemSettingsPage.ts","apps/release/pages/connectionsPage.ts","apps/release/pages/tasks/taskAccessPage.ts","apps/release/pages/index.ts","apps/release/pages/login-page.ts","apps/release/fixtures/helper.ts","apps/release/fixtures/index.ts","apps/release/index.ts"],"sourcesContent":["import { Page } from '@playwright/test';\n\nexport class WithPage {\n protected readonly page: Page;\n\n constructor(page: Page) {\n this.page = page;\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ReleaseCreatePage extends WithPage {\n releaseForm: Locator;\n\n constructor(page: Page) {\n super(page);\n this.releaseForm = this.page.locator('#release-properties .form-group');\n }\n\n async setName(releaseName: string): Promise<void> {\n await this.page.locator('#release-form-title').click();\n await this.page.locator('#release-form-title').fill(releaseName);\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.release-description').hover();\n await this.page.locator('.display').filter({ hasText: 'Set description' }).locator('.edit-icon').click();\n await this.page.locator('textarea').click();\n await this.page.locator('textarea').clear();\n await this.page.locator('textarea').fill(description);\n await this.page.getByText('Save', { exact: true }).click();\n }\n\n async setOwner(ownerName: string): Promise<void> {\n await this.page.locator('.release-owner').click();\n await this.page.locator('input[name=\"owner\"]').fill(ownerName);\n }\n\n async create(): Promise<void> {\n await this.page.getByRole('button', { name: 'Create' }).waitFor({ state: 'visible' });\n await this.page.getByRole('button', { name: 'Create' }).click();\n }\n\n async expectVariablesCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.variable-editor .form-group')).toHaveCount(count);\n }\n\n async expectContainingVariable(variableName: string, value: string): Promise<void> {\n await expect(this.page.locator(`#form-${variableName} .text span`)).toContainText(value);\n }\n\n async selectTemplate(templateName: string): Promise<void> {\n await this.page.getByPlaceholder('No template').click();\n await this.page.getByPlaceholder('No template').clear();\n await this.page.getByPlaceholder('No template').fill(templateName);\n await this.page.getByText(templateName).click();\n }\n\n async removeTemplate(): Promise<void> {\n await this.page.locator('.template-select .close-icon').click();\n }\n\n async setValueForVariables(variableName: string, value: string): Promise<void> {\n await this.page.locator(`#form-${variableName} .display`).click();\n await this.page.locator(`input[name=\"${variableName}\"]`).fill(value);\n await this.page.locator(`input[name=\"${variableName}\"]`).blur();\n }\n\n async setVariable(variable: string, value: string): Promise<void> {\n await this.releaseForm.filter({ hasText: variable }).locator('div[inline-text-editor]').click();\n await this.releaseForm.filter({ hasText: variable }).locator('div[inline-text-editor] input').fill(value);\n await this.releaseForm.filter({ hasText: variable }).locator('div[inline-text-editor] input').blur();\n }\n\n async resetVariableValues(): Promise<void> {\n await this.page.locator('button', { hasText: 'Reset to defaults' }).click();\n await this.page.locator('button', { hasText: 'Reset variables' }).click();\n await expect(this.page.locator('button', { hasText: 'Reset to defaults' })).toBeDisabled();\n }\n\n async clickOnPrefillVariables(): Promise<void> {\n await this.page.getByText('Pre-fill variable values from previous releases').click();\n }\n\n async selectPreviousRelease(releaseName: string): Promise<void> {\n await this.page.locator('button', { hasText: 'Select release' }).click();\n await this.page.locator('a', { hasText: releaseName }).click();\n }\n\n async expectPrefillWarning(message: string): Promise<void> {\n await expect(this.page.getByText(message)).toBeVisible();\n }\n}\n","import { expect, Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleasesHeaderPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n getHeaderSelector(): string {\n return '.release-list-header';\n }\n\n getBaseDrawerSelector(): string {\n return `${this.getHeaderSelector()} .releases-filter-drawer`;\n }\n\n getFilterDrawerSelector(): string {\n return `${this.getBaseDrawerSelector()} div[role=\"dialog\"]`;\n }\n\n getStatusInputSelector(): string {\n return `${this.getBaseDrawerSelector()} input#release-status-filter-autocomplete`;\n }\n\n getBasePopperSelector(): string {\n return '.dot-popper[role=\"presentation\"]';\n }\n\n getSelectAllStatusesButtonSelector(): string {\n return `${this.getBasePopperSelector()} button[data-testid=\"dot-action-item-btn\"]`;\n }\n\n getTitleInputSelector(): string {\n return `${this.getHeaderSelector()} input#title-filter`;\n }\n\n getRiskLevelInputSelector(): string {\n return `${this.getBaseDrawerSelector()} input#risk`;\n }\n\n async setReleaseStatusFilter(statuses: string[]): Promise<this> {\n for (const status of statuses) {\n await this.page.locator(this.getStatusInputSelector()).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li`).filter({ hasText: status }).click();\n }\n return this;\n }\n\n async setReleaseTagsFilter(tags: string[]): Promise<this> {\n for (const tag of tags) {\n await this.page.locator(`${this.getBaseDrawerSelector()} input#release-tags`).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li`).filter({ hasText: tag.toLowerCase() }).click();\n }\n return this;\n }\n\n async setTaskTagsFilter(tags: string[]): Promise<this> {\n for (const tag of tags) {\n await this.page.locator(`${this.getBaseDrawerSelector()} input#task-tags`).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li`).filter({ hasText: tag.toLowerCase() }).click();\n }\n return this;\n }\n\n async setRiskLevelFilter(riskLevel: string): Promise<this> {\n await this.page.locator(this.getRiskLevelInputSelector()).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li:has-text(\"${riskLevel}\")`).click({ force: true });\n return this;\n }\n\n async filterReleaseByTitle(releaseTitle: string): Promise<void> {\n await this.page.locator(this.getTitleInputSelector()).fill(releaseTitle);\n }\n\n async clearTitleFilter(): Promise<this> {\n await this.page.locator(this.getTitleInputSelector()).fill('');\n return this;\n }\n\n async openFilterDrawer(): Promise<this> {\n await this.page.locator(`${this.getHeaderSelector()} button`, { hasText: 'Filters' }).click();\n await expect(this.page.locator(this.getFilterDrawerSelector())).toBeVisible();\n return this;\n }\n\n async closeFilterDrawer(): Promise<this> {\n await this.page.locator(`${this.getBaseDrawerSelector()} .dot-icon-btn[data-testid=\"close-btn\"]`).click();\n await expect(this.page.locator(this.getFilterDrawerSelector())).not.toBeVisible();\n return this;\n }\n\n async clearAllFilters(): Promise<this> {\n await this.page\n .locator(`${this.getHeaderSelector()} .release-list-filter-row button[data-testid=\"clear-all-btn\"]`)\n .click();\n return this;\n }\n\n async clearAllStatusFilters(): Promise<this> {\n await this.page.locator(this.getStatusInputSelector()).click();\n await this.page\n .locator(`${this.getBaseDrawerSelector()} div.filter-release-status-autocomplete button[title=\"Clear\"]`)\n .click();\n return this;\n }\n\n async selectAllStatusFilters(): Promise<this> {\n await this.page.locator(this.getStatusInputSelector()).click();\n await this.page.locator(this.getSelectAllStatusesButtonSelector()).click();\n return this;\n }\n\n async gotoListView(): Promise<void> {\n await this.clickOnReleasesPageTab('Releases');\n await expect(this.page.locator('.release-list')).toBeVisible();\n }\n\n async gotoCalendarView(): Promise<void> {\n await this.clickOnReleasesPageTab('Calendar');\n await expect(this.page.locator('.tl-viewport')).toBeVisible();\n }\n\n async clickOnReleasesPageTab(tabName: 'Releases' | 'Archive' | 'Calendar'): Promise<this> {\n await this.page.locator('releases-tabs .dot-tab-label').filter({ hasText: tabName }).click();\n return this;\n }\n\n async toggleFilterFlaggedOnly(): Promise<this> {\n await this.page\n .locator(`${this.getBaseDrawerSelector()} .flagged-releases-switch input[aria-label=\"Flagged releases\"]`)\n .click();\n return this;\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { ReleasePage } from './releases/ReleasePage';\nimport { ReleaseCreatePage } from './releases/releaseCreatePage';\nimport { ReleasesHeaderPage } from './ReleaseHeaderPage';\n\nexport class ReleasesListPage extends ReleasesHeaderPage {\n releaseCreatePage: ReleaseCreatePage;\n buttonNewRelease: Locator;\n constructor(page: Page) {\n super(page);\n this.releaseCreatePage = new ReleaseCreatePage(page);\n this.buttonNewRelease = page.locator('.action-toolbar-actions button').filter({ hasText: 'New release' });\n }\n\n async expectNumberOfReleases(releaseTitle: string, amount: number): Promise<void> {\n await this.filterReleaseByTitle(releaseTitle);\n if (amount === 1) {\n await expect(this.page.locator('.release').getByText(releaseTitle)).toBeVisible({ timeout: 5000 });\n } else {\n expect(await this.page.locator('.release').getByText(releaseTitle).count()).toBe(amount);\n }\n }\n\n async expectReleaseStarted(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Planned' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseStatusInProgress(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'In progress' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseAborted(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Aborted' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseFailed(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Failed' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseFailing(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Failing' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseCompleted(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Completed' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectRedirectToReleasesList(): Promise<void> {\n await expect(this.page.getByLabel('breadcrumb').getByText('Releases')).toBeVisible();\n await expect(this.page.locator('.release-list')).toBeVisible();\n }\n\n async openReleaseByName(releaseTitle: string): Promise<ReleasePage> {\n await this.page.locator('.release-line .row-wrapper .release-title-wrapper a', { hasText: releaseTitle }).click();\n return new ReleasePage(this.page);\n }\n\n async createNewRelease(releaseName: string, description: string): Promise<void> {\n await this.releaseCreatePage.setName(releaseName);\n await this.releaseCreatePage.setDescription(description);\n await this.releaseCreatePage.create();\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n\n async createNewReleaseWithOwner(releaseName: string, description: string, ownerName: string): Promise<void> {\n await this.releaseCreatePage.setName(releaseName);\n await this.releaseCreatePage.setDescription(description);\n await this.releaseCreatePage.setOwner(ownerName);\n await this.releaseCreatePage.create();\n }\n\n async openReleasesList(): Promise<this> {\n await this.page.goto('./#/releases');\n await expect(this.page.locator('.release-list')).toBeVisible();\n return this;\n }\n\n async clickReleaseOptions(releaseTitle: string): Promise<this> {\n await this.page\n .locator('.release-line')\n .filter({ hasText: releaseTitle })\n .locator('.options-icon')\n .click({ force: true });\n return this;\n }\n\n async clickAddToRelease(): Promise<this> {\n const addToGroupLink = this.page.locator('a:has-text(\"Add to group\")');\n await expect(addToGroupLink).toBeVisible();\n await addToGroupLink.click({ force: true });\n return this;\n }\n\n async checkAddDisabled(): Promise<this> {\n await expect(this.page.locator('.modal-footer .primary')).toBeDisabled();\n return this;\n }\n\n async selectReleaseGroup(rgTitle: string): Promise<this> {\n await this.page.locator('.ui-autocomplete-input').click({ force: true });\n await this.page.locator('.ui-autocomplete-input').fill(rgTitle);\n await this.page.locator('.ui-autocomplete-input').press('Backspace');\n await this.page.locator('li').filter({ hasText: rgTitle }).click();\n return this;\n }\n\n async clickAddToReleaseGroup(): Promise<this> {\n await expect(this.page.locator('.modal-footer .primary')).toBeVisible();\n await this.page.locator('.modal-footer .primary').click();\n return this;\n }\n}\n","import { expect } from '@playwright/test';\nimport { ReleasesListPage } from './ReleasesListPage';\nimport { WithPage } from './WithPage';\n\nexport class TriggersPage extends WithPage {\n async openRelatedReleasesOf(title: string): Promise<ReleasesListPage> {\n await this.openContextMenu(title);\n await this.page.locator('.popover-content xlr-context-menu a', { hasText: 'View releases' }).click();\n return new ReleasesListPage(this.page);\n }\n\n private async openContextMenu(title: string): Promise<void> {\n await expect(async () => {\n await this.page.locator('.trigger-row-content', { hasText: title }).locator('.context-menu-button').click();\n await expect(this.page.locator('.popover-content')).toBeVisible();\n }).toPass();\n }\n}\n","import { Locator } from '@playwright/test';\n\ntype WaitForRes = [locatorIndex: number, locator: Locator];\nexport async function waitForOneOf(locators: Locator[]): Promise<WaitForRes> {\n const res = await Promise.all([\n ...locators.map(async (locator, index): Promise<WaitForRes> => {\n let timedOut = false;\n await locator.waitFor({ state: 'visible', timeout: 2000 }).catch(() => (timedOut = true));\n return [timedOut ? -1 : index, locator];\n }),\n ]);\n const resolvedLocator = res.find((r) => r[0] !== -1);\n if (!resolvedLocator) {\n console.warn('waitForOneOf', res);\n throw new Error('no locator visible before timeout');\n }\n return resolvedLocator;\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport moment from 'moment';\n\nexport class DateUtil extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async openDatePicker(selector: string): Promise<void> {\n await this.page.locator(`${selector} .date`).click();\n }\n\n /**\n * Setting date, month and year from calendar picker\n */\n async setDate(date?: string, monthYear?: string): Promise<void> {\n const prev = this.page.locator('.datepicker-days .prev');\n const next = this.page.locator('.datepicker-days .next');\n const monYear = this.page.locator('.datepicker-days .datepicker-switch');\n\n const currentYear = await monYear.textContent();\n const thisMonth = moment(monthYear, 'MMMM YYYY').isBefore(currentYear);\n while ((await monYear.textContent()) != monthYear) {\n if (thisMonth) {\n await prev.click();\n } else {\n await next.click();\n }\n }\n await this.page\n .getByRole('cell', { name: '' + date + '', exact: true })\n .first()\n .click();\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.page.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async setDuration(days?: string, hours?: string, mins?: string): Promise<void> {\n if (typeof days !== 'undefined') {\n await this.page.locator('.days').fill(days);\n }\n if (typeof hours !== 'undefined') {\n await this.page.locator('.hours').fill(hours);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.minutes').fill(mins);\n }\n await this.page.keyboard.press('Enter');\n }\n\n async expectTimeToBe(selector: Locator, format: string, date: Date | string): Promise<void> {\n if (typeof date === 'string') {\n date = new Date(date);\n }\n const formattedDate = moment(date).format(format);\n await expect(selector).toBeVisible();\n const value = await selector.inputValue();\n expect(value).toBe(formattedDate);\n }\n\n /**\n *\n * @returns Getting current month and year in the format \"MonthName YYYY\"\n */\n async getCurrentMonthYear(): Promise<string> {\n const monthNames = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December',\n ];\n const d = new Date();\n const month = monthNames[d.getMonth()];\n const year = d.getFullYear();\n return `${month} ${year}`;\n }\n\n /**\n *\n * @returns Getting current date in the format \"dd MonthName YYYY\"\n */\n async getCurrentDate(): Promise<string> {\n const d = new Date();\n const date = d.getDate();\n const monthYear = await this.getCurrentMonthYear();\n return `${date} ${monthYear}`;\n }\n\n /**\n *\n * @param days Number of days to add to current date within the current month\n * @returns\n */\n async getFutureDate(days: number): Promise<string> {\n const d = new Date();\n d.setDate(d.getDate() + days);\n const date = d.getDate();\n const monthYear = await this.getCurrentMonthYear();\n return `${date} ${monthYear}`;\n }\n\n async removeDate(selector: Locator): Promise<void> {\n return await selector.locator(`.remove`).click();\n }\n async expectDateNotDeletable(selector: Locator): Promise<void> {\n await expect(selector.locator(`.remove`)).not.toBeVisible();\n }\n\n async expectDateToBe(selector: Locator, date: Date | string): Promise<void> {\n return await this.expectInputContainingDate(selector, date);\n }\n\n async expectDateToBeInferred(selector: Locator): Promise<void> {\n await expect(selector.locator(`input.light-text`).first()).toBeVisible();\n }\n\n async expectNoDate(selector: Locator): Promise<void> {\n expect(selector.locator(`.date-placeholder`)).toBeVisible();\n }\n\n async expectInputContainingDate(inputLocator: Locator, date: Date | string): Promise<void> {\n await expect(inputLocator).toBeVisible();\n\n const attribute = await inputLocator.getAttribute('value');\n\n expect(attribute).toContain(date);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { waitForOneOf } from './helper';\nimport { DateUtil } from './common/dateUtil';\n\ntype ExpectWithLocator = (l: Locator) => void;\n\nexport class VariablePage extends WithPage {\n addListValue: Locator;\n addVariableValue: Locator;\n listAddButton: Locator;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.addListValue = this.page.locator('.variable-selector .xl-components-input-full input');\n this.addVariableValue = this.page.locator('.variable-value .xl-components-input-full input');\n this.dateUtil = new DateUtil(page);\n this.listAddButton = this.page.getByRole('button', { name: 'Add' });\n }\n\n async openVariable(variableKey: string): Promise<VariableModal> {\n await this.page.locator(`.variables-list .variable`).getByText(variableKey).click();\n return new VariableModal(this.page);\n }\n\n async addNewVariable(variableName: string, labelname: string, description?: string): Promise<void> {\n await this.page.locator('button', { hasText: 'New variable' }).click();\n await this.page.fill(`[name=\"fieldKey\"]`, variableName);\n await this.page.locator('.variable-label input').fill(labelname);\n if (description) await this.page.locator('.variable-description input').fill(description);\n }\n\n async addNewVariableInFolder(variableName: string, labelname: string, description?: string): Promise<void> {\n await this.page.locator('button', { hasText: 'New folder variable' }).click();\n await this.page.fill(`[name=\"fieldKey\"]`, variableName);\n await this.page.locator('.variable-label input').fill(labelname);\n if (description) await this.page.locator('.variable-description input').fill(description);\n }\n\n async selectVariableTextType(valueName: string, multiline?: boolean): Promise<void> {\n await this.page.getByRole('combobox').selectOption('StringVariable');\n if (multiline) {\n await this.clickMultiline();\n await this.page.locator('.variable-value textarea').fill(valueName);\n } else await this.page.locator('.variable-value input').fill(valueName);\n }\n\n async selectVariableListboxType(\n possiblevalue: Array<string> | string,\n defaultValue: string,\n required?: true,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n await this.addListValue.fill(value);\n await this.listAddButton.click();\n }\n } else {\n await this.addListValue.fill(possiblevalue);\n await this.listAddButton.click();\n }\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n }\n }\n\n async selectVariablePasswordType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('PasswordStringVariable');\n await this.page.locator('input[type=\"password\"]').type(possiblevalue);\n }\n\n async selectVariableCheckboxType(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('BooleanVariable');\n await this.page.getByRole('checkbox').check();\n }\n\n async selectVariableNumberType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('IntegerVariable');\n await this.page.locator('input[ng-model=\"var.value\"]').fill(possiblevalue);\n }\n\n async selectVariableMultiListType(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MultiSelectListBox');\n await this.addListValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addListValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.getByText('Select all', { exact: true }).click();\n }\n\n async selectVariableByDate(date: string, monthYear: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DateVariable');\n await this.page.getByText('Select date').click();\n await this.setDate(date, monthYear);\n }\n\n async setDate(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async addVariableKeyValueMap(keys1: string, values1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MapStringStringVariable');\n await this.page.getByPlaceholder('key').fill(keys1);\n await this.page.getByPlaceholder('Value').fill(values1);\n await this.listAddButton.click();\n await this.page.locator('.xl-map-string-string-div-buttons .search-icon').click();\n await this.page.getByRole('row', { name: 'Search' }).getByRole('textbox').fill(keys1);\n const detail = await this.page.locator('table.table-condensed span').allInnerTexts();\n expect(detail[0]).toEqual(keys1);\n expect(detail[1]).toEqual(values1);\n }\n\n async addVariableSet(possiblevalue1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('SetStringVariable');\n await this.page.locator('.dip-input input').fill(possiblevalue1);\n await this.listAddButton.click();\n }\n\n async submitTheVariable(): Promise<void> {\n const createButton = this.page.locator('.modal-footer .save');\n await expect(createButton).toBeEnabled();\n await createButton.scrollIntoViewIfNeeded();\n await createButton.click();\n // Expect is needed here to avoid flackiness on clicking create button\n await expect(createButton).not.toBeVisible();\n }\n\n async expectVariableWithNameValueAndType(name: string, value: string, type: string): Promise<void> {\n await this.page.locator('.variables-list .row-table').waitFor({ timeout: 10000 });\n const rowLocator = await this.page.locator('.variable .data-row').allTextContents();\n expect(rowLocator.toString()).toContain(name);\n expect(rowLocator.toString()).toContain(value);\n expect(rowLocator.toString()).toContain(type);\n }\n\n async clickEditVariable(variableName: string): Promise<VariableModal> {\n await this.page.locator('.data-row').filter({ hasText: variableName }).getByText('Edit').first().click();\n return new VariableModal(this.page);\n }\n\n async clickDeleteVariable(variableName: string): Promise<DeleteVariableModel> {\n await this.page\n .locator('.data-row')\n .filter({ hasText: variableName })\n .locator('.action .delete-icon')\n .first()\n .click();\n return new DeleteVariableModel(this.page);\n }\n\n async expectVariablesCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.variable .data-row')).toHaveCount(count);\n }\n\n async expectVariableNotPresent(variableName: string): Promise<void> {\n await expect(this.page.locator('.variable').filter({ hasText: variableName })).not.toBeVisible();\n }\n\n async clearReleaseVariableSearch(): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").clear();\n }\n\n async switchPossibleValuesToVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n }\n\n async selectVariableListboxTypeWithVariable(\n variableName: string,\n defaultValue: string,\n required?: boolean,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n } else {\n await this.page.getByRole('checkbox').uncheck();\n }\n }\n\n async clickMultiline(): Promise<void> {\n await this.page.locator('#multiline').click();\n }\n\n async searchFolderVariable(variableName: string): Promise<void> {\n await this.page.locator('.searchFilter').fill(variableName);\n }\n\n async clearFolderVarSearch(): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n }\n\n async clickFolderVariableButton(): Promise<void> {\n await this.page.getByText('Folder variables').click();\n }\n\n async clickReleaseVariableButton(): Promise<void> {\n await this.page.getByText('Release variables').click();\n }\n}\n\nclass VariableModal extends WithPage {\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n }\n private async expectValue(locators: Locator[], expectFn: ExpectWithLocator[]): Promise<void> {\n const [index, locator] = await waitForOneOf(locators);\n expectFn[index](locator);\n }\n\n async expectValueToBe(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode .text-container'),\n ],\n [\n (l) => expect(l).toHaveValue(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n ],\n );\n }\n\n async expectValueToContain(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode'),\n ],\n [\n (l) => expect(l.inputValue()).toContain(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n ],\n );\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async expectPossibleValues(possiblevalue: Array<string> | string): Promise<void> {\n const listLocator = await this.page.locator('.editor .xl-list-row').allInnerTexts();\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n expect(listLocator).toContain(value);\n }\n } else {\n expect(listLocator).toContain(possiblevalue);\n }\n }\n\n async expectPossibleVariableValues(possibleVariableValue: string): Promise<void> {\n await expect(this.page.locator('.variable-dropdown input')).toHaveValue(possibleVariableValue);\n }\n\n async addPossibleValue(value: Array<string> | string): Promise<void> {\n if (value instanceof Array) {\n for (const li of value) {\n await this.page.locator('.xl-components-input-full input').fill(li);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n } else {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n }\n\n async selectVariableValue(defaultValue: string): Promise<void> {\n await this.page.locator('.variable-value select').selectOption(defaultValue);\n }\n\n async save(): Promise<void> {\n const saveButton = this.page.locator('#modal .modal-footer .save');\n await saveButton.scrollIntoViewIfNeeded();\n await saveButton.click({ delay: 2000 });\n // Expect is needed here to avoid flackiness on clicking save button on modal window\n await expect(saveButton).not.toBeVisible();\n }\n\n async createPossibleValuesVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await expect(async () => {\n await this.page.locator('.ui-autocomplete-input').clear();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n const check = await this.page\n .locator('.ui-menu-item-wrapper')\n .getByText('${' + variableName + '}', { exact: true })\n .isVisible({ timeout: 1000 });\n if (check) {\n await this.page\n .locator('.ui-menu-item-wrapper')\n .getByText('${' + variableName + '}', { exact: true })\n .click({ timeout: 1000 });\n } else {\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click({ timeout: 1000 });\n }\n }).toPass();\n }\n\n async expectVariableValueToBe(value: string): Promise<void> {\n expect(await this.page.locator('.variable-value select option[selected=\"selected\"]').textContent()).toBe(value);\n }\n\n async expectNoVariablesInList(): Promise<void> {\n await expect(this.page.getByText('No variables defined.')).toBeVisible();\n }\n\n async expectNameInput(value: string): Promise<void> {\n await expect(this.page.locator(`#modal .variable-name input`)).toHaveValue(value);\n }\n\n async expectLabel(value: string): Promise<void> {\n await expect(this.page.locator('#modal .variable-label input')).toHaveValue(value);\n }\n\n async expectRequired(value: boolean): Promise<void> {\n if (value) await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).toBeChecked();\n else await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).not.toBeChecked();\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.variable-description input').click();\n await this.page.locator('.variable-description input').clear();\n await this.page.locator('.variable-description input').fill(description);\n }\n\n async setLabel(labelValue: string): Promise<void> {\n await this.page.locator('.variable-label input').fill(labelValue);\n }\n\n async setDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setValue(value: string): Promise<void> {\n await this.page.locator('.variable-value input').fill(value);\n }\n\n async clearValue(): Promise<void> {\n await this.page.locator('.variable-value input').clear();\n }\n\n async clickMultiline(): Promise<void> {\n await this.page.locator('#multiline').click();\n }\n\n async setValueForMultilinePassword(value: string): Promise<void> {\n await this.page.locator('.password-textarea').fill(value);\n }\n}\nclass DeleteVariableModel extends WithPage {\n model: VariableModal;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.model = new VariableModal(page);\n this.dateUtil = new DateUtil(page);\n }\n async deleteVariable(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async replaceItWithVariable(variable: string): Promise<void> {\n await this.model.createPossibleValuesVariable(variable);\n }\n\n async replaceItwithValue(value: string): Promise<void> {\n await this.page.locator('.display').click();\n await this.page.getByLabel('*').fill(value);\n }\n\n async clickReplaceAndDelete(): Promise<void> {\n await this.page.getByRole('button', { name: 'Replace and delete' }).click();\n }\n\n async addValue(value: string): Promise<void> {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n\n async remove(value: string): Promise<void> {\n await this.page.locator('li').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async expectReplacementPromptDisplayed(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async removeItemOnSet(value: string): Promise<void> {\n await this.page.locator('tr').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async addValueForSet(key: string, value: string): Promise<void> {\n await this.page.locator('.input-key').fill(key);\n await this.page.locator('.input-value').fill(value);\n }\n\n async replaceWithIntegerValue(value: string): Promise<void> {\n await this.page.locator('.editable').fill(value);\n }\n\n async replaceForBooleanValue(): Promise<void> {\n await this.page.locator('.editor input').click();\n }\n\n async deleteBySettingDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ActivityRail extends WithPage {\n commentFilterInput: Locator;\n filterIconButton: Locator;\n markdownWrapper: Locator;\n sortButton: Locator;\n systemListItem: Locator;\n tooltipPopper: Locator;\n userListItem: Locator;\n viewAllListItem: Locator;\n\n constructor(page: Page) {\n super(page);\n this.sortButton = this.page.locator(\".dot-icon-btn[data-testid='task-comment-sort-btn']\");\n this.viewAllListItem = this.page.locator(\".dot-li[data-id='all']\");\n this.systemListItem = this.page.locator(\".dot-li[data-id='system']\");\n this.userListItem = this.page.locator(\".dot-li[data-id='user']\");\n this.filterIconButton = this.page.locator(\".dot-icon-btn[aria-label='filter icon button']\");\n this.commentFilterInput = this.page.locator('input#task-comment-filter');\n this.markdownWrapper = this.page.locator('.markdown-wrapper');\n this.tooltipPopper = this.page.locator('.MuiTooltip-popper');\n }\n\n async expectCommentToContain(comment: string, shouldContain = true): Promise<void> {\n const commentLocator = this.markdownWrapper.getByText(comment);\n\n if (shouldContain) {\n await expect(commentLocator).toBeVisible();\n } else {\n await expect(commentLocator).toHaveCount(0);\n }\n }\n\n async expectCommentToContainAtPosition(comment: string, positionIndex: number): Promise<this> {\n await expect(this.markdownWrapper.nth(positionIndex).getByText(comment)).toBeVisible();\n return this;\n }\n\n async expectCommentToContainLink(hrefLink: RegExp): Promise<void> {\n await expect(this.page.locator('.markdown-wrapper a')).toHaveAttribute('href', hrefLink);\n }\n\n async expectTaskIsCommentable(isCommentable: boolean): Promise<void> {\n return expect(await this.page.locator('#task-comment').count()).toBe(isCommentable ? 1 : 0);\n }\n\n async addComment(comment: string): Promise<this> {\n await this.page.locator('#task-comment').fill(comment);\n await this.page.locator('.icon-send-airplane').click();\n return this;\n }\n\n async searchComments(filter: string): Promise<this> {\n await this.commentFilterInput.fill(filter);\n await this.commentFilterInput.press('Enter');\n return this;\n }\n\n async clickOnFilterIconButton(): Promise<this> {\n await this.filterIconButton.click();\n return this;\n }\n\n async clickOnUserListItemFilter(): Promise<this> {\n await this.userListItem.click();\n return this;\n }\n\n async clickOnSystemListItemFilter(): Promise<this> {\n await this.systemListItem.click();\n return this;\n }\n\n async clickOnViewAllListItemFilter(): Promise<this> {\n await this.viewAllListItem.click();\n return this;\n }\n\n async clickOnSortIconButton(): Promise<this> {\n await this.sortButton.click();\n return this;\n }\n\n async expectAuthorCommentsToBe(author: string): Promise<this> {\n await expect(this.page.locator('.task-comment-user h6')).toHaveText(author);\n return this;\n }\n\n async expectSortIconButtonToHaveTooltipText(tooltipText: string): Promise<this> {\n await this.sortButton.hover();\n await expect(this.tooltipPopper.getByText(tooltipText)).toBeVisible();\n return this;\n }\n\n async expectCommentsDateTimeToBe(comment: string, date: string): Promise<this> {\n const commentLocator = this.page\n .locator('.task-comment-body')\n .filter({ has: this.page.locator('.markdown-switcher').getByText(comment) })\n .locator('.task-comment-user span')\n .getByRole('tooltip', { name: 'Edited' });\n await expect(commentLocator).toHaveAttribute('aria-label', date);\n return this;\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class AttachmentRail extends WithPage {\n async expectWithAttachment(filename: string): Promise<void> {\n const test = this.page.locator('.task-attachments-grid .file-item-text');\n await expect(test).toContainText(filename);\n }\n\n async getAttachmentsListCount(): Promise<number> {\n return await this.page.locator('.file-upload-list div').count();\n }\n\n async uploadFile(filePath: string): Promise<void> {\n const fileChooserPromise = this.page.waitForEvent('filechooser');\n await this.page.getByRole('button', { name: 'Select file(s)' }).click();\n const fileChooser = await fileChooserPromise;\n await fileChooser.setFiles(filePath);\n }\n\n async downloadFile(filename: string): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n const downloadPromise = this.page.waitForEvent('download');\n await this.page\n .locator('li')\n .filter({ hasText: '' + filename + '' })\n .click();\n await downloadPromise;\n }\n\n async deleteAttachment(fileName: string): Promise<void> {\n await this.page.locator('li').filter({ hasText: fileName }).click();\n await this.page.getByLabel('delete file').click();\n await this.page.getByRole('button', { name: 'Delete' }).waitFor({ state: 'visible' });\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async expectWithNoAttachment(tempFile: string): Promise<void> {\n const test = await this.page.locator('.task-attachments-grid .file-item-text').count();\n if (test > 0) {\n await expect(this.page.locator('.task-attachments-grid .file-item-text')).not.toContainText(tempFile);\n } else {\n await expect(this.page.locator('.task-attachments-grid .file-item-text')).not.toBeVisible();\n }\n }\n}\n","import { WithPage } from '../WithPage';\nimport { Page, expect } from '@playwright/test';\n\nexport class AttributeRail extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async clickAddAttribute(): Promise<void> {\n await this.page.getByTestId('add-btn').click();\n }\n\n async expectAttributeEditable(): Promise<void> {\n await expect(this.page.locator('#facet-type')).not.toHaveAttribute('readonly', '');\n }\n\n async addTag(tagName: string): Promise<void> {\n await this.page.locator('#task-tags').click();\n await this.page.locator('#task-tags').fill(tagName);\n await this.page.locator('#task-tags').press('Enter');\n }\n\n async expectContainsTag(tagName: Array<string> | string): Promise<void> {\n if (Array.isArray(tagName)) {\n for (const tag of tagName) {\n await expect(this.page.locator('.task-tags-wrapper .dot-chip').filter({ hasText: tag })).toBeVisible();\n }\n } else {\n await expect(this.page.locator('.task-tags-wrapper .dot-chip').filter({ hasText: tagName })).toBeVisible();\n }\n }\n\n async selectAttributeType(type: string): Promise<void> {\n await this.page.getByRole('combobox', { name: 'Type of attribute' }).click();\n await this.page.getByRole('combobox', { name: 'Type of attribute' }).fill(type);\n await this.page.getByRole('option', { name: type }).click();\n }\n\n async fillInputValue(labelName: string, value: string): Promise<void> {\n await this.page.getByRole('combobox', { name: labelName }).click();\n await this.page.getByRole('combobox', { name: labelName }).clear();\n await this.page.getByRole('combobox', { name: labelName }).fill(value);\n await this.page.getByRole('option', { name: value, exact: true }).click();\n }\n\n async saveAttributes(): Promise<void> {\n await this.page.locator('.task-attribute-edit-buttons').click();\n await this.page.getByTestId('save-btn').click();\n }\n\n async cancelAttribute(): Promise<void> {\n await this.page.getByTestId('cancel-btn').click();\n }\n\n async setInputTextField(fieldId: string, value: string): Promise<void> {\n await this.page.locator(`input[id=\"${fieldId}\"]`).focus();\n await this.page.locator(`input[id=\"${fieldId}\"]`).fill(value);\n }\n\n async expectFacetCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.task-attribute-item')).toHaveCount(count);\n }\n\n async expectFieldValueToBe(fieldId: string, value: string): Promise<void> {\n await expect(this.page.locator('input[id=\"' + fieldId + '\"]')).toHaveValue(value);\n }\n\n async clickEditExistingFacet(facetName: string): Promise<void> {\n await this.page.locator('.task-attribute-item').filter({ hasText: facetName }).getByTestId('edit-btn').click();\n }\n\n async deleteFacet(faceName: string): Promise<void> {\n await this.page.locator('.task-attribute-item').filter({ hasText: faceName }).getByTestId('delete-btn').click();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ConditionRail extends WithPage {\n railLocator: Locator;\n preconditionToggle: Locator;\n textEditor: Locator;\n saveButton: Locator;\n\n constructor(page: Page) {\n super(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-conditions');\n this.preconditionToggle = page.getByLabel('Enable precondition');\n this.textEditor = page.locator('textarea');\n this.saveButton = page.getByTestId('save-btn');\n }\n\n async enablePrecondition(): Promise<void> {\n expect(await this.preconditionToggle.isChecked()).toBe(false);\n await this.preconditionToggle.check();\n }\n\n async disablePrecondition(): Promise<void> {\n expect(await this.preconditionToggle.isChecked()).toBe(true);\n await this.preconditionToggle.uncheck();\n }\n\n async setPrecondition(script: string): Promise<void> {\n await this.enablePrecondition();\n await this.textEditor.fill(script);\n await this.saveButton.dblclick();\n await this.page.waitForTimeout(1000);\n }\n\n async expectPreconditionEditable(editable: boolean): Promise<void> {\n if (editable) {\n await expect(this.textEditor).toBeEditable();\n } else {\n await expect(this.textEditor).not.toBeEditable();\n }\n }\n\n async enableFailureHandler(): Promise<void> {\n await this.page.getByLabel('Enable failure handler').check();\n }\n\n async expectEnabledFailureHandlerToggle(): Promise<void> {\n await expect(this.page.getByLabel('Enable failure handler')).toBeEnabled();\n }\n\n async expectDisabledFailureHandlerToggle(): Promise<void> {\n await expect(this.page.getByLabel('Enable failure handler')).toBeDisabled();\n }\n\n async clickFailureHandler(): Promise<this> {\n await this.page.getByRole('button', { name: 'failure' }).click();\n return this;\n }\n\n async clickPrecondition(): Promise<this> {\n await this.page.getByRole('button', { name: 'precondition' }).click();\n return this;\n }\n\n async expectFailureHandlerHasDefaults(): Promise<this> {\n await expect(this.page.locator('.task-conditions .dot-label-wrapper')).toContainText('If the task fails');\n await expect(this.page.locator('#select-action')).toContainText('Skip task');\n return this;\n }\n\n async selectPostAction(action: string): Promise<this> {\n await this.page\n .getByRole('textbox', { name: 'If the task fails' })\n .getByLabel('If the task fails')\n .selectOption(action);\n return this;\n }\n\n async enterFailureHandlerScript(script: string): Promise<this> {\n await this.page.locator('.ace_content').click();\n await this.page.locator('textarea').fill(script);\n await this.saveButton.click();\n return this;\n }\n\n async expectScriptToContain(script: string): Promise<void> {\n await expect(this.page.locator('.code-editor .ace_content')).toContainText(script);\n }\n\n async expectFailureHandlerEditable(): Promise<this> {\n await expect(this.page.locator('#select-action')).toBeVisible();\n return this;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ConfigRail extends WithPage {\n railLocator: Locator;\n\n constructor(page: Page) {\n super(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-config');\n }\n\n async openInputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Input properties').click();\n }\n\n async openOutputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Output properties').click();\n }\n\n async getValueFromCi(propertyName: string): Promise<string> {\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async getAllOptionsFromCi(propertyName: string): Promise<string[]> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n return this.railLocator.locator(`.dot-popper ul li`).allInnerTexts();\n }\n\n async setValueFromCi(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.locator(`.dot-popper ul li`, { hasText: value }).click();\n }\n\n async getValueFromString(propertyName: string): Promise<string | null> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async setValueFromString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueFromLargeString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`textarea[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueFromPassword(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setAndCreateVariable(propertyName: string, variableName: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(variableName);\n await this.railLocator.locator(`.dot-popper button`, { hasText: variableName }).click();\n }\n\n async setVariable(propertyName: string, variableName: string): Promise<void> {\n return this.setValueFromCi(propertyName, variableName);\n }\n\n async expectValueFromString(propertyName: string, propertyValue: string): Promise<void> {\n return await expect(this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`)).toHaveText(\n propertyValue,\n );\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class OverviewRail extends WithPage {\n dependency: Dependency;\n modal: ModalWindow;\n railLocator: Locator;\n scriptTextArea: Locator;\n constructor(page: Page) {\n super(page);\n this.dependency = new Dependency(page);\n this.modal = new ModalWindow(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-drawer-content');\n this.scriptTextArea = this.page.locator('.code-editor textarea.ace_text-input');\n }\n\n async openInputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Input properties').click();\n }\n\n async openOutputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Output properties').click();\n }\n\n async getValueFromCi(propertyName: string): Promise<string> {\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async getAllOptionsFromCi(propertyName: string): Promise<string[]> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n return this.railLocator.locator(`.dot-popper ul li`).allInnerTexts();\n }\n\n async setValueFromCi(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.locator(`.dot-popper ul li`, { hasText: value }).click();\n }\n\n async clickCreateNewCiInVariable(propertyName: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.getByTestId('dot-action-item-btn').click();\n }\n\n async getValueFromString(propertyName: string): Promise<string | null> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async getStringListField(propertyName: string): Promise<StringList> {\n return new StringList(propertyName, this.page);\n }\n\n async getStringSetField(propertyName: string): Promise<StringSet> {\n return new StringSet(propertyName, this.page);\n }\n\n async getStringMapField(propertyName: string): Promise<StringMap> {\n return new StringMap(propertyName, this.page);\n }\n\n async setValueFromString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueFromLargeString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`textarea[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueForBody(value: string): Promise<void> {\n await this.railLocator.locator('.notification-body-field .markdown-viewer').focus();\n await this.railLocator.locator('.notification-body-field .markdown-viewer').dblclick();\n await this.railLocator.locator('#notification-body').fill(value);\n await this.railLocator.locator('#notification-body').press('Enter');\n await this.railLocator.getByTestId('save-button').click();\n }\n\n async setValueFromPassword(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async selectVariableFromOption(objectID: string, variable: string): Promise<void> {\n await this.page.locator(`div[data-testid=\"${objectID}\"] .icon-variable`).click();\n await this.page.locator(`#${objectID}`).fill(variable);\n await this.page.getByRole('option', { name: variable }).click();\n }\n\n async setValueForDateVariable(variable: string, date: string): Promise<this> {\n await this.page.getByRole('textbox', { name: variable }).fill(date);\n return this;\n }\n\n async createNewVariableForField(objectID: string, variable: string): Promise<void> {\n const variable_icon = this.page.locator(`div[data-testid=\"${objectID}\"] .icon-variable`);\n if (await variable_icon.isVisible()) {\n await variable_icon.click({ timeout: 1000 });\n }\n await this.page.locator(`#${objectID}`).fill(variable);\n await this.railLocator.locator(`.dot-popper button`, { hasText: variable }).click();\n }\n\n async createReleaseIdInOutputProperties(propertyName: string, variableName: string): Promise<void> {\n await this.railLocator.locator(`#${propertyName}`).fill(variableName);\n await this.page.getByTestId('dot-action-item-btn').click();\n }\n\n async expectValueInOutputProperties(variableId: string, value: string, expected = true): Promise<void> {\n if (expected) {\n await expect(this.railLocator.locator(`#${variableId}`)).toBeVisible();\n await expect(this.railLocator.locator(`#${variableId}`)).toHaveValue(value);\n } else {\n await expect(this.railLocator.locator(`#${variableId}`)).not.toBeVisible();\n }\n }\n\n async expectValueInInputProperties(propertyName: string, value: string, expected = true): Promise<void> {\n if (expected) {\n await expect(this.railLocator.locator(`[name='${propertyName}']`)).toHaveValue(value);\n }\n }\n\n async selectReleaseIdInOutputProperties(objectID: string, variableName: string): Promise<void> {\n await this.railLocator.locator(`#${objectID}`).fill(variableName);\n await this.page.getByRole('option', { name: variableName }).click();\n }\n\n async expectVariable(propertyName: string, expected = true): Promise<void> {\n if (expected)\n await expect(\n this.railLocator\n .locator(`input[id=\"${propertyName}\"]`)\n .or(this.railLocator.locator(`textarea[id=\"${propertyName}\"]`)),\n ).toBeVisible();\n else\n await expect(\n this.railLocator\n .locator(`input[id=\"${propertyName}\"]`)\n .or(this.railLocator.locator(`textarea[id=\"${propertyName}\"]`)),\n ).not.toBeVisible();\n }\n\n async expectAlertMessage(alertMessage: string): Promise<void> {\n await expect(this.railLocator.locator('.warning .MuiAlert-message')).toHaveText(alertMessage);\n }\n\n async expectValueFromString(propertyName: string, propertyValue: string): Promise<void> {\n return await expect(this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`)).toHaveText(\n propertyValue,\n );\n }\n\n async expectValueFromResultString(propertyName: string, value: string): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${propertyName}\"]`).getByText(value)).toBeVisible();\n return this;\n }\n\n async expectDisabledInputField(propertyName: string): Promise<this> {\n const inputField = this.railLocator.locator(`.task-input-property input[id=\"${propertyName}\"]`);\n if (await inputField.isVisible()) await expect(inputField).toHaveAttribute('readonly' || 'disabled', '');\n return this;\n }\n\n async expectRiskProfileValue(value: string): Promise<void> {\n await expect(this.railLocator.locator('#riskProfileId')).toHaveValue(value);\n }\n\n async expectTo(value: string): Promise<void> {\n return await expect(this.railLocator.getByTestId(`dot-autocomplete-chip`)).toHaveText(value);\n }\n\n async expectAutoCompleteFieldValue(label: string, value: string[] | string): Promise<void> {\n await expect(\n this.railLocator.locator('.task-input-property').filter({ hasText: label }).getByTestId('dot-autocomplete-chip'),\n ).toContainText(value);\n }\n\n async expectFieldValue(fieldName: string, value: string): Promise<void> {\n await expect(this.railLocator.locator(`input[name=\"${fieldName}\"]`)).toHaveValue(value);\n }\n\n async expectSubjectToBe(value: string): Promise<void> {\n return await expect(this.page.locator('#notification-subject')).toHaveValue(value);\n }\n\n async expectBodyToBe(value: string): Promise<void> {\n return await expect(this.page.locator('.notification-body-field p')).toHaveText(value);\n }\n\n async expectReleaseTitleToBe(value: string): Promise<void> {\n return await expect(this.page.locator('input[name=newReleaseTitle]')).toHaveValue(value);\n }\n\n async setBody(value: string): Promise<void> {\n await this.page.locator('.notification-body-field p').dblclick();\n await this.page.locator('.notification-body-field #notification-body').fill(value);\n await this.page.getByTestId(`save-button`).click();\n }\n\n async setReleaseTags(tags: Array<string> | string): Promise<void> {\n if (typeof tags !== 'string') {\n for (const tag of tags) {\n await this.page.locator('#release-tags').fill(tag);\n await this.page.locator('#release-tags').press('Enter');\n }\n } else {\n await this.page.locator('#release-tags').fill(tags);\n await this.page.locator('#release-tags').press('Enter');\n }\n }\n\n async setScript(script: string): Promise<void> {\n await this.scriptTextArea.clear();\n await this.scriptTextArea.fill(script);\n await this.page.locator('.code-editor .header button:has-text(\"Save\")').click();\n }\n\n async expectScriptToContain(script: string): Promise<void> {\n await expect(this.page.locator('.code-editor .ace_content')).toContainText(script);\n }\n\n async enterScriptForAutoComplete(script: string): Promise<void> {\n await this.scriptTextArea.clear();\n await this.scriptTextArea.fill(script);\n await this.scriptTextArea.press('.');\n }\n\n async openScriptEditorInSeparateWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-enter-btn').click();\n await expect(this.page.locator('#dialogTitle')).toBeVisible();\n }\n\n async closeFullscreenScriptWindowWithESC(): Promise<void> {\n await this.page.locator('#dialogTitle').press('Escape');\n await expect(this.page.locator('#dialogTitle')).not.toBeVisible();\n }\n\n async closeFullscreenScriptWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-exit-btn').click();\n await expect(this.page.locator('#dialogTitle')).not.toBeVisible();\n }\n\n async abort(comment: string): Promise<void> {\n await this.page.getByTestId('single-action-button').click();\n await this.page.getByTestId('task-action-comment').click();\n await this.page.getByTestId('task-action-comment').fill(comment);\n await this.page.locator('button', { hasText: 'Abort' }).click();\n }\n\n async expectDependenciesDisplayed(dependencies: any[]): Promise<void> {\n await this.railLocator.locator('.gate-task-dependencies').waitFor();\n for (let i = 0; i < dependencies.length; i++) {\n await expect(this.page.locator('.dependency').filter({ hasText: dependencies[i] })).toBeVisible();\n }\n }\n\n async expectDependencyStatus(option = true): Promise<void> {\n if (option) {\n await expect(this.page.locator('.with-status .task-status')).toBeVisible();\n } else {\n await expect(this.page.locator('.with-status .task-status')).not.toBeVisible();\n }\n }\n\n async expectResolvedDependency(): Promise<void> {\n await expect(this.page.locator('span[aria-label=\"check-line icon\"]')).toBeVisible();\n }\n\n async expectUnresolvedDependency(): Promise<void> {\n await expect(this.page.locator('span[aria-label=\"close-line icon\"]')).not.toBeVisible();\n }\n\n async expectCanDeleteDependency(title: string, canDelete = true): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options');\n if (canDelete) {\n await depOptionsIcon.click();\n await expect(this.railLocator.getByRole('menuitem', { name: 'Remove' })).toBeVisible();\n } else {\n await expect(depOptionsIcon).not.toBeVisible();\n }\n }\n\n async expectDependencyContextualMenu(option = true): Promise<void> {\n const depOptionsIcon = this.page.locator('.dependency .icon-options');\n if (option) {\n await expect(depOptionsIcon).toBeVisible();\n } else {\n await expect(depOptionsIcon).not.toBeVisible();\n }\n }\n\n async expectDependencyContextualMenuFor(title: string, option = true): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options');\n if (option) {\n await expect(depOptionsIcon).toBeVisible();\n } else {\n await expect(depOptionsIcon).not.toBeVisible();\n }\n }\n\n async removeDependency(title: string): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByLabel(title, { exact: true }) })\n .locator('.icon-options');\n await depOptionsIcon.click();\n await this.railLocator.getByRole('menuitem', { name: 'Remove' }).click();\n }\n\n async expectDependencyNotToBeVisible(): Promise<void> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).not.toBeVisible();\n }\n\n async getDependencyCount(): Promise<number> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n return await this.railLocator.locator('.gate-task-dependencies .dependency').count();\n }\n\n async addDependency(): Promise<void> {\n await expect(this.railLocator.locator('.add-dependency-btn')).toBeVisible();\n await this.railLocator.locator('.add-dependency-btn').click();\n }\n\n async addCondition(): Promise<void> {\n await expect(this.railLocator.getByTestId('add-condition')).toBeVisible();\n await this.railLocator.getByTestId('add-condition').click();\n }\n\n async expectDependencyText(dependencies: string, isVisible = true): Promise<void> {\n if (isVisible) {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n await expect(this.page.locator(`.gate-task-dependencies`).getByLabel(dependencies).first()).toBeVisible();\n } else await expect(this.page.locator(`.gate-task-dependencies`).getByLabel(dependencies)).not.toBeVisible();\n }\n\n async clickEditDependency(dependencies: string): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByLabel(dependencies) })\n .first()\n .locator('.actions');\n await depOptionsIcon.click();\n const frame = this.page.getByTestId('undefined-menu');\n if (await frame.isVisible()) {\n await this.railLocator.getByRole('menuitem', { name: 'Edit' }).click();\n } else {\n await depOptionsIcon.click();\n await this.railLocator.getByRole('menuitem', { name: 'Edit' }).click();\n }\n }\n async validateAutoCompleteOptionsInDescription(\n descriptionName: string,\n expectedVariableCount: number,\n variableToSelection?: string,\n ): Promise<void> {\n await this.page.getByLabel('Double-click to edit').waitFor({ timeout: 10000 });\n await this.page.getByLabel('Double-click to edit').hover();\n await this.page.locator('.markdown-viewer-actions').getByTestId('edit-button').click();\n await this.page.locator('#task-description-input').fill(descriptionName);\n await expect(this.page.locator('.dot-popper-content-wrapper .option-name')).toHaveCount(expectedVariableCount);\n if (variableToSelection)\n await this.page\n .locator('.dot-popper-content-wrapper .option-name')\n .filter({ hasText: variableToSelection })\n .click();\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n\n // eslint-disable-next-line max-params\n async validateAutoCompleteOptions(\n fieldLabel: string,\n value: string,\n expectedVariableCount: number,\n variableToSelect?: string,\n ): Promise<void> {\n await this.page.getByLabel(fieldLabel).click();\n await this.page.getByLabel(fieldLabel).fill(value);\n await expect(this.page.getByRole('option')).toHaveCount(expectedVariableCount);\n if (variableToSelect) await this.page.getByRole('option', { name: variableToSelect }).click();\n }\n\n async setReleaseTitle(releaseName: string): Promise<void> {\n await this.page.getByLabel('Release title *').fill(releaseName);\n }\n\n async setFolder(folderName: string): Promise<void> {\n await this.page.getByPlaceholder('Select a folder').click();\n await this.page.getByPlaceholder('Search folder...').fill(folderName);\n await this.page.getByRole('button', { name: folderName }).click();\n }\n\n async setTemplate(templateName: string): Promise<void> {\n await this.page.locator('#templateId').click();\n await this.page.locator('#templateId').fill(templateName);\n await this.page.getByRole('option', { name: templateName }).click();\n }\n\n async clearTemplate(): Promise<void> {\n await this.page.locator('#templateId').click();\n await this.page.locator('#templateId').clear();\n }\n\n async errorMsgVisible(errorMessage: string): Promise<void> {\n await expect(this.page.locator('#dialogTitle')).toContainText(errorMessage);\n }\n\n async isButtonVisible(buttonName: string, visible = true): Promise<void> {\n const locator = this.page.getByRole('button', { name: buttonName });\n if (visible) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async cancelDialogWindow(): Promise<void> {\n await this.page.getByRole('button', { name: 'cancel' }).click();\n }\n\n async acceptDialogWindow(): Promise<void> {\n await this.page.getByRole('button', { name: 'change template' }).click();\n }\n\n async setRiskProfile(RiskProfile: string): Promise<void> {\n await this.page.getByLabel('Risk profile').click();\n await this.page.getByLabel('Risk profile').fill(RiskProfile);\n await this.page.getByRole('option', { name: RiskProfile }).click();\n }\n\n async expectTemplate(template: string): Promise<void> {\n await expect(this.railLocator.locator('#templateId')).toBeVisible({ timeout: 10000 });\n await expect(this.railLocator.locator('#templateId')).toHaveValue(template);\n }\n\n async setAutoCompletePassword(passwordValue: string): Promise<void> {\n await this.page.getByTestId('password').getByLabel('Click to switch between').click();\n await this.page.locator('#password').fill(passwordValue);\n await this.page.getByRole('option', { name: passwordValue }).click();\n }\n\n async setAutoCompleteField(fieldLabel: string, value: string): Promise<void> {\n await this.page.getByLabel(fieldLabel).click();\n await this.page.getByLabel(fieldLabel).fill(value);\n await this.page.getByRole('option', { name: value }).click();\n }\n\n async setNewAutoCompleteField(fieldLabel: string, value: string): Promise<void> {\n await this.page.getByLabel(fieldLabel).click();\n await this.page.getByLabel(fieldLabel).fill(value);\n await this.page.getByTestId('dot-action-item-btn').click();\n }\n\n async setTextField(fieldID: string, value: string): Promise<void> {\n await this.page.locator(`[data-test-id=\"${fieldID}\"]`).nth(1).click();\n await this.page.locator(`input[name='${fieldID}']`).fill(value);\n }\n\n async setEmailField(fieldName: string, value: string): Promise<void> {\n await this.page.getByLabel(`${fieldName}`, { exact: true }).click();\n await this.page.getByLabel(`${fieldName}`, { exact: true }).clear();\n await this.page.getByLabel(`${fieldName}`, { exact: true }).fill(value);\n await this.page.getByLabel(`${fieldName}`, { exact: true }).press('Enter');\n }\n\n async selectValueFromOption(fieldId: string, value: string): Promise<void> {\n await this.page.locator(`#${fieldId}`).selectOption(value);\n }\n\n async abortButtonVisibility(visible = true): Promise<void> {\n const locator = this.page.getByRole('button', { name: 'Abort' });\n if (visible) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async setPattern(patternName: string): Promise<void> {\n await this.page.locator('#patternId').click();\n await this.page.locator('#patternId').fill(patternName);\n await this.page.getByRole('option', { name: patternName }).click();\n }\n\n async setStartDate(date: string): Promise<void> {\n await this.page.locator('#startDate').click();\n await this.page.locator('#startDate').fill(date);\n }\n\n async setEndDate(date: string): Promise<void> {\n await this.page.locator('#endDate').click();\n await this.page.locator('#endDate').fill(date);\n }\n\n async enableFallback(): Promise<void> {\n await this.page.getByLabel('Fallback').check();\n }\n\n async expectDescription(description: string): Promise<void> {\n await expect(this.page.getByTestId('dot-accordion-details')).toHaveText(description);\n }\n\n async editDescription(description: string): Promise<void> {\n await this.page.getByLabel('Double-click to edit').waitFor({ timeout: 10000 });\n await this.page.getByLabel('Double-click to edit').hover();\n await this.page.locator('.markdown-viewer-actions').getByTestId('edit-button').click();\n await this.page.locator('#task-description-input').clear();\n await this.page.locator('#task-description-input').fill(description);\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n\n async expectedGateConditionDisplayed(title: string, isVisible = true): Promise<void> {\n if (isVisible)\n await expect(this.page.locator('.gate-task-condition-input').filter({ hasText: title })).toBeVisible();\n else await expect(this.page.locator('.gate-task-condition-input').filter({ hasText: title })).not.toBeVisible();\n }\n\n async expectedGateConditionChecked(title: string, expected = true): Promise<void> {\n if (expected)\n await expect(\n this.page.locator('.gate-task-condition').filter({ hasText: title }).getByTestId('CheckBoxIcon'),\n ).toBeVisible();\n else\n await expect(\n this.page.locator('.gate-task-condition').filter({ hasText: title }).getByTestId('CheckBoxOutlineBlankIcon'),\n ).toBeVisible();\n }\n\n async removeCondition(title: string): Promise<void> {\n await this.page.locator('.gate-task-condition').filter({ hasText: title }).locator('.icon-delete').click();\n }\n\n async checkGateCondition(title: string): Promise<void> {\n await this.page\n .locator('.gate-task-condition')\n .filter({ hasText: title })\n .getByTestId('CheckBoxOutlineBlankIcon')\n .click();\n }\n\n async expectScriptEditable(): Promise<void> {\n await this.page.locator('div.ace_content').click();\n await expect(this.scriptTextArea).not.toHaveAttribute('disabled', '');\n await expect(this.scriptTextArea).not.toHaveAttribute('readonly', '');\n }\n\n async expectInputPropertiesEditable(propertyName: Array<string> | string): Promise<void> {\n if (typeof propertyName !== 'string') {\n for (const pName of propertyName) {\n await expect(this.railLocator.locator(`input[id=\"${pName}\"]`)).not.toHaveAttribute('disabled', '');\n await expect(this.railLocator.locator(`input[id=\"${pName}\"]`)).not.toHaveAttribute('readonly', '');\n }\n } else {\n await expect(this.railLocator.locator(`input[id=\"${propertyName}\"]`)).not.toHaveAttribute('disabled', '');\n await expect(this.railLocator.locator(`input[id=\"${propertyName}\"]`)).not.toHaveAttribute('readonly', '');\n }\n }\n\n async setSelectField(fieldName: string, fieldValue: string): Promise<void> {\n await this.page.getByTestId(`${fieldName}-input`).click();\n const closeIcon = this.page.getByTestId(`CloseIcon`);\n if (await closeIcon.isVisible()) {\n await closeIcon.click();\n }\n await this.page.getByTestId(`${fieldName}-input`).fill(fieldValue);\n await this.page.getByText(fieldValue).click();\n }\n\n async expectStartReleaseToBe(value: string): Promise<void> {\n return await expect(this.railLocator.locator('#startRelease')).toHaveValue(value);\n }\n\n async setStartReleaseVariable(value: string): Promise<void> {\n await this.railLocator.locator('#startRelease').click();\n await this.railLocator.locator('#startRelease').fill(value);\n }\n\n async close(): Promise<void> {\n await this.page.locator('task-drawer .dot-drawer .task-drawer-header').getByTestId('close-btn').click();\n }\n\n async deselectValue(ObjectID: string): Promise<this> {\n await this.page.locator(`#${ObjectID}`).hover();\n await this.page.getByRole('button', { name: 'Clear' }).click();\n await expect(this.page.locator(`#${ObjectID}`)).toHaveValue('');\n return this;\n }\n\n async expectEditVariableList(isVisible = true): Promise<this> {\n if (isVisible) {\n await expect(this.page.getByTestId('edit-btn')).toBeVisible();\n } else {\n await expect(this.page.getByTestId('edit-btn')).toBeDisabled();\n }\n return this;\n }\n\n async clickEditVariableList(): Promise<this> {\n await this.page.getByTestId('edit-btn').click();\n return this;\n }\n\n async removeVariable(variableName: string): Promise<this> {\n await this.page.locator('.draggable-list').filter({ hasText: variableName }).locator('.icon-close').click();\n return this;\n }\n\n async saveVariable(): Promise<this> {\n await this.page.getByTestId('save-btn').click();\n return this;\n }\n\n async selectVariable(variable: Array<string> | string): Promise<this> {\n if (variable instanceof Array) {\n for (const value of variable) {\n await this.railLocator.getByRole('combobox', { name: 'Variables in this task' }).click();\n await this.railLocator.getByText(value).click();\n }\n } else {\n await this.railLocator.getByRole('combobox', { name: 'Variables in this task' }).click();\n await this.railLocator.getByText(variable).click();\n }\n return this;\n }\n\n async setValueForUserInputField(propertyName: string, value: string): Promise<void> {\n await this.page.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.page.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async toggleIgnoreVariableInterpolation(): Promise<void> {\n await this.page.getByLabel('Ignore variable interpolation').click();\n }\n}\n\nexport class ModalWindow extends WithPage {\n saveLocator: Locator;\n modalLocator: Locator;\n constructor(page: Page) {\n super(page);\n this.modalLocator = this.page.locator('.dot-dialog-content');\n this.saveLocator = this.page.getByRole('button', { name: 'Save' });\n }\n\n async setInputTextField(propertyName: string, value: string): Promise<void> {\n await this.modalLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.modalLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n await this.modalLocator.press('Tab');\n }\n\n async save(): Promise<void> {\n await this.saveLocator.click();\n }\n}\n\nexport class Dependency extends WithPage {\n private readonly dependencyLocator: Locator;\n private release: Locator;\n private phase: Locator;\n private task: Locator;\n\n constructor(page: Page) {\n super(page);\n this.dependencyLocator = page.locator('.gate-task-dependencies .dependency-selector-component');\n this.release = this.dependencyLocator.locator('#release-dependency');\n this.phase = this.dependencyLocator.locator('#phase-dependency');\n this.task = this.dependencyLocator.locator('#task-dependency');\n }\n\n async getRelease(): Promise<string | null> {\n return await this.release.getAttribute('value');\n }\n\n async getPhase(): Promise<string | null> {\n return await this.phase.getAttribute('value');\n }\n\n async getTask(): Promise<string | null> {\n return await this.task.getAttribute('value');\n }\n\n async setRelease(releaseTitle: string): Promise<void> {\n await this.release.click();\n await this.release.fill(releaseTitle);\n await this.page.getByRole('option', { name: releaseTitle }).waitFor();\n await this.page.getByRole('option', { name: releaseTitle }).click();\n }\n\n async save(): Promise<void> {\n await expect(this.dependencyLocator.getByTestId('save-button')).toBeVisible();\n await this.dependencyLocator.getByTestId('save-button').click();\n }\n\n async setPhase(phaseTitle: string): Promise<void> {\n await this.phase.click();\n await this.phase.fill('');\n const count = await this.page.getByRole('option', { name: phaseTitle }).count();\n if (count > 0) {\n await this.page.getByRole('option', { name: phaseTitle }).click();\n } else {\n await this.page.locator('.phase-dependency').getByLabel('Open').click();\n await this.page.getByRole('option', { name: phaseTitle }).click();\n }\n }\n\n async setTask(taskTitle: string): Promise<void> {\n await this.task.click();\n await this.task.fill(' ');\n await this.page.getByRole('option', { name: taskTitle }).click();\n }\n\n async clearPhase(): Promise<void> {\n await this.phase.clear();\n }\n\n async expectVariableModeEnabled(mode: boolean): Promise<void> {\n await expect(this.dependencyLocator.getByLabel('input-variable')).toBeVisible();\n const variableMode = await this.dependencyLocator.getByLabel('input-variable').getAttribute('aria-pressed');\n expect(variableMode).toBe('' + mode + '');\n }\n\n async clickVariable(): Promise<void> {\n await this.dependencyLocator.getByLabel('input-variable').waitFor();\n await this.dependencyLocator.getByLabel('input-variable').click();\n }\n\n //TODO: getAttribute('value') is not working as expected. Need to be fixed with better alternative.\n async expectMinimumOptions(options: any[]): Promise<void> {\n await this.dependencyLocator.getByPlaceholder('Please select a variable of').click();\n for (let i = 0; i < options.length; i++) {\n const option = await this.dependencyLocator.locator('#mui-30-option-' + i).getAttribute('value');\n expect(options[i]).toContain(option);\n }\n }\n\n async enterNewVariable(variableName: string): Promise<void> {\n await this.page.getByLabel('Please select a variable of').click();\n await this.page.getByLabel('Please select a variable of').fill(variableName);\n await this.page.getByTestId('dot-action-item-btn').click();\n }\n\n async selectVariable(variableName: string): Promise<void> {\n await this.page.getByLabel('Please select a variable of').click();\n await this.page.getByRole('option', { name: variableName }).click();\n }\n}\n\nexport class StringList extends WithPage {\n propertyName: string;\n constructor(propertyName: string, page: Page) {\n super(page);\n this.propertyName = propertyName;\n }\n\n async setValueFromStringList(value: string): Promise<this> {\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).focus();\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).fill(value);\n await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .icon-add`).click();\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).getByText(value)).toBeVisible();\n return this;\n }\n\n async expectStringListCount(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).count()).toBe(count);\n return this;\n }\n\n async removeValueFromStringList(value: string): Promise<this> {\n await this.page\n .locator(`[data-test-id=\"${this.propertyName}\"] .list`)\n .filter({ hasText: value })\n .locator('.icon-close')\n .click();\n return this;\n }\n\n async expectInputFieldDisabled(): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] input`)).not.toBeEditable();\n return this;\n }\n\n async expectValueFromStringList(value: string): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).getByText(value)).toBeVisible();\n return this;\n }\n}\n\nexport class StringSet extends WithPage {\n propertyName: string;\n\n constructor(propertyName: string, page: Page) {\n super(page);\n this.propertyName = propertyName;\n }\n\n async setValueFromStringSet(value: string): Promise<this> {\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).focus();\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).fill(value);\n await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .icon-add`).click();\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).getByText(value)).toBeVisible();\n return this;\n }\n\n async expectInputFieldDisabled(): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] input`)).not.toBeEditable();\n return this;\n }\n\n async expectAddButtonDisabled(): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .icon-add`)).toBeDisabled();\n return this;\n }\n\n async expectStringSetCount(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).count()).toBe(count);\n return this;\n }\n\n async removeValueFromStringSet(key: string): Promise<this> {\n await this.page\n .locator(`[data-test-id=\"${this.propertyName}\"] .list`)\n .filter({ hasText: key })\n .locator('.icon-close')\n .click();\n return this;\n }\n}\n\nexport class StringMap extends WithPage {\n propertyName: string;\n\n constructor(propertyName: string, page: Page) {\n super(page);\n this.propertyName = propertyName;\n }\n\n async setValueFromMap(key: string, value: string): Promise<void> {\n await this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`).click();\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-key-input\"]`)\n .fill(key);\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-value-input\"]`)\n .fill(value);\n await this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.map-row-save-button`).click();\n await expect(this.page.locator(`.map-data-row .map-key`).getByText(key)).toBeVisible();\n }\n\n async removeValueFromMap(key: string): Promise<this> {\n await this.page\n .locator(`.map-data-row`)\n .filter({ has: this.page.locator(`.map-key`).getByText(key) })\n .locator(`.icon-delete`)\n .click();\n await expect(this.page.locator(`.map-data-row .map-key`).getByText(key)).not.toBeVisible();\n return this;\n }\n\n async expectStringMapCount(count: number): Promise<this> {\n expect(await this.page.locator('.map-data-row').count()).toBe(count);\n return this;\n }\n\n async expectAddButtonDisabledForMap(key: string, value: string): Promise<this> {\n await this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`).click();\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-key-input\"]`)\n .fill(key);\n await expect(\n this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`),\n ).toBeDisabled();\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-value-input\"]`)\n .fill(value);\n await expect(\n this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`),\n ).toBeDisabled();\n return this;\n }\n\n async expectInputFieldDisabledForMap(): Promise<this> {\n await expect(\n this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-value-input\"]`),\n ).not.toBeVisible();\n return this;\n }\n}\n","import { expect, Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\nimport moment from 'moment';\n\nexport class SchedulingRail extends WithPage {\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n }\n\n async expectStartDateToBeDisplayed(): Promise<void> {\n await expect(\n this.page.locator('.flex-section.column').filter({ hasText: 'Start Date' }).locator('.task-date-view-content'),\n ).toBeVisible();\n }\n\n async expectStartDateToBe(date: string): Promise<void> {\n expect(\n await this.page\n .locator('.flex-section.column')\n .filter({ hasText: 'Start Date' })\n .locator('.task-date-view-content .dot-avatar')\n .getAttribute('aria-label'),\n ).toContain(date);\n }\n\n async expectStartDateWarningBannerToNotBePresent(): Promise<void> {\n const alertBanner = this.page.locator('.dot-alert-banner');\n await expect(alertBanner).not.toBeVisible();\n }\n\n async expectStartDateWarningBanner(text: string, originalScheduledStartDate?: string): Promise<void> {\n const alertBanner = this.page.locator('.dot-alert-banner');\n await expect(alertBanner).toBeVisible();\n await expect(alertBanner).toContainText(text);\n if (originalScheduledStartDate) {\n const originalScheduledStartDateText = await this.page\n .locator('.dot-alert-banner p[data-testid=\"original-scheduled-start-date\"] span')\n .textContent();\n if (originalScheduledStartDateText) {\n expect(moment(new Date(originalScheduledStartDateText)).format('YYYY-MM-DDTHH:mm')).toBe(\n moment(new Date(originalScheduledStartDate)).format('YYYY-MM-DDTHH:mm'),\n );\n }\n }\n }\n\n async expectEndDateToBeDisplayed(): Promise<void> {\n await expect(\n this.page.locator('.flex-section.column').filter({ hasText: 'End Date' }).locator('.task-date-view-content'),\n ).toBeVisible();\n }\n\n async switchWaitForScheduledDate(): Promise<void> {\n await this.page.locator('.wait-for-start input').click();\n }\n\n async expectWaitForScheduledDateToBeChecked(): Promise<void> {\n await expect(this.page.locator('.wait-for-start input')).toBeChecked();\n }\n\n async expectWaitForScheduledDateToBeUnchecked(): Promise<void> {\n await expect(this.page.locator('.wait-for-start input')).not.toBeChecked();\n }\n\n async setDueTime(day?: string, hour?: string, minute?: string): Promise<void> {\n await this.page.locator('.duration-view-content').click();\n if (day) {\n await this.page.locator('#days').clear();\n await this.page.locator('#days').fill(day);\n }\n if (hour) {\n await this.page.locator('#hours').clear();\n await this.page.locator('#hours').fill(hour);\n }\n if (minute) {\n await this.page.locator('#minutes').clear();\n await this.page.locator('#minutes').fill(minute);\n }\n await this.page.getByTestId('save-button').click();\n }\n\n async setStartDate(date: string, monthYear: string): Promise<void> {\n await this.page\n .locator('.flex-section.column')\n .filter({ hasText: 'Start date' })\n .locator('.task-date')\n .waitFor({ timeout: 10000 });\n // reclick if the date picker is not visible\n await expect(async () => {\n await this.page.locator('.flex-section.column').filter({ hasText: 'Start date' }).locator('.task-date').click();\n // sometimes the date picker closes itself\n await this.page.waitForTimeout(1000);\n await expect(this.page.locator('.MuiPickersCalendarHeader-label')).toBeVisible({ timeout: 100 });\n }).toPass();\n await this.setDate(date, monthYear);\n }\n\n async setEndDate(date: string, monthYear: string): Promise<void> {\n await this.page\n .locator('.flex-section.column')\n .filter({ hasText: 'End date' })\n .locator('.task-date')\n .waitFor({ timeout: 10000 });\n // reclick if the date picker is not visible\n await expect(async () => {\n await this.page.locator('.flex-section.column').filter({ hasText: 'End date' }).locator('.task-date').click();\n // sometimes the date picker closes itself\n await this.page.waitForTimeout(1000);\n await expect(this.page.locator('.MuiPickersCalendarHeader-label')).toBeVisible({ timeout: 100 });\n }).toPass();\n await this.setDate(date, monthYear);\n }\n\n async setDate(date: string, monthYear: string): Promise<void> {\n const prev = this.page.getByTestId('ArrowLeftIcon');\n const next = this.page.getByTestId('ArrowRightIcon');\n const monYear = this.page.locator('.MuiPickersCalendarHeader-label');\n const currentDate = await monYear.textContent();\n const thisMonth = moment(monthYear, 'MMMM YYYY').isBefore(currentDate);\n while ((await monYear.textContent()) != monthYear) {\n if (thisMonth) {\n await prev.click();\n } else {\n await next.click();\n }\n }\n await this.page\n .getByRole('gridcell', { name: '' + date + '', exact: true })\n .first()\n .click();\n }\n\n async checkDelayDuringBlackoutPeriod(): Promise<void> {\n await this.page\n .locator('.task-wait-switch')\n .filter({ hasText: 'blackout' })\n .locator('.PrivateSwitchBase-input')\n .check();\n }\n\n async unCheckDelayDuringBlackoutPeriod(): Promise<void> {\n await this.page.getByTestId('blackout').locator('.PrivateSwitchBase-input').uncheck();\n }\n\n async checkEnvironmentAvailability(): Promise<void> {\n await this.page\n .locator('.task-wait-switch')\n .filter({ hasText: 'environment' })\n .locator('.PrivateSwitchBase-input')\n .check();\n }\n\n async unCheckEnvironmentAvailability(): Promise<void> {\n await this.page.getByTestId('environment').locator('.PrivateSwitchBase-input').uncheck();\n }\n}\n","import { WithPage } from '../WithPage';\nimport { expect, Locator, Page } from '@playwright/test';\n\nexport class HistoryRail extends WithPage {\n logsFilterInput: Locator;\n logContentWrapper: Locator;\n sortButton: Locator;\n\n constructor(page: Page) {\n super(page);\n this.logsFilterInput = this.page.locator('input#drawer-history-filter');\n this.sortButton = this.page.locator(\".dot-icon-btn[data-testid='drawer-history-sort-btn']\");\n this.logContentWrapper = this.page.locator('.content-right-message');\n }\n\n async expectLogToContain(log: string, shouldContain = true): Promise<void> {\n const logLocator = this.logContentWrapper.getByText(log);\n\n if (shouldContain) {\n await expect(logLocator).toBeVisible();\n } else {\n await expect(logLocator).toHaveCount(0);\n }\n }\n\n async expectLogToContainAtPosition(log: string, positionIndex: number): Promise<this> {\n await expect(this.logContentWrapper.nth(positionIndex).getByText(log)).toBeVisible();\n return this;\n }\n\n async searchLogs(filter: string): Promise<this> {\n await this.logsFilterInput.fill(filter);\n return this;\n }\n\n async clickOnSortIconButton(): Promise<this> {\n await this.sortButton.click();\n return this;\n }\n}\n","import { ActivityRail } from './taskActivity';\nimport { AttachmentRail } from './taskAttachments';\nimport { AttributeRail } from './taskAttribute';\nimport { ConditionRail } from './taskCondition';\nimport { ConfigRail } from './taskConfig';\nimport { OverviewRail } from './taskOverview';\nimport { Locator, Page, expect } from '@playwright/test';\nimport { SchedulingRail } from './taskScheduling';\nimport { WithPage } from '../WithPage';\nimport { HistoryRail } from './taskHistory';\n\ntype Rail =\n | 'Overview'\n | 'Activity'\n | 'Config'\n | 'Scheduling'\n | 'Conditions'\n | 'Attributes'\n | 'Attach'\n | 'Tags'\n | 'History';\n\nexport class TaskDrawer extends WithPage {\n activity: ActivityRail;\n attachment: AttachmentRail;\n attribute: AttributeRail;\n cancelButton: Locator;\n commentBox: Locator;\n completeButton: Locator;\n confirm: Locator;\n config: ConfigRail;\n condition: ConditionRail;\n failMenu: Locator;\n history: HistoryRail;\n retryButton: Locator;\n openMenu: Locator;\n overview: OverviewRail;\n scheduling: SchedulingRail;\n skipMenu: Locator;\n startButton: Locator;\n taskDrawerLocator: Locator;\n\n constructor(page: Page) {\n super(page);\n this.activity = new ActivityRail(page);\n this.attachment = new AttachmentRail(page);\n this.attribute = new AttributeRail(page);\n this.cancelButton = this.page.getByTestId('task-action-cancel');\n this.commentBox = this.page.getByTestId('task-action-comment');\n this.confirm = this.page.locator('.popper-action-buttons').getByTestId('dot-button');\n this.config = new ConfigRail(page);\n this.condition = new ConditionRail(page);\n this.completeButton = this.page.getByRole('button', { name: 'Complete', exact: true });\n this.failMenu = this.page.getByRole('menuitem', { name: 'Fail' });\n this.history = new HistoryRail(page);\n this.openMenu = this.page.getByRole('button', { name: 'arrow-down icon', exact: true });\n this.overview = new OverviewRail(page);\n this.retryButton = this.page.getByRole('button', { name: 'Retry' });\n this.scheduling = new SchedulingRail(page);\n this.startButton = this.page.getByTestId('single-action-button');\n this.skipMenu = this.page.getByRole('menuitem', { name: 'Skip' });\n this.taskDrawerLocator = this.page.locator('task-drawer .dot-drawer');\n }\n\n async waitForTaskDrawer(): Promise<void> {\n const handle = await this.page.locator('.dot-drawer-paper').elementHandle();\n await handle?.waitForElementState('stable');\n }\n\n async openOverviewRail(): Promise<void> {\n await this.openRail('Overview');\n }\n\n async openActivityRail(): Promise<void> {\n await this.openRail('Activity');\n }\n\n async openSchedulingRail(): Promise<SchedulingRail> {\n await this.openRail('Scheduling');\n return new SchedulingRail(this.page);\n }\n\n async openConditionRail(): Promise<void> {\n await this.openRail('Conditions');\n }\n\n async openAttributesRail(): Promise<void> {\n await this.openRail('Attributes');\n }\n\n async openAttachRail(): Promise<void> {\n await this.openRail('Attach');\n }\n\n async openTagsRail(): Promise<void> {\n await this.openRail('Tags');\n }\n\n async openHistoryRail(): Promise<void> {\n await this.openRail('History');\n }\n\n async openRail(rail: Rail): Promise<void> {\n await this.taskDrawerLocator.locator('.task-navigation-rail').getByText(rail).click();\n }\n\n async close(): Promise<void> {\n await this.taskDrawerLocator.locator('.task-drawer-header').getByTestId('close-btn').click();\n }\n\n async retryTask(comment: string): Promise<void> {\n await this.page.waitForTimeout(1000);\n await this.retryButton.click();\n await this.commentBox.fill(comment);\n await this.page.getByTestId('popper-test-id-content-wrapper').getByTestId('dot-button').click();\n }\n\n async skipTask(comment: string): Promise<void> {\n await this.openMenu.click();\n await this.skipMenu.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async failTask(comment: string): Promise<void> {\n await this.openMenu.click();\n await this.failMenu.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async completeTask(comment: string): Promise<void> {\n await this.completeButton.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async startNow(comment: string): Promise<void> {\n await this.startButton.click();\n await this.commentBox.fill(comment);\n await this.page.locator('button', { hasText: 'Start now' }).click();\n await expect(this.startButton).not.toBeVisible();\n }\n\n async startNowWithBlackout(comment: string): Promise<void> {\n await this.startButton.click();\n await this.commentBox.fill(comment);\n await expect(\n this.page.getByText('Are you sure you want to run this task during the blackout period?'),\n ).toBeVisible();\n await this.page.locator('button', { hasText: 'Start now' }).click();\n await expect(this.startButton).not.toBeVisible();\n }\n\n async expectTaskTitle(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task-drawer .task-title-input .dot-view-mode-typography')).toContainText(\n taskTitle,\n );\n }\n\n async expectCompleteButtonEnabled(): Promise<void> {\n await expect(this.completeButton).toBeEnabled();\n }\n\n async expectCompleteButtonNotEnabled(): Promise<void> {\n await expect(this.completeButton).not.toBeEnabled();\n }\n\n async expectButtonNotVisible(buttonName: string): Promise<this> {\n await expect(this.page.getByRole('button', { name: buttonName, exact: true })).not.toBeVisible();\n return this;\n }\n\n async expectSkipMenuNotEnabled(): Promise<void> {\n await this.openMenu.click();\n await expect(this.skipMenu).not.toBeEnabled();\n }\n\n async setTitle(title: string): Promise<void> {\n await this.page.getByTestId('task-title-input-view-mode-typography').click();\n await this.page.getByTestId('task-title-input-input').clear();\n await this.page.getByTestId('task-title-input-input').fill(title);\n await this.page.getByTestId('task-title-input-input').press('Enter');\n }\n\n async expectTaskTitleEditable(): Promise<this> {\n await this.page.getByTestId('task-title-input-view-mode-typography').click();\n await expect(this.page.getByTestId('task-title-input-input')).toBeEditable();\n return this;\n }\n\n async expectTypeToContain(taskType: string): Promise<void> {\n await expect(this.page.locator('.task-drawer .task-type')).toContainText(taskType);\n }\n\n async clickExpand(): Promise<void> {\n await this.page.getByRole('tooltip', { name: 'Expand' }).getByTestId('expand-btn').click();\n await expect(this.page.getByRole('tooltip', { name: 'Shrink' }).getByTestId('expand-btn')).toBeVisible();\n }\n\n async clickShrink(): Promise<void> {\n await this.page.getByRole('tooltip', { name: 'Shrink' }).getByTestId('expand-btn').click();\n await expect(this.page.getByRole('tooltip', { name: 'Expand' }).getByTestId('expand-btn')).toBeVisible();\n }\n\n async expectAssignedTo(username: string): Promise<void> {\n await expect(this.taskDrawerLocator.getByRole('button', { name: username })).toBeVisible();\n }\n\n async expectStartButtonToBeEnabled(isEnabled = true): Promise<void> {\n if (isEnabled) {\n await expect(this.startButton).toBeEnabled();\n } else await expect(this.startButton).not.toBeEnabled();\n }\n\n async startTask(comment: string): Promise<void> {\n await this.startButton.click();\n await this.completeButton.click();\n await this.commentBox.fill(comment);\n await this.completeButton.click();\n await expect(this.startButton).not.toBeVisible();\n }\n\n // Other locators are flaky and it can be replaced if we get locator change in the frontend\n async clickOnStartDate(): Promise<void> {\n await this.page.getByTestId('month-and-year').first().click();\n }\n\n async removeStartDate(): Promise<void> {\n await this.page.getByRole('button', { name: 'Set by user' }).locator('.MuiChip-deleteIcon').click();\n }\n\n async setStartDate(date: string): Promise<void> {\n await this.clickOnStartDate();\n await this.page.locator('.MuiPickersDay-root', { hasText: date }).click();\n }\n\n async assignToMe(userName: string, existingUsername: string): Promise<void> {\n await expect(async () => {\n await this.page\n .locator('.user-task-assigned-wrapper .editable')\n .getByText(existingUsername)\n .click({ timeout: 1000 });\n await this.page.getByTestId(`render-option-${userName}`).click({ timeout: 1000 });\n }).toPass();\n }\n\n async expectAssigneeToBeEnabled(): Promise<void> {\n await expect(this.page.locator('.user-task-assigned-wrapper .clickable-avatar')).toBeVisible();\n }\n\n async removeAssignToUser(userName: string): Promise<this> {\n await this.page.getByRole('button', { name: userName }).click();\n await this.page.getByRole('button', { name: 'Clear' }).click();\n return this;\n }\n\n async assignToTeam(existingTeamName: string, teamName: string): Promise<this> {\n await this.page.locator('.team-task-assigned-wrapper .editable').getByText(existingTeamName).click();\n await this.page.getByTestId(`render-option-${teamName}`).click();\n return this;\n }\n\n async expectAssignedToTeam(teamName: string): Promise<void> {\n await expect(this.page.getByRole('button', { name: teamName })).toBeVisible();\n }\n\n async removeAssignedTeam(teamName: string): Promise<this> {\n await this.page.locator('.team-task-assigned-wrapper .editable').getByText(teamName).click();\n await this.page.getByRole('button', { name: 'Clear' }).click();\n return this;\n }\n\n async setFlag(flagName: string, flagComment: string): Promise<void> {\n await this.page.getByTestId('flag-btn').click();\n await this.page.getByLabel(flagName).click();\n await this.page.getByPlaceholder('Set message').click();\n await this.page.getByPlaceholder('Set message').fill(flagComment);\n await this.page.getByPlaceholder('Set message').press('Enter');\n await expect(this.page.getByRole('button', { name: `flag icon ${flagComment}` })).toBeVisible();\n }\n\n async expectFlaggedWith(flagName: string, flagComment: string): Promise<void> {\n await this.page.getByRole('button', { name: 'flag icon' }).click();\n const regexPattern = new RegExp(`${flagComment}.*${flagName}`, 'i');\n await expect(this.page.getByText(regexPattern)).toBeVisible();\n }\n\n async expectStartDateToBeDisplayed(): Promise<void> {\n await expect(this.page.getByTestId('start-date-title')).toHaveCount(1);\n }\n\n async expectStartDayToBeInAvatar(expectedDay: string): Promise<void> {\n const startDayAvatar = this.page.locator(`.task-date-content .MuiAvatar-root[aria-label] `).nth(0);\n const startDay = await startDayAvatar.locator('..').locator('h3').textContent();\n expect(startDay?.trim()).toBe(expectedDay);\n }\n\n async expectEndDayToBeInAvatar(expectedDay: string): Promise<void> {\n const endDayAvatar = this.page.locator(`.task-date-content .MuiAvatar-root[aria-label] `).nth(1);\n const endDay = await endDayAvatar.locator('..').locator('h3').textContent();\n expect(endDay?.trim()).toBe(expectedDay);\n }\n\n async expectEndDateToBeDisplayed(): Promise<void> {\n await expect(this.page.getByTestId('end-date-title')).toHaveCount(1);\n }\n\n async expectStartDateAndEndDateToBeDisplayed(): Promise<void> {\n await expect(this.page.getByTestId('month-and-year')).toHaveCount(2);\n }\n\n async expectPhaseAndTaskTitleToContain(phaseName: string, taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task-header-top-path')).toContainText(phaseName);\n await this.expectTaskTitle(taskTitle);\n }\n\n async expectTaskStatusLine(statusLine: string): Promise<void> {\n await expect(this.taskDrawerLocator.locator(`.task-status-line`)).toHaveText(statusLine);\n }\n\n async expectTaskStatusLineHref(link: RegExp): Promise<void> {\n await expect(this.taskDrawerLocator.locator(`.task-status-line a`)).toHaveAttribute('href', link);\n }\n\n async expectNoTaskActionButton(): Promise<void> {\n await expect(this.page.locator('.task-action-buttons')).not.toBeVisible();\n }\n\n async clickTaskOptionIcon(): Promise<void> {\n await this.page.getByTestId('task-options-button').click();\n }\n\n async deleteTaskFromOption(): Promise<void> {\n await this.clickTaskOptionIcon();\n await this.page.getByText('Delete task').click();\n await expect(this.page.getByRole('heading', { name: 'Delete task' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async duplicateTaskFromOption(): Promise<void> {\n await this.clickTaskOptionIcon();\n await this.page.getByText('Duplicate').click();\n }\n\n async expectOptionNotVisible(option: string): Promise<void> {\n await this.clickTaskOptionIcon();\n await expect(this.page.getByText(option)).not.toBeVisible();\n }\n\n async refresh(): Promise<void> {\n await this.page.getByTestId('refresh-btn').click();\n }\n\n async expectRefreshButtonNotVisible(): Promise<void> {\n await expect(this.page.getByTestId('refresh-btn')).not.toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class ReleaseGanttPage extends WithPage {\n releaseHeader: Locator;\n taskDrawer: TaskDrawer;\n constructor(page: Page) {\n super(page);\n this.releaseHeader = this.page.locator('.release-header');\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async enableShowDates(): Promise<void> {\n await this.page.locator('#toggleIsDatesColumnsShown').check();\n }\n\n async disableShowDates(): Promise<void> {\n await this.page.locator('#toggleIsDatesColumnsShown').uncheck();\n }\n\n async expectPlanningDataColumnsHidden(): Promise<void> {\n expect(\n await this.page.locator(`#gantt .gantt_grid_data .gantt_row`).first().locator(`.gantt_cell`).count(),\n ).toEqual(1);\n }\n\n async expectPlanningDateColumnsShown(): Promise<void> {\n expect(\n await this.page.locator(`#gantt .gantt_grid_data .gantt_row`).first().locator(`.gantt_cell`).count(),\n ).toEqual(4);\n }\n\n async expectReleaseOnBreadcrumb(title: string): Promise<void> {\n await expect(this.page.getByRole('link', { name: title })).toBeVisible();\n }\n\n async expectPhaseDisplayed(phaseName: string): Promise<void> {\n await expect(this.page.getByTitle(phaseName, { exact: true })).toBeVisible();\n }\n\n async expectTaskDisplayed(taskName: string, isDisplayed = true): Promise<void> {\n if (isDisplayed) await expect(this.page.getByTitle(taskName)).toBeVisible();\n else await expect(this.page.getByTitle(taskName)).not.toBeVisible();\n }\n\n async expandGanttTree(title: string): Promise<void> {\n return await this.page.locator('.gantt_cell').filter({ hasText: title }).locator('.gantt_open').click();\n }\n\n async expectDifferentWidth(title1: string, title2: string): Promise<void> {\n const releaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title1, { exact: true })\n .getAttribute('style');\n const PhaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title2, { exact: true })\n .getAttribute('style');\n return expect(releaseWidth).not.toEqual(PhaseWidth);\n }\n\n async expectSameWidth(title1: string, title2: string): Promise<void> {\n const releaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title1, { exact: true })\n .getAttribute('style');\n const PhaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title2, { exact: true })\n .getAttribute('style');\n return expect(releaseWidth).toEqual(PhaseWidth);\n }\n\n async expectElementWithClasses(title: string, classes: Array<string>): Promise<void> {\n const eleNumber = await this.page\n .locator(`.${classes.join('.')}`)\n .locator(`.gantt_task_content`)\n .getByText(title, { exact: true })\n .count();\n return expect(eleNumber).toBe(1);\n }\n\n async resizeToDayIndex(title: string, index: number): Promise<void> {\n await this.page.locator(`#gantt .gantt_container .gantt_task_line`).filter({ hasText: title }).click();\n await this.page\n .locator(`.gantt_task_line`)\n .filter({ hasText: title })\n .locator(`.gantt_task_drag.task_right`)\n .hover();\n const objId = await this.page.locator(`.gantt_task_line`).filter({ hasText: title }).getAttribute('task_id');\n await this.page.mouse.down();\n await this.page.locator(`div[task_id='${objId}']`).locator('.gantt_task_cell').nth(index).hover();\n await this.page.mouse.up();\n }\n\n async expectLinksToBeDisplayed(countOfLinks: number): Promise<void> {\n expect(await this.page.locator('.gantt_task_link').count()).toEqual(countOfLinks);\n }\n\n async expectLeftHandleVisibility(title: string, visible: boolean): Promise<void> {\n const objId = await this.page.locator(`.gantt_task_line`).filter({ hasText: title }).getAttribute('task_id');\n if (visible) {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container ').locator(`div[task_id=\"${objId}\"].gantt-no-left-handle`),\n ).not.toBeVisible();\n } else {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container ').locator(`div[task_id=\"${objId}\"].gantt-no-left-handle`),\n ).toBeVisible();\n }\n }\n\n async expectRightHandleVisibility(title: string, visible: boolean): Promise<void> {\n const objId = await this.page.locator(`.gantt_task_line`).filter({ hasText: title }).getAttribute('task_id');\n if (visible) {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container').locator(`div[task_id='${objId}'].gantt-no-right-handle`),\n ).not.toBeVisible();\n } else {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container').locator(`div[task_id='${objId}'].gantt-no-right-handle`),\n ).toBeVisible();\n }\n }\n\n async openTaskDrawer(title: string): Promise<TaskDrawer> {\n await this.page.getByTitle(title).dblclick();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openPhaseDetails(phaseName: string): Promise<void> {\n await this.page.getByTitle(phaseName).dblclick();\n }\n\n getRow(phaseName: string): GanttRow {\n return new GanttRow(this.page, phaseName);\n }\n}\nclass GanttRow extends WithPage {\n private readonly phaseName: Locator;\n dateUtil: DateUtil;\n constructor(page: Page, phaseName: string) {\n super(page);\n this.phaseName = page.locator('.gantt_row').filter({ hasText: phaseName });\n this.dateUtil = new DateUtil(page);\n }\n\n private async getFirstDate(): Promise<Locator> {\n return this.phaseName.locator('.date-editor .date input').first();\n }\n\n private async getLastDate(): Promise<Locator> {\n return this.phaseName.locator('.date-editor .date input').last();\n }\n\n private async getFirstDateEditor(): Promise<Locator> {\n return this.phaseName.locator('.date-editor').first();\n }\n\n private async getLastDateEditor(): Promise<Locator> {\n return this.phaseName.locator('.date-editor').last();\n }\n\n async setStartDate(date?: string, monthYear?: string): Promise<void> {\n await (await this.getFirstDate()).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setEndDate(date?: string, monthYear?: string): Promise<void> {\n await (await this.getLastDate()).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async expectStartDateToBe(date: Date | string): Promise<void> {\n const dateTimePicker = this.getFirstDate();\n await this.dateUtil.expectDateToBe(await dateTimePicker, date);\n }\n\n async expectEndDateToBe(date: Date | string): Promise<void> {\n const dateTimePicker = this.getLastDate();\n await this.dateUtil.expectDateToBe(await dateTimePicker, date);\n }\n\n async removeStartDate(): Promise<void> {\n const dateTimePicker = await this.getFirstDateEditor();\n await this.dateUtil.removeDate(dateTimePicker);\n }\n\n async removeEndDate(): Promise<void> {\n const dateTimePicker = this.getLastDateEditor();\n await this.dateUtil.removeDate(await dateTimePicker);\n }\n\n async expectStartDateToBeInferred(): Promise<void> {\n const dateTimePicker = await this.getFirstDateEditor();\n await this.dateUtil.expectDateToBeInferred(dateTimePicker);\n }\n\n async expectEndDateToBeInferred(): Promise<void> {\n const dateTimePicker = await this.getLastDateEditor();\n await this.dateUtil.expectDateToBeInferred(dateTimePicker);\n }\n\n async expectStartDateNotDeletable(): Promise<void> {\n const dateTimePicker = await this.getFirstDate();\n await this.dateUtil.expectDateNotDeletable(dateTimePicker);\n }\n\n async expectEndDateNotDeletable(): Promise<void> {\n const dateTimePicker = await this.getLastDate();\n await this.dateUtil.expectDateNotDeletable(dateTimePicker);\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.phaseName.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async clickDuration(): Promise<void> {\n await this.phaseName.locator('.duration-editor').first().click();\n }\n\n async removeDuration(): Promise<void> {\n await this.phaseName.click();\n return await this.phaseName.locator(`.remove-duration`).click();\n }\n\n async expectNoDuration(): Promise<void> {\n expect(await this.phaseName.locator('.duration-editor').textContent()).toContain('');\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport moment from 'moment';\n\nexport class ReleasePropertiesPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async editReleaseName(name: string): Promise<void> {\n await this.page.locator('#release-form-title').clear();\n await this.page.locator('#release-form-title').fill(name);\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.task-description').hover();\n await this.page.locator('.display > .xl-icon').first().click();\n await this.page.locator('textarea').click();\n await this.page.locator('textarea').clear();\n await this.page.locator('textarea').fill(description);\n await this.page.getByText('Save').first().click();\n }\n\n async setScriptUsername(username: string): Promise<void> {\n await this.page.getByPlaceholder('Set user...').waitFor();\n await this.page.getByPlaceholder('Set user...').click();\n await this.page.locator('input[name=\"\"]').fill(username, { timeout: 2000 });\n }\n\n async setScriptUserPassword(password: string): Promise<void> {\n await this.page.locator('span[name=\"scriptUserPassword\"]').waitFor();\n await this.page.locator('span[name=\"scriptUserPassword\"]').click();\n await this.page.locator('input[name=\"scriptUserPassword\"]').fill(password, { timeout: 2000 });\n }\n\n async save(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).waitFor();\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.locator('.form-footer .last-saved')).toBeVisible();\n }\n\n async reset(): Promise<void> {\n await this.page.getByRole('button', { name: 'Reset' }).waitFor();\n await this.page.getByRole('button', { name: 'Reset' }).click();\n }\n\n async expectWithAttachment(filename: string): Promise<void> {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).toBeVisible();\n }\n\n async getAttachmentsListCount(): Promise<number> {\n return await this.page.locator('.attachments tr').count();\n }\n\n async uploadFile(filePath: string): Promise<void> {\n const fileChooserPromise = this.page.waitForEvent('filechooser');\n await this.page.locator('input[type=\"file\"]').click();\n const fileChooser = await fileChooserPromise;\n await fileChooser.setFiles(filePath);\n }\n\n async expectWithNoAttachment(filename: string): Promise<void> {\n const test = await this.page.locator('.attachments').isVisible();\n if (test) {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).not.toBeVisible();\n }\n }\n\n async downloadFile(filename: string): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n const downloadPromise1 = this.page.waitForEvent('download');\n await this.page.getByText(filename).click();\n const download = await downloadPromise1;\n // Wait for the download process to complete and save the downloaded file in given path.\n await download.saveAs('./core/xlr-ui/build/playwright/' + download.suggestedFilename());\n expect(download.suggestedFilename()).toBe(filename);\n }\n\n async deleteAttachment(fileName: string): Promise<void> {\n await this.page.getByRole('row', { name: fileName }).locator('span').click();\n await this.page.getByText('Remove').click();\n }\n\n async expectVariableDisplayed(variable: string, present: boolean): Promise<void> {\n if (present)\n await expect(this.page.locator(`#release-properties .form-group`, { hasText: variable })).toHaveCount(1);\n else await expect(this.page.locator(`#release-properties .form-group`, { hasText: variable })).toHaveCount(0);\n }\n\n async setScheduledStartDate(date?: string, monthYear?: string): Promise<void> {\n await this.page.locator(`.scheduled-start-date .date`).click();\n const prev = this.page.locator('.datepicker-days .prev');\n const next = this.page.locator('.datepicker-days .next');\n const monYear = this.page.locator('.datepicker-days .datepicker-switch');\n\n const thisMonth = moment(monthYear, 'MMMM YYYY').isBefore();\n\n while ((await monYear.textContent()) != monthYear) {\n if (thisMonth) {\n await prev.click();\n } else {\n await next.click();\n }\n }\n await this.page\n .getByRole('cell', { name: '' + date + '', exact: true })\n .first()\n .click();\n }\n\n async setScheduledStartTime(hrs?: string, mins?: string, meridian?: string): Promise<void> {\n await this.page.locator('.scheduled-start-date .time-picker-holder').click();\n if (typeof hrs !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-hour').click();\n await this.page.locator('.bootstrap-timepicker-hour').clear();\n await this.page.locator('.bootstrap-timepicker-hour').fill(hrs);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-minute').click();\n await this.page.locator('.bootstrap-timepicker-minute').clear();\n await this.page.locator('.bootstrap-timepicker-minute').fill(mins);\n }\n if (typeof meridian !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-meridian').click();\n await this.page.locator('.bootstrap-timepicker-meridian').clear();\n await this.page.locator('.bootstrap-timepicker-meridian').fill(meridian);\n }\n await this.page.keyboard.press('Escape');\n }\n\n async setDuration(days?: string, hours?: string, mins?: string): Promise<void> {\n await this.page.locator('.duration-editor').click();\n if (typeof days !== 'undefined') {\n await this.page.locator('.days').click();\n await this.page.locator('.days').clear();\n await this.page.locator('.days').fill(days);\n }\n if (typeof hours !== 'undefined') {\n await this.page.locator('.hours').click();\n await this.page.locator('.hours').clear();\n await this.page.locator('.hours').fill(hours);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.minutes').click();\n await this.page.locator('.minutes').clear();\n await this.page.locator('.minutes').fill(mins);\n }\n await this.page.keyboard.press('Escape');\n }\n\n async expectScheduledStartDateToBe(date: string): Promise<void> {\n expect(await this.page.locator(`.scheduled-start-date .date input`).getAttribute('value')).toContain(date);\n }\n\n async expectScheduledStartTimeToBe(date: string): Promise<void> {\n expect(await this.page.locator(`.scheduled-start-date .time input`).getAttribute('value')).toContain(date);\n }\n\n async expectDueDateToBe(date: string): Promise<void> {\n expect(await this.page.locator('.due-date .date input').getAttribute('value')).toContain(date);\n }\n\n async expectedDueDateTime(time: string): Promise<void> {\n expect(await this.page.locator('.due-date .time input').getAttribute('value')).toContain(time);\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.page.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async setDueDate(hrs?: string, min?: string, meridian?: string): Promise<void> {\n await this.page.locator('.due-date .time-picker-holder').click();\n if (typeof hrs !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-hour').click();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-hour').clear();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-hour').fill(hrs);\n }\n if (typeof min !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-minute').click();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-minute').clear();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-minute').fill(min);\n }\n if (typeof meridian !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-meridian').click();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-meridian').clear();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-meridian').fill(meridian);\n }\n await this.page.keyboard.press('Escape');\n }\n\n async checkAbortOnFailure(): Promise<void> {\n await this.page.locator('#release-form-abort-on-failure').check();\n await expect(this.page.locator('#release-form-abort-on-failure')).toBeChecked();\n }\n\n async expectDescriptionToBe(description: string): Promise<void> {\n expect(await this.page.locator('.release-description p').textContent()).toContain(description);\n }\n\n async expectReleaseNameToBe(name: string): Promise<void> {\n await expect(this.page.locator('form[name=\"releasePropertiesForm\"]')).toContainText('Properties for ' + name);\n }\n\n async expectStartDateReadonly(): Promise<void> {\n await expect(\n this.page\n .locator('#release-properties .form-group')\n .filter({ hasText: 'Start date' })\n .locator('.date-editor.readonly'),\n ).toBeVisible();\n }\n\n async expectEndDateReadonly(): Promise<void> {\n await expect(\n this.page\n .locator('#release-properties .form-group')\n .filter({ hasText: 'End date' })\n .locator('.date-editor.readonly'),\n ).toBeVisible();\n }\n\n async setOwner(user: string): Promise<void> {\n await this.page.locator('.release-owner').click();\n await this.page.locator('.release-owner input').clear();\n await this.page.locator('.release-owner input').fill(user);\n }\n\n async expectPageTitleToBeInBreadcrumbLink(releaseName: string): Promise<void> {\n expect(await this.page.locator('.dot-breadcrumbs a').allTextContents()).toContain(releaseName);\n }\n\n async reloadPage(): Promise<void> {\n await this.page.reload({ timeout: 3000 });\n }\n\n async expectOwnerToBe(user: string): Promise<void> {\n await expect(this.page.locator('.release-owner')).toContainText(user);\n }\n\n async expectReleaseTaggedWith(tagName: string): Promise<void> {\n await expect(this.page.locator('#tags')).toContainText(tagName);\n }\n\n async expectTemplateTitleToBe(templateTitle: string): Promise<void> {\n await expect(this.page.locator('[data-test=\"created-from-template\"]')).toContainText(templateTitle);\n }\n\n async expectRiskProfileTitleToBe(riskProfile: string): Promise<void> {\n await expect(this.page.locator('[data-test=\"release-risk-profile\"]')).toContainText(riskProfile);\n }\n\n async expectStartFromReleaseToBe(parentRelease: string): Promise<void> {\n await expect(this.page.locator('.started-from-release')).toHaveText(parentRelease);\n }\n\n async expectTemplateURLToBe(templateURL: string): Promise<void> {\n expect(await this.page.locator('[data-test=\"created-from-template\"]').getAttribute('href')).toContain(templateURL);\n }\n\n async expectStartFromReleaseURLToBe(parentReleaseURL: string): Promise<void> {\n expect(await this.page.locator('.started-from-release').getAttribute('href')).toContain(parentReleaseURL);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ReleaseTeamsAndPermissionsPage extends WithPage {\n saveButton: Locator;\n resetButton: Locator;\n constructor(page: Page) {\n super(page);\n this.resetButton = this.page.getByRole('button', { name: 'Reset' });\n this.saveButton = this.page.getByRole('button', { name: 'Save' });\n }\n\n async expectSaveButtonDisabled(): Promise<void> {\n expect(this.saveButton).toBeDisabled();\n }\n\n async expectUserIsAssignedToTeam(teamName: string, userName: string): Promise<void> {\n const releaseAdminRow = this.page.locator('#teams-permissions-table tr', { hasText: teamName });\n await expect(releaseAdminRow.locator('span.tag-wrapper.tag-label', { hasText: userName })).toBeVisible();\n }\n}\n","import { WithPage } from '../WithPage';\nimport { Locator, Page, expect } from '@playwright/test';\nimport { DateUtil } from '../common/dateUtil';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class ReleaseTableViewPage extends WithPage {\n commentBox: Locator;\n contextMenuButton: Locator;\n completeButton: Locator;\n dateUtil: DateUtil;\n refreshButton: Locator;\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.commentBox = this.page.locator(`.input-block-level`);\n this.contextMenuButton = this.page.locator('#context-menu-container li');\n this.completeButton = this.page.getByTestId('release-grid-complete-btn');\n this.dateUtil = new DateUtil(page);\n this.refreshButton = this.page.getByTestId('refresh-btn');\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async openContextMenuForTask(taskTitle: string): Promise<void> {\n await this.page\n .locator('.name-cell-wrapper')\n .filter({ hasText: taskTitle })\n .locator('.context-menu-button')\n .click();\n }\n\n // eslint-disable-next-line max-params\n async callMenuOptionsForTask(\n taskTitle: string,\n option: string,\n taskGroup?: string,\n taskType?: string,\n ): Promise<void> {\n await expect(async () => {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText(option).click({ timeout: 1000 });\n }).toPass();\n if (await this.commentBox.isVisible()) {\n await this.commentBox.fill(' Automation Test Comment');\n } else if (await this.page.getByRole('heading', { name: 'Change task type' }).isVisible()) {\n await this.page.getByPlaceholder('Start typing to filter task').click();\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n await this.page.locator('#task-selector').fill(taskGroup);\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n await this.page.getByTestId(taskType).click();\n }\n if (await this.page.getByRole('button', { name: option, exact: true }).isVisible())\n await this.page.getByRole('button', { name: option, exact: true }).click();\n }\n\n async expectAssignToUser(taskTitle: string, username: string): Promise<void> {\n await this.refreshButton.click();\n expect(\n await this.page\n .locator('.ui-grid-row')\n .filter({ hasText: taskTitle })\n .locator(`span[display-user=\"row.entity.planItem.owner\"] span`)\n .textContent(),\n ).toContain(username);\n }\n\n async expectToHasGateIcon(taskTitle: string): Promise<void> {\n await expect(\n this.page.locator('.ui-grid-row').filter({ hasText: taskTitle }).locator('.marker-check-icon'),\n ).toBeVisible();\n }\n\n async expectTaskRowCountToBe(title: string, expectedCount: number): Promise<void> {\n await this.refreshButton.click();\n await expect(this.page.locator('.name-cell-title').filter({ hasText: title })).toHaveCount(expectedCount);\n }\n\n async setHeaderFilter(columnTitle: string, valueToFilter: string): Promise<void> {\n const filter = this.page.locator(`.ui-grid-header-cell`).filter({ hasText: columnTitle }).locator(`input`);\n await filter.clear();\n await filter.fill(valueToFilter);\n }\n\n async expectRowCountToBe(cellCount: number): Promise<void> {\n await expect(this.page.locator('.ui-grid-canvas .name-cell')).toHaveCount(cellCount);\n }\n\n async filterStartDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator(`.ui-grid-header-cell`).filter({ hasText: 'Start Date' }).locator(`input`).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async filterEndDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator(`.ui-grid-header-cell`).filter({ hasText: 'End Date' }).locator(`input`).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async openTaskDrawer(taskTitle: string): Promise<TaskDrawer> {\n await this.page.locator('.name-cell-title').filter({ hasText: taskTitle }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async collapseNthRowByIndex(Indexnumber: number): Promise<void> {\n await this.page.locator('.task-group-toggle .xl-icon.arrow-down-icon').nth(Indexnumber).click();\n }\n\n async closePhaseModal(): Promise<void> {\n await this.page.locator(\"button[type='button'] i[class='xl-icon close-icon']\").click();\n }\n\n async expectTaskToHaveStatus(taskTitle: string, status: string): Promise<void> {\n await this.refreshButton.click();\n await expect(this.page.locator('.ui-grid-row').filter({ hasText: taskTitle }).locator('.label')).toContainText(\n status,\n );\n }\n\n async expectOverdueOnEndDate(taskTitle: string): Promise<void> {\n await expect(\n this.page.locator(`.ui-grid-row`).filter({ hasText: taskTitle }).locator(`i.xl-icon.delay-icon.overdue-icon`),\n ).toBeVisible();\n }\n\n async selectTask(taskTitle: string): Promise<void> {\n const checkboxLocator = this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: taskTitle })\n .locator(`input.item-selector`);\n await expect(async () => {\n await checkboxLocator.click({ force: true });\n await expect(checkboxLocator).toBeChecked({ timeout: 1000 });\n }).toPass();\n }\n\n async expectSelectedTasksCounter(text: string): Promise<void> {\n await expect(this.page.getByTestId('release-grid-selected-tasks')).toBeVisible();\n await expect(this.page.getByTestId('release-grid-selected-tasks')).toContainText(text);\n }\n\n async clearSelection(): Promise<this> {\n await this.page.getByTestId('release-grid-unselect-btn').click();\n return this;\n }\n\n async assignSelectedTasks(owner?: string, team?: string): Promise<this> {\n await this.page.getByText('Assign to').click();\n if (owner) {\n const ownerSelector = this.page.locator('.task-owner');\n await ownerSelector.focus();\n await ownerSelector.click();\n await this.page.getByLabel('*').fill(owner);\n await this.page.locator('a').filter({ hasText: owner }).click();\n }\n if (team) {\n const teamSelector = this.page.locator('.task-team > .display');\n await teamSelector.focus();\n await teamSelector.click();\n await this.page.getByLabel(team, { exact: true }).selectOption(team);\n }\n await this.page.getByRole('button', { name: 'Assign' }).click();\n return this;\n }\n\n async expectSuccessMessage(successMessage: string): Promise<this> {\n await expect(this.page.getByLabel('success')).toContainText(successMessage);\n return this;\n }\n\n async completeSelectedTasks(comment: string): Promise<this> {\n await this.completeButton.click();\n await this.page.getByPlaceholder('Give feedback or place a').fill(comment);\n await this.page.locator('.modal-footer').getByRole('button', { name: 'Complete' }).click();\n return this;\n }\n\n async selectFromMoreActions(menuItem: string): Promise<this> {\n await this.page.getByTestId('release-grid-dropdown-btn').click();\n await this.page.getByRole('menuitem', { name: menuItem }).click();\n\n if (['Skip', 'Reopen', 'Retry', 'Fail'].includes(menuItem)) {\n await this.commentBox.fill('Automation Test Comment');\n }\n await this.page.getByRole('button', { name: menuItem, exact: true }).click();\n return this;\n }\n\n async addCommentToSelectedTask(comment: string): Promise<this> {\n await this.page.getByTestId('release-grid-comment-btn').click();\n await this.page.getByPlaceholder('Give feedback or place a').click();\n await this.page.getByPlaceholder('Give feedback or place a').fill(comment);\n await this.page.getByRole('button', { name: 'Comment' }).click();\n await expect(this.page.getByLabel('success')).toBeVisible();\n return this;\n }\n\n async selectSubtasks(item: string): Promise<this> {\n await this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: item })\n .locator(`.tasks-group-select`)\n .click({ force: true });\n return this;\n }\n\n async shiftSelectFromTo(taskFrom: string, taskTo: string): Promise<this> {\n await this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: taskFrom })\n .locator(`.item-selector`)\n .click({ force: true });\n await this.page.keyboard.down('Shift');\n await this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: taskTo })\n .locator(`.item-selector`)\n .click({ force: true });\n await this.page.keyboard.up('Shift');\n return this;\n }\n\n async isContextualMenuItemEnabled(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await expect(this.contextMenuButton.filter({ hasText: menuName })).not.toHaveClass(/disabled/);\n await expect(this.contextMenuButton.filter({ hasText: menuName }).locator('a')).not.toBeDisabled();\n await this.closeContextMenu();\n }\n\n async isContextualMenuItemDisabled(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n const menuItem = this.contextMenuButton.filter({ hasText: menuName });\n await expect(menuItem).toHaveClass(/disabled/);\n const anchorTag = menuItem.locator('a');\n const disabledAttribute = await anchorTag.getAttribute('disabled');\n expect(disabledAttribute).not.toBeNull();\n await this.closeContextMenu();\n }\n\n async closeContextMenu(): Promise<void> {\n await this.page.locator('#release-header').click();\n }\n\n async expectDisabledActions(actionName: string): Promise<this> {\n await expect(this.page.getByTestId(`release-grid-${actionName}-btn`)).toBeDisabled();\n return this;\n }\n\n async expectDisabledActionsOnMoreActionsMenu(menuItem: Array<string> | string): Promise<this> {\n await this.page.getByTestId('release-grid-dropdown-btn').click();\n if (menuItem instanceof Array) {\n for (const val of menuItem) {\n await expect(this.page.getByRole('button', { name: val, exact: true })).toBeDisabled();\n }\n } else {\n await expect(this.page.getByRole('button', { name: menuItem, exact: true })).toBeDisabled();\n }\n await this.closeContextMenu();\n return this;\n }\n}\n","import * as fs from 'fs';\nimport path from 'path';\nimport { WithPage } from '../WithPage';\nimport { Locator, Page, expect } from '@playwright/test';\n\nexport class Util extends WithPage {\n tempDir: string;\n content: string;\n closeIcon: Locator;\n\n constructor(page: Page) {\n super(page);\n this.tempDir = '';\n this.content = '';\n this.closeIcon = this.page.locator('.xl-icon.close-icon');\n }\n\n async createTempFile(fileName: path.ParsedPath | string, testInfo: any): Promise<void> {\n const content = fileName.toString();\n const tempDir = testInfo.outputPath(fileName.toString());\n fs.promises.writeFile(tempDir, content, 'utf8');\n }\n\n async expandAllFolders(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('.rstm-toggle-icon.xl-icon.arrow-right-icon');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandAllFolders();\n }\n }\n await expect(icExpandTreeview1).not.toBeVisible();\n }\n\n async openSideNavMenu(menuItem: string): Promise<void> {\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).scrollIntoViewIfNeeded();\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).click();\n }\n\n async openNestedMenuItem(nestedMenuItem: string): Promise<void> {\n await this.page.locator('.MuiList-root li').getByText(nestedMenuItem, { exact: true }).scrollIntoViewIfNeeded();\n await this.page.locator('.MuiList-root li').getByText(nestedMenuItem, { exact: true }).click();\n }\n\n async clickCloseIcon(): Promise<void> {\n await this.closeIcon.click();\n }\n\n async clickOnStatusField(): Promise<void> {\n await this.page.locator('.ci-filter-status.ng-isolate-scope').click();\n }\n\n async clickOnStatus(statusNames: string[]): Promise<void> {\n await this.clickOnStatusClearAll();\n await this.clickOnStatusField();\n for (let i = 0; i < statusNames.length; i++) {\n await this.page.locator(`i.xl-icon.icon-s.checkbox[data='${statusNames[i]}']`).click();\n }\n // Clicking outside to close the grid dropdown\n await this.page.getByText('Status').click();\n }\n\n async clickOnStatusClearAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Clear all' }).click();\n await this.page.getByText('Status').click();\n }\n\n async clickOnStatusSelectAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Select all' }).click();\n await this.page.getByText('Status').click();\n }\n\n async setOrderBy(orderBy: string): Promise<void> {\n await this.page.locator('.order-by-filter .btn:first-child').click();\n await this.page.locator(`.order-by-filter .bootstrap-link:has-text('${orderBy}')`).click();\n }\n\n async setSearchFilter(filterText: string): Promise<void> {\n await this.page.locator('.searchFilter').fill(filterText);\n }\n\n async clearSearchFilter(): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n }\n\n async leaveWithoutSaving(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Confirm leave' })).toBeVisible();\n await expect(this.page.getByRole('paragraph')).toContainText('You have unsaved changes that will be lost.');\n await this.page.getByRole('button', { name: 'Leave without saving' }).click();\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { TriggersPage } from '../TriggersPage';\nimport { WithPage } from '../WithPage';\nimport { VariablePage } from '../variablePage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\nimport { ReleaseCreatePage } from './releaseCreatePage';\nimport { ReleaseGanttPage } from './releaseGanttPage';\nimport { ReleasePropertiesPage } from './releasePropertiesPage';\nimport { ReleaseTeamsAndPermissionsPage } from './releaseTeamsAndPermissionsPage';\nimport { ReleaseTableViewPage } from './releaseTableViewPage';\nimport { DateUtil } from '../common/dateUtil';\nimport { Util } from '../common/util';\n\nexport class ReleasePage extends WithPage {\n private defaultTimeout = 10_000;\n addPhaseBtn: Locator;\n createPage: ReleaseCreatePage;\n ganttPage: ReleaseGanttPage;\n tableView: ReleaseTableViewPage;\n taskDrawer: TaskDrawer;\n teamsPermissions: ReleaseTeamsAndPermissionsPage;\n phaseTitle: Locator;\n properties: ReleasePropertiesPage;\n variables: VariablePage;\n util: Util;\n\n constructor(page: Page) {\n super(page);\n this.addPhaseBtn = this.page.getByTestId('add-phase-btn');\n this.createPage = new ReleaseCreatePage(page);\n this.ganttPage = new ReleaseGanttPage(page);\n this.tableView = new ReleaseTableViewPage(page);\n this.taskDrawer = new TaskDrawer(page);\n this.teamsPermissions = new ReleaseTeamsAndPermissionsPage(page);\n this.phaseTitle = this.page.locator('.phase .phase-title');\n this.properties = new ReleasePropertiesPage(page);\n this.variables = new VariablePage(page);\n this.util = new Util(page);\n }\n\n async openTriggers(): Promise<TriggersPage> {\n await this.openSubPage('Triggers');\n return new TriggersPage(this.page);\n }\n\n async abort(comment = 'Abort for testing'): Promise<void> {\n await this.page.getByTestId('abort-btn').waitFor();\n await this.page.getByTestId('abort-btn').click();\n await this.page.getByPlaceholder('Provide a reason').fill(comment);\n await this.page.getByRole('button', { name: 'Abort' }).click();\n await this.page.locator('.progress-status-and-percentage').waitFor();\n await expect(this.page.locator('.progress-status-and-percentage')).toContainText('Aborted');\n }\n\n getPhase(phaseName: string): Phase {\n return new Phase(this.page, phaseName);\n }\n\n async expectPhaseCountToBe(expectedPhaseCount: number): Promise<void> {\n const phaseCount = await this.page.locator('.phase').count();\n expect(phaseCount).toBe(expectedPhaseCount);\n }\n\n async expectVariableToBeFound(variableName: string): Promise<void> {\n await expect(this.page.locator(`span.variable:has-text(\"${variableName}\")`)).toHaveCount(1);\n }\n\n async expectNotFlagged(): Promise<void> {\n await expect(this.page.locator('.flag-none-icon')).toBeHidden();\n }\n\n async expectRiskFlagOnTaskCard(): Promise<void> {\n await expect(this.page.locator('.risk-flag-icon')).toBeVisible();\n }\n\n async expectBlackoutIconOnTaskCard(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task').filter({ hasText: taskTitle }).locator('.circle-minus-icon')).toBeVisible();\n }\n\n async expectFlagOnCompletedTaskCard(): Promise<void> {\n await expect(this.page.locator('.flag-count')).toBeVisible();\n }\n\n async refresh(): Promise<void> {\n await this.page.reload();\n await this.page.waitForSelector('#release');\n }\n\n async start(): Promise<void> {\n await this.page.getByTestId('start-btn').click();\n await this.page.getByRole('button', { name: 'Start' }).click();\n await expect(this.page.locator('.dot-dialog')).not.toBeVisible();\n await this.page.waitForSelector('#release');\n }\n\n async waitForCompletion(timeout = this.defaultTimeout): Promise<void> {\n await this.page.locator('#release.completed').waitFor({ timeout });\n }\n\n async waitForTaskCompleted(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.completed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskNeedsInput(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.waiting_for_input').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async waitForTaskCompletedInAdvance(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.completed_in_advance').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskInProgress(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskFailed(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.failed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskFailing(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.failing').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async waitForTaskSkipped(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.skipped').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskSkippedInAdvance(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.skipped_in_advance').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskAborted(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.aborted').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForStatusLine(statusLine: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task .status-line').getByText(statusLine, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async expectTaskStatusLineToContain(taskTitle: string, info: string): Promise<void> {\n await expect(this.page.locator('.task').filter({ hasText: taskTitle }).locator('.status-line')).toContainText(info);\n }\n\n async expectTaskStatusLineToContainHref(taskTitle: string, link: RegExp): Promise<void> {\n const taskInfo = this.page.locator('.task').filter({ hasText: taskTitle }).locator('.status-line a');\n await expect(taskInfo).toHaveAttribute('href', link);\n }\n\n async waitForTaskStarted(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByTitle(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskPlanned(title: string): Promise<void> {\n await expect(this.page.locator('.task.planned').getByText(title, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async clickOnStatusLine(statusLine: string): Promise<void> {\n await this.page.locator('.task .status-line a').getByText(statusLine, { exact: true }).click();\n }\n\n async expectTaskCompletedInAdvance(taskTitle: string): Promise<void> {\n await expect(\n this.page.locator('#release-content .completed_in_advance .task-title').filter({ hasText: taskTitle }),\n ).toBeVisible();\n }\n\n async expectTaskPending(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.pending').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n\n async expectCurrentTaskToContain(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.active .task-title').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n\n async openManualTaskDetails(title: string): Promise<void> {\n await this.page.locator(`text=${title}`).click({ force: true });\n await expect(this.page.locator('div').filter({ hasText: title }).first()).toBeVisible();\n }\n\n async reopenTask(comment: string): Promise<void> {\n await this.page\n .locator('div')\n .filter({ hasText: /^Reopen$/ })\n .click();\n await this.page.getByTestId('task-action-comment').click();\n await this.page.getByTestId('task-action-comment').fill(comment);\n await this.page.locator('button', { hasText: 'Reopen' }).click();\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.task-header').getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromTableView(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.name-cell-title').getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromGrantt(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.gantt_tree_content').getByText(taskName, { exact: true }).dblclick();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openVariables(): Promise<void> {\n await this.util.openSideNavMenu('Variables');\n await expect(this.page.getByLabel('breadcrumb').getByText('Variables', { exact: true })).toBeVisible();\n }\n\n async openProperties(): Promise<void> {\n await this.util.openSideNavMenu('Properties');\n await expect(this.page.getByLabel('breadcrumb').getByText('Properties')).toBeVisible();\n }\n\n async openReleaseFlow(): Promise<void> {\n await this.util.openSideNavMenu('Flow');\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n\n async openRelationships(): Promise<void> {\n await this.util.openSideNavMenu('Relationships');\n await expect(this.page.getByLabel('breadcrumb').getByText('Relationships')).toBeVisible();\n }\n\n async openTeamsPermissions(): Promise<void> {\n await this.util.openSideNavMenu('Teams & Permissions');\n await expect(this.page.getByLabel('breadcrumb').getByText('Teams & Permissions')).toBeVisible();\n }\n\n async openDashboard(): Promise<void> {\n await this.util.openSideNavMenu('Dashboard');\n await expect(this.page.getByLabel('breadcrumb').getByText('Dashboard')).toBeVisible();\n }\n\n async openHistory(): Promise<void> {\n await this.util.openSideNavMenu('History');\n await expect(this.page.getByLabel('breadcrumb').getByText('History')).toBeVisible();\n }\n\n private async openReleaseMenu(menuItem: string): Promise<void> {\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).click();\n }\n\n private async openSubPage(subpage: string): Promise<void> {\n await this.page.locator('ul.side-nav li', { hasText: subpage }).click();\n }\n\n async openTask(taskName: string): Promise<void> {\n await this.page.getByTitle(taskName, { exact: true }).click();\n }\n\n async collapseAllTaskView(): Promise<void> {\n const icCollapseTreeview1 = this.page.locator('div.pull-left.expander.ng-scope i.xl-icon.arrow-down-icon');\n for (const element of await icCollapseTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.collapseAllTaskView();\n }\n }\n }\n\n async expandAllTaskView(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('div.pull-left.expander.ng-scope i.xl-icon.arrow-right-icon');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandAllTaskView();\n }\n }\n }\n\n async expectTemplateLabelNotToBePresent(): Promise<void> {\n await expect(this.page.locator('.dot-chip').filter({ hasText: 'TEMPLATE' })).not.toBeVisible();\n }\n\n async expectAbortedStatusToBePresent(): Promise<void> {\n await this.page.locator('.progress-status-and-percentage').waitFor({ timeout: 10000 });\n await expect(this.page.locator('.progress-status-and-percentage')).toHaveText('Aborted');\n }\n\n async expectInProgressStatusToBePresent(): Promise<void> {\n await this.page.locator('.release-status').waitFor({ timeout: 10000 });\n await expect(this.page.locator('.release-status')).toHaveText('In progress');\n }\n\n async expectFailedStatusToBePresent(): Promise<void> {\n await this.page.locator('.progress-status-and-percentage').waitFor({ timeout: 10000 });\n await expect(this.page.locator('.progress-status-and-percentage')).toHaveText('Failed0%');\n }\n\n async openTableView(): Promise<void> {\n await this.util.openSideNavMenu('Table');\n await expect(this.page.locator('.release-grid-container')).toBeVisible();\n }\n\n async openPlannerView(): Promise<void> {\n await this.util.openSideNavMenu('Planner');\n await expect(this.page.locator('.gantt-container')).toBeVisible();\n }\n\n async expandGanttFolder(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('.gantt_tree_icon.gantt_open');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandGanttFolder();\n }\n }\n }\n\n async backToRelease(): Promise<void> {\n await this.page.locator('.icon-back').click();\n }\n\n async expectTitleToBeInBreadcrumbLink(title: string): Promise<void> {\n await expect(this.page.locator('.dot-breadcrumbs a', { hasText: title })).toBeVisible();\n }\n\n async expectHasPhase(title: string): Promise<void> {\n await expect(this.page.locator(`#release-content .phase-title`, { hasText: title })).toBeVisible();\n }\n\n async addNewPhase(phaseName?: string): Promise<void> {\n await this.addPhaseBtn.click();\n if (phaseName) {\n await this.phaseTitle.getByText('New Phase').click();\n await this.phaseTitle.getByRole('textbox').clear();\n await this.phaseTitle.getByRole('textbox').fill(phaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: phaseName })).toBeVisible();\n }\n }\n\n async renamePhase(oldPhaseName: string, newPhaseName: string): Promise<void> {\n await this.phaseTitle.getByText(oldPhaseName).click();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').clear();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').fill(newPhaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: newPhaseName })).toBeVisible();\n }\n\n async exportRelease(exportAs = 'Audit report (Excel)'): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n await this.page.getByTestId('template-export-btn').click();\n const downloadPromise = this.page.waitForEvent('download');\n await this.page.getByRole('link', { name: exportAs }).click();\n await downloadPromise;\n }\n\n async expectTaskToBePresent(taskName: string): Promise<void> {\n await expect(this.page.locator('.task .task-title').filter({ hasText: taskName })).toBeVisible();\n }\n\n async expectTaskNotToBePresent(taskName: string): Promise<void> {\n await expect(this.page.locator('.task .task-title').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async toggleTaskFilter(filterOption: string): Promise<void> {\n await this.clickFilterOptions();\n await this.page.locator(`#filter-container #${filterOption}`).click();\n await this.clickFilterOptions();\n }\n\n async clickFilterOptions(): Promise<void> {\n await this.page.locator('#release-header .dropdown-button').click();\n }\n\n async expectTaskToHaveFailed(title: string, failCount: number): Promise<void> {\n await expect(\n this.page.locator(`.task`).filter({ hasText: title }).locator(`.task-infos .failure-count.count-warning`),\n ).toBeVisible();\n await expect(\n this.page.locator(`.task`).filter({ hasText: title }).locator(`.task-infos .failure-count.count-warning`),\n ).toContainText(failCount.toString());\n }\n\n async expectTaskToHaveBeenDelayed(title: string): Promise<void> {\n await expect(\n this.page.locator(`.task`).filter({ hasText: title }).locator(`.task-infos .delay-count`),\n ).toBeVisible();\n }\n\n async expectOnePhaseDisplayed(): Promise<void> {\n expect(await this.page.locator('.phase-content').count()).toBe(1);\n }\n\n async restartPhases(): Promise<RestartPhaseModel> {\n await this.page.getByTestId('restart-btn').click();\n return new RestartPhaseModel(this.page);\n }\n\n async expectAddPhaseNotVisible(): Promise<void> {\n await expect(this.addPhaseBtn).not.toBeVisible();\n }\n\n async expectAddTaskNotVisible(): Promise<void> {\n await expect(this.page.locator('.add-task.link')).not.toBeVisible();\n }\n\n async expectTaskCount(count: number): Promise<void> {\n expect(await this.page.locator('.task-container').count()).toBe(count);\n }\n\n async expectCurrentTaskCount(count: number): Promise<void> {\n expect(await this.page.locator('.task.active').count()).toBe(count);\n }\n}\n\nclass Phase extends WithPage {\n private readonly phaseLocator: Locator;\n commentBox: Locator;\n contextMenuButton: Locator;\n dateUtil: DateUtil;\n\n constructor(page: Page, phaseName: string) {\n super(page);\n this.phaseLocator = page.locator('.phase', { hasText: phaseName });\n this.commentBox = this.page.locator(`.input-block-level`);\n this.contextMenuButton = this.page.locator('#context-menu-container li');\n this.dateUtil = new DateUtil(page);\n }\n\n async setTitle(title: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header .display').click();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').clear();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').fill(title);\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').blur();\n }\n\n async isMenuItemEnabled(menuName: string, taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n const menuItem = this.contextMenuButton.filter({\n has: this.page.locator('a').getByText(menuName, { exact: true }),\n });\n await expect(menuItem).not.toHaveClass(/disabled/);\n await this.closeContextMenu();\n }\n\n async isMenuItemDisabled(menuName: string, taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n const menuItem = this.contextMenuButton.filter({\n has: this.page.locator('a').getByText(menuName, { exact: true }),\n });\n await expect(menuItem).toHaveClass(/disabled/);\n await this.closeContextMenu();\n }\n\n async expectMenuItemIsNotVisible(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await expect(this.contextMenuButton.getByText(menuName, { exact: true })).not.toBeVisible();\n await this.closeContextMenu();\n }\n\n async expectMenuItemIsVisible(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await expect(this.contextMenuButton.getByText(menuName, { exact: true })).toBeVisible();\n await this.closeContextMenu();\n }\n\n async expectSubmenuItemIsVisible(parentMenuItem: string, menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.contextMenuButton.getByText(parentMenuItem, { exact: true }).hover();\n await expect(\n this.page\n .locator(`#context-menu-container ul[data-id=\"${parentMenuItem}\"] li`)\n .getByText(menuName, { exact: true }),\n ).toBeVisible();\n await this.closeContextMenu();\n }\n\n async clickSubmenuItemForTask(parentMenuItem: string, menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.contextMenuButton.getByText(parentMenuItem, { exact: true }).hover();\n await this.page\n .locator(`#context-menu-container ul[data-id=\"${parentMenuItem}\"] li a`)\n .getByText(menuName, { exact: true })\n .click();\n }\n\n async expectSnackbarSuccessMessage(message: string): Promise<void> {\n const snackbar = this.page.locator('.dot-snackbar[severity=\"success\"]');\n await expect(snackbar.locator('[aria-label=\"success\"]')).toHaveText(message);\n await snackbar.getByRole('button').click();\n }\n\n async closeContextMenu(): Promise<void> {\n await this.page.locator('#release-header').click();\n }\n\n async expectTaskBorderWithColor(taskName: string, color: string): Promise<void> {\n await expect(this.page.locator(`.task-box:has-text('${taskName}')`)).toHaveCSS('border-top-color', color);\n }\n\n async pasteTaskFromTaskGenerator(): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n const pasteButton = this.page.locator('button[data-testid=\"paste-copied-task-btn\"]');\n await expect(pasteButton).toBeEnabled();\n await pasteButton.click();\n }\n\n async addTaskInPhase(taskTitle: string, taskGroup: string, taskType: string): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.page.locator('#task-selector').hover();\n await this.page.locator('button[aria-label=\"Clear\"]').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.locator('.icon-close').click();\n await this.page.locator('#task-title').fill(taskTitle);\n await this.page.getByTestId('save-select-task-btn').click();\n await this.page.locator('#release-header').click();\n await expect(this.phaseLocator.locator('.task-title').filter({ hasText: taskTitle })).toBeVisible();\n }\n\n async getNumberOfTasks(): Promise<number> {\n return await this.phaseLocator.locator('.task').count();\n }\n\n async expectToHaveNoneditableTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title > span')).toContainText(phaseTitle);\n }\n\n async expectToHaveTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title')).toContainText(phaseTitle);\n }\n\n async openContextMenuForTask(taskTitle: string, group = false): Promise<void> {\n if (!group)\n await this.phaseLocator.locator('.task').filter({ hasText: taskTitle }).locator('.context-menu-button').click();\n else\n await this.phaseLocator\n .locator('.task-group .task')\n .filter({ hasText: taskTitle })\n .locator('.context-menu-button')\n .click();\n }\n\n async skipFromContextMenu(comment: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Skip').click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Skip', exact: true }).click();\n }\n\n async completeFromContextMenu(taskTitle: string, comment: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Complete').click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Complete', exact: true }).click();\n }\n\n async changeTypeFromContextMenu(taskTitle: string, taskGroup: string, taskType: string): Promise<this> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Change type').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.getByRole('button', { name: 'Change type' }).click();\n return this;\n }\n\n async unlockFromContextMenu(taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n await this.page.locator('.dropdown-menu li').getByText('Unlock').click();\n await this.expectLockCheckMark(taskTitle, false);\n }\n\n async lockFromContextMenu(taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n await this.page.locator('.dropdown-menu li').getByText('Lock').click();\n await this.expectLockCheckMark(taskTitle, true);\n }\n\n async expectChangeTypeContextMenuDisabled(taskTitle: string, taskGroup: string, taskType: string): Promise<this> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Change type').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await expect(this.page.getByRole('button', { name: 'Change type' })).toBeDisabled();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async expectGateCheckMark(): Promise<this> {\n await expect(this.page.locator('.task-type-gatetask .marker-check-icon')).toBeVisible();\n return this;\n }\n\n async expectLockCheckMark(taskTitle: string, isVisible = true): Promise<this> {\n if (isVisible) {\n await expect(\n this.page.locator('.task-header').filter({ hasText: taskTitle }).locator('.lock-icon'),\n ).toBeVisible();\n } else {\n await expect(\n this.page.locator('.task-header').filter({ hasText: taskTitle }).locator('.lock-icon'),\n ).not.toBeVisible();\n }\n return this;\n }\n\n async expectFailureHandlerCheckMar(taskTitle: string, isVisible = true): Promise<this> {\n if (isVisible) {\n await expect(\n this.page.locator('.task').filter({ hasText: taskTitle }).locator('.failure-handler-icon'),\n ).toBeVisible();\n } else {\n await expect(\n this.page.locator('.task').filter({ hasText: taskTitle }).locator('.failure-handler-icon'),\n ).not.toBeVisible();\n }\n return this;\n }\n\n async expectNoOptionInChangeType(taskTitle: string, taskGroup: string): Promise<this> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Change type').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await expect(this.page.getByText('No options')).toBeVisible();\n await this.page.getByTestId('ArrowDropDownIcon').click();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async assignToMeFromContextMenu(taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Assign to me').click();\n }\n\n async duplicateFromContextMenu(taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Duplicate').click();\n await expect(this.page.locator('.task .task-title').getByText(`${taskTitle} copy`)).toBeVisible();\n }\n\n async expectTemplateLabelNotToBePresent(): Promise<void> {\n await expect(this.page.locator('.dot-chip').filter({ hasText: 'TEMPLATE' })).not.toBeVisible();\n }\n\n async openPhaseDetails(): Promise<void> {\n await this.phaseLocator.locator('.phase-details').click();\n }\n\n async close(): Promise<void> {\n await this.page.locator(\"button[type='button'] i[class='xl-icon close-icon']\").click();\n }\n\n async expectStartDateToBeDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal .start-date')).toBeVisible();\n }\n\n async expectDueDateToBeDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal .due-date')).toBeVisible();\n }\n\n async expectEndDateToBeDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal .end-date')).toBeVisible();\n }\n\n async setTitleFromPhaseDetails(title: string): Promise<void> {\n await this.page.locator('h4.phase-title').click();\n await this.page.locator('h4.phase-title input').fill(title);\n await this.page.locator('h4.phase-title input').press('Enter');\n await expect(this.page.locator('h4.phase-title')).toContainText(title);\n }\n\n async setDueDateFromPhaseDetails(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.openDatePicker('.modal .due-date .date-editor');\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setScheduledStartDateFromPhaseDetails(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.openDatePicker('.modal .scheduled-start-date .date-editor');\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n await this.dateUtil.expectDurationToBe(duration);\n }\n\n async setDurationFromPhaseDetails(days?: string, hours?: string, mins?: string): Promise<void> {\n await this.page.locator('.duration-editor').click();\n await this.dateUtil.setDuration(days, hours, mins);\n }\n\n async expectDueTimeToBe(format: string, date: Date | string): Promise<void> {\n const selector = this.page.locator('.modal .due-date .time-picker-holder input');\n await this.dateUtil.expectTimeToBe(selector, format, date);\n }\n\n async deleteTaskInPhase(taskName: string): Promise<void> {\n await this.page.locator('.task').filter({ hasText: taskName }).locator('.xl-icon.options-icon').click();\n await this.page.locator('.remove-task-button').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Task' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.phaseLocator.locator('li').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async deletePhase(phaseName: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header').filter({ hasText: phaseName }).locator('.actions').hover();\n await this.phaseLocator.locator('.phase-header').filter({ hasText: phaseName }).locator('.delete-icon').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Phase' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.phaseLocator.locator('.phase-header').filter({ hasText: phaseName })).not.toBeVisible();\n }\n\n async expectCompletedPhase(): Promise<void> {\n await expect(this.page.getByText('View all completed phases')).toBeVisible();\n }\n\n async clickViewAllCompletedPhase(): Promise<void> {\n await this.page.getByText('View all completed phases').click();\n }\n\n async expectTaskToBePresent(taskName: string, visible = true): Promise<void> {\n if (visible)\n await expect(this.phaseLocator.locator('.task .task-title').filter({ hasText: taskName })).toBeVisible();\n else await expect(this.phaseLocator.locator('.task .task-title').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async expectContainingTask(taskName: string, exist = true): Promise<void> {\n const taskHeaderLocator = this.phaseLocator.locator('.task-header').filter({ hasText: taskName });\n if (exist) {\n await expect(taskHeaderLocator).toContainText(taskName);\n } else {\n await expect(taskHeaderLocator).not.toContainText(taskName);\n }\n }\n\n // eslint-disable-next-line max-params\n async addTaskInGroup(\n currentGroupType: string,\n taskTitle: string,\n taskGroup: string,\n taskType: string,\n ): Promise<void> {\n const groupTaskLocator = this.phaseLocator\n .locator('li')\n .filter({ hasText: currentGroupType })\n .locator('a.add-task.link');\n\n await groupTaskLocator.click();\n await this.page.locator('#task-selector').hover();\n await this.page.locator('button[aria-label=\"Clear\"]').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.locator('.icon-close').click();\n await this.page.locator('#task-title').fill(taskTitle);\n await this.page.getByTestId('save-select-task-btn').click();\n await this.page.locator('#release-header').click();\n await expect(this.phaseLocator.filter({ hasText: currentGroupType }).getByText(taskTitle)).toBeVisible();\n }\n\n async openContextMenuForTaskInGroup(groupName: string, taskTitle: string): Promise<void> {\n const taskLocator = this.phaseLocator\n .filter({ hasText: groupName })\n .locator('.task')\n .filter({ hasText: taskTitle });\n await taskLocator.locator('.task .context-menu-button').click();\n }\n\n async duplicateFromContextualMenuInGroup(groupName: string, taskTitle: string): Promise<this> {\n await this.openContextMenuForTaskInGroup(groupName, taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Duplicate').click();\n return this;\n }\n\n async deleteFromContextualMenuInGroup(groupName: string, taskTitle: string): Promise<this> {\n await this.openContextMenuForTaskInGroup(groupName, taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n return this;\n }\n async duplicatePhase(): Promise<void> {\n await this.phaseLocator.locator('.duplicate-phase').click();\n }\n\n async expectActionsDisabled(): Promise<void> {\n await expect(this.phaseLocator.locator('.duplicate-phase')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.delete-phase')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.task .duplicate-task')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.task .delete-task')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.task-generator .add-task')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.display')).toHaveCount(0);\n }\n\n async expectTaskFailureManualPermission(): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n const checkboxElement = await this.page.getByTestId('save-select-task-btn').isEnabled();\n if (!checkboxElement) {\n await this.page.getByTestId('cancel-select-task-btn').click();\n await this.phaseLocator.getByText('Add task').click();\n }\n await this.page.getByTestId('save-select-task-btn').click();\n await expect(\n this.page.locator('p').filter({ hasText: 'You don’t have permission to view this page.' }),\n ).toBeVisible();\n }\n\n async expectCurrentTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.active').count()).toBe(count);\n }\n\n async expectCompletedTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.completed').count()).toBe(count);\n }\n\n async expectFailedTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.failed').count()).toBe(count);\n }\n\n async expectFailingTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.failing').count()).toBe(count);\n }\n\n async expectSkippedTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.skipped').count()).toBe(count);\n }\n}\n\nclass RestartPhaseModel extends WithPage {\n continueBtn: Locator;\n\n constructor(page: Page) {\n super(page);\n this.continueBtn = this.page.getByRole('button', { name: 'Continue' });\n }\n\n async fromPhase(phase: string): Promise<void> {\n await this.page.locator('.modal select[data-test=\"fromPhase\"]').selectOption(phase);\n }\n\n async fromTask(task: string): Promise<void> {\n await this.page.locator('.modal select[data-test=\"fromTask\"]').selectOption(task);\n }\n\n async expectNoTaskSelectorVisible(): Promise<void> {\n await expect(this.page.locator('.modal select[data-test=\"fromTask\"]')).not.toBeVisible();\n }\n\n async continue(): Promise<void> {\n await this.page.locator('.modal .continue').click();\n }\n\n async resumeNow(): Promise<void> {\n await this.page.locator('.modal .resume-now').click();\n }\n\n async resumeLater(): Promise<void> {\n await this.page.locator('.modal .resume-later').click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ApplicationsPage extends WithPage {\n async goToApplicationsPage(): Promise<this> {\n await this.page.goto('./#/applications');\n await expect(this.page).toHaveTitle('Applications - Digital.ai Release');\n return this;\n }\n\n async addNewApplication(applicationName: string): Promise<this> {\n await this.page.locator(`//button[normalize-space()='New application']`).click();\n await this.page.locator(`input[placeholder='Add name...']`).type(applicationName);\n await this.page.locator(`//button[normalize-space()='Save']`).click();\n return this;\n }\n\n async verifyApplicationisCreated(applicationName: string): Promise<this> {\n await this.page.waitForSelector(`div[title='${applicationName}'] strong`);\n return this;\n }\n\n async createApplicationAndLinkEnvironment(environmentName: string, applicationName: string): Promise<this> {\n await this.page.locator(`//button[normalize-space()='New application']`).click();\n await this.page.locator(`input[placeholder='Add name...']`).type(applicationName);\n await this.page.locator(\"input[placeholder='Filter environment name...']\").type(environmentName);\n await this.page.locator(`div[title='${environmentName}']`).click();\n await this.page.locator(`//button[normalize-space()='Save']`).click();\n await this.page.locator('i.xl-icon.close-icon').click();\n return this;\n }\n}\n","export class DataRandomGenerator {\n static codePointA = 65;\n static codePointZ = 90;\n\n static getString(): string {\n return Math.random().toString(36).substring(2);\n }\n\n static getNumber(min: number, max: number): number {\n return Math.floor(Math.random() * (max - min + 1) + min);\n }\n\n static getAlphabetsString(length: number): string {\n let alphabets = '';\n for (let i = 0; i < length; i++) {\n alphabets += String.fromCharCode(\n DataRandomGenerator.getNumber(DataRandomGenerator.codePointA, DataRandomGenerator.codePointZ),\n );\n }\n return alphabets;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { Util } from '../common/util';\n\nexport class DeliveryActivityLogsPage {\n constructor(private page: Page) {}\n rowSelector = '.activity-logs-table .dot-tbody .dot-tr:not(.loading-row)';\n\n async expectActivityLogEntry({ msg, user }: { msg?: string; user?: string }): Promise<this> {\n if (user) {\n await expect(this.page.locator(`${this.rowSelector}:has-text(\"${user}\")`).first()).toBeVisible();\n }\n if (msg) {\n await expect(this.page.locator(`${this.rowSelector}:has-text(\"${msg}\")`).first()).toBeVisible();\n }\n return this;\n }\n\n async expectCountToBe(count: number): Promise<this> {\n await expect(this.page.locator(this.rowSelector)).toHaveCount(count, { timeout: 1000 });\n return this;\n }\n\n async setSearchFilter(filterText: string): Promise<this> {\n const input = this.page.locator('input#activity-logs-filter');\n await input.fill('');\n const responsePromise = this.page.waitForResponse((resp) => resp.url().includes('/activity/'));\n await input.type(filterText);\n await responsePromise;\n return this;\n }\n}\n\nexport class FolderDeliveryPage extends WithPage {\n util: Util;\n addName: Locator;\n addDescription: Locator;\n searchForDelivery: Locator;\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n this.addName = page.locator('.xl-react-components input[placeholder=\"Add...\"]');\n this.addDescription = page.getByPlaceholder('Set description...');\n this.searchForDelivery = page.getByPlaceholder('Search for deliveries...', { exact: true });\n }\n\n async filterDeliveryByName(deliveryName: string): Promise<void> {\n await this.searchForDelivery.click();\n await this.searchForDelivery.clear();\n await this.searchForDelivery.fill(deliveryName);\n await this.searchForDelivery.press('Enter');\n await expect(\n this.page.locator('xlr-delivery-row').filter({ hasText: deliveryName }).getByRole('link').first(),\n ).toBeVisible();\n }\n\n async editDelivery(deliveryName: string, newDeliveryName: string): Promise<void> {\n await this.page\n .locator('xlr-delivery-row')\n .filter({ hasText: deliveryName })\n .locator('.fc-list-item-actions .edit-icon')\n .click();\n await this.util.openSideNavMenu('Properties');\n await this.addName.click();\n await this.addName.clear();\n await this.addName.fill(newDeliveryName);\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.locator('.saved-text')).toContainText('Last saved on ');\n }\n\n async deleteDelivery(deliveryName: string): Promise<void> {\n await this.page\n .locator('xlr-delivery-row')\n .filter({ hasText: deliveryName })\n .locator('.fc-list-item-actions .delete-icon')\n .click();\n await expect(this.page.getByText('Delete release delivery', { exact: true })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(\n this.page.locator('.success').filter({ hasText: 'Deleted release delivery successfully' }),\n ).toBeVisible();\n }\n\n async expectDeliveryDisplayed(deliveryName: string): Promise<void> {\n await expect(this.page.locator('.fc-list-item-title')).toContainText(deliveryName);\n }\n\n async openDeliveryLogs(deliveryId: string, filter?: Record<string, unknown>): Promise<DeliveryActivityLogsPage> {\n const deliveryLogs = await this.appendFilterQueryString(`#/deliveries/${deliveryId}/logs`, filter);\n await this.page.goto(deliveryLogs);\n return new DeliveryActivityLogsPage(this.page);\n }\n\n async appendFilterQueryString(url: string, filter?: Record<string, unknown>): Promise<string> {\n if (filter) {\n const queryString = (() => {\n const result = [];\n for (const key in filter) {\n const value = filter[key];\n if (value) {\n if (value === true) {\n result.push(`${key}`);\n } else {\n result.push(`${key}=${encodeURIComponent(String(value))}`);\n }\n }\n }\n\n return result;\n })().join('&');\n\n if (queryString) {\n url += `?${queryString}`;\n }\n }\n return url;\n }\n\n async openDeliveryTimeline(deliveryId: string, filter?: any): Promise<this> {\n const timelinePath = await this.appendFilterQueryString(`#/deliveries/${deliveryId}/timeline`, filter);\n await this.page.goto(timelinePath);\n return this;\n }\n\n async openDeliveryPatternActivityLogs(\n folderId: string,\n deliveryId: string,\n filter?: any,\n ): Promise<DeliveryActivityLogsPage> {\n const patternActivityLogs = await this.appendFilterQueryString(\n `#/folders/${folderId}/delivery-patterns/${deliveryId}/logs`,\n filter,\n );\n await this.page.goto(patternActivityLogs);\n await this.page.getByTestId('activity-logs-title-typography').waitFor({ state: 'visible' });\n return new DeliveryActivityLogsPage(this.page);\n }\n\n async openDeliveries(): Promise<void> {\n await this.page.goto('./#/deliveries');\n }\n\n async resetFilter(): Promise<void> {\n await Promise.all([\n this.page.waitForResponse((r) => r.url().includes('/api/v1/deliveries/search')),\n this.page.locator('navigation-sidebar, .navigation-sidebar').locator('li', { hasText: 'Deliveries' }).click(),\n ]);\n\n const clearAllLink = this.page.locator('a.xl-react-link:has-text(\"Clear all\")');\n if ((await clearAllLink.isVisible()) && !(await clearAllLink.isDisabled())) {\n await Promise.all([\n this.page.waitForResponse((r) => r.url().includes('/api/v1/deliveries/search')),\n clearAllLink.click(),\n ]);\n }\n\n await this.page.locator('.xl-react-components-input-full:visible').first().click();\n const input = this.page.locator('.react-tagsinput-input');\n await input.fill('In progress');\n\n const inputCheckbox = this.page.locator('[title=\"In progress\"] input[type=\"checkbox\"]');\n if (!(await inputCheckbox.isChecked())) {\n await Promise.all([\n this.page.waitForResponse((r) => r.url().includes('/api/v1/deliveries/search')),\n this.page.locator('[title=\"In progress\"] .checkbox').click(),\n ]);\n }\n\n await this.setOrderBy('Start date');\n await this.page.waitForSelector('.fc-list-loaded', { state: 'visible' });\n }\n\n async setOrderBy(orderBy: string): Promise<void> {\n await this.page.locator('.order-by-filter .btn:first-child').click();\n await this.page.locator(`.order-by-filter .bootstrap-link`, { hasText: orderBy }).click();\n await this.page.locator('.order-by-filter .btn:first-child').click();\n await this.page.waitForSelector('.fc-list-loaded', { state: 'visible' });\n }\n\n async openDeliveryFlow(title: string): Promise<void> {\n await this.filterDeliveryByName(title);\n await this.page\n .locator('xlr-delivery-row, .delivery-row')\n .filter({ hasText: title })\n .getByRole('link')\n .first()\n .click();\n }\n\n async completeStage(stageTitle: string, trackedItems: string[] = []): Promise<this> {\n const popup = this.page.locator(`[data-cy='popup-${stageTitle}']`);\n await popup.click();\n const popover = this.page.locator('.ant-popover:not(.ant-popover-hidden)');\n const completeOption = popover.locator('a:text(\"Complete\")');\n await completeOption.click();\n\n if (trackedItems.length > 0) {\n const trackedRows = this.page.locator('.tracked-item-row');\n await expect(trackedRows).toHaveCount(trackedItems.length);\n for (const item of trackedItems) {\n await expect(this.page.locator(`.tracked-item-row:has-text(\"${item}\")`)).toBeVisible();\n }\n }\n\n const confirmButton = this.page.locator('.confirmation-dialog button:text(\"Complete\")');\n await confirmButton.click();\n await expect(this.page.locator(`.label-completed:has-text(\"Completed\")`)).toBeVisible();\n return this;\n }\n\n async reopenStage(stageTitle: string): Promise<this> {\n const popup = this.page.locator(`[data-cy='popup-${stageTitle}']`);\n await popup.click();\n const popover = this.page.locator('.ant-popover:not(.ant-popover-hidden)');\n await popover.locator('a:text(\"Reopen\")').click();\n await this.page.locator('.confirmation-dialog button:text(\"Reopen\")').click();\n await expect(this.page.locator('.label-completed:has-text(\"Completed\")')).not.toBeVisible();\n return this;\n }\n\n async verifyStageContextMenuIsPresent(titles: string[]): Promise<void> {\n for (const title of titles) {\n const locator = this.page.locator(`[data-cy='popup-${title}']`);\n await expect(locator).toHaveCount(1);\n }\n }\n\n async openFolderPath(folderPath: string): Promise<void> {\n await this.page.goto(`./#/folders/${encodeURIComponent(folderPath)}/releases`);\n await this.page.waitForSelector('.folder-content, .folder-view', { state: 'visible' });\n }\n\n async openDeliveryFromFolder(title: string): Promise<void> {\n await this.page\n .locator('xlr-delivery-row, .release-row')\n .filter({ hasText: title })\n .getByRole('link')\n .first()\n .click();\n\n await this.page.waitForSelector('.delivery-flow, .flow-container', { state: 'visible' });\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { Util } from '../common/util';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\n\nexport class FolderGroupsPage extends WithPage {\n util: Util;\n newReleaseGroupButton: Locator;\n dateUtil: DateUtil;\n dateMonth: Date;\n\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n this.util = new Util(page);\n this.newReleaseGroupButton = page.getByText('New release group');\n this.dateMonth = new Date();\n }\n\n async createGroup(groupName: string, startDate?: string, endDate?: string): Promise<void> {\n await this.newReleaseGroupButton.click();\n await expect(this.page.getByText('Create new release group')).toBeVisible();\n await this.enterGroupName(groupName);\n const monthYear = await this.dateUtil.getCurrentMonthYear();\n if (startDate) await this.enterStartDate(startDate, monthYear);\n if (endDate) await this.enterEndDate(endDate, monthYear);\n await this.clickCreate();\n await this.expectSuccessMessageOnReleaseGroupCreation();\n }\n\n async addReleaseToGroup(releaseName: string): Promise<void> {\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Add release' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Add release' }).click({ force: true });\n await this.page.getByPlaceholder('Search for a release...').click();\n await this.page.getByPlaceholder('Search for a release...').fill(releaseName);\n await this.page.keyboard.press('Enter');\n await this.page\n .locator('release-list-modal-release-row')\n .filter({ hasText: releaseName })\n .getByRole('checkbox')\n .check();\n await this.page.getByRole('button', { name: 'Add' }).click();\n await this.expectSuccessMessageOnAddingReleaseToGroup();\n await expect(this.page.getByRole('link', { name: releaseName })).toBeVisible();\n }\n\n async editReleaseGroupName(newGroupName: string): Promise<void> {\n await this.page.locator('#title').click();\n await this.page.locator('#title').clear();\n await this.page.locator('#title').fill(newGroupName);\n await this.page.locator('.modal-footer .button.save').click();\n await this.expectSuccessMessageOnUpdatingGroup();\n }\n\n async enterGroupName(groupName: string): Promise<void> {\n await this.page.locator('#title').click();\n await this.page.locator('#title').fill(groupName);\n }\n\n async enterStartDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('.form-group').filter({ hasText: 'start date' }).locator('.date input').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async enterEndDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('.form-group').filter({ hasText: 'end date' }).locator('.date input').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async clickCreate(): Promise<void> {\n await this.page.getByRole('button', { name: 'Create' }).click();\n }\n\n async expectSuccessMessageOnReleaseGroupCreation(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Created release group successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async expectSuccessMessageOnAddingReleaseToGroup(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(\n this.page.locator('.success').filter({ hasText: 'Added release to release group successfully' }),\n ).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async expectSuccessMessageOnUpdatingGroup(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Updated release group successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async closeNotificationBanner(): Promise<void> {\n const closeIcon = this.page.locator('.dot-alert-banner').getByTestId(`CloseIcon`);\n if (await closeIcon.isVisible()) {\n await closeIcon.click();\n }\n }\n\n async searchReleaseGroupByTitle(title: string): Promise<void> {\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).click();\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).fill(title);\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).press('Enter');\n await expect(this.page.locator('.fc-list-item-title')).toContainText(title);\n }\n\n async deleteReleaseGroup(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.success').filter({ hasText: 'Deleted release group successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async clickReleaseGroupEdit(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-update').click();\n }\n\n async clickSave(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n\n async clickCancel(): Promise<void> {\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n }\n\n async clickOnStatusField(): Promise<void> {\n await this.page.locator('.ci-filter-status.ng-isolate-scope').click();\n }\n\n async statusFilter(statusNames: string[]): Promise<void> {\n await this.clickOnStatusClearAll();\n await this.clickOnStatusField();\n for (let i = 0; i < statusNames.length; i++) {\n await this.page.locator(`i.xl-icon.icon-s.checkbox[data='${statusNames[i]}']`).click();\n }\n }\n\n async clickOnStatusClearAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Clear all' }).click();\n }\n\n async clickOnStatusSelectAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Select all' }).click();\n }\n}\n","interface BaseConfigurationItem {\n id: string;\n type: string;\n}\n\ninterface PlanItem extends BaseConfigurationItem {\n title?: string;\n}\n\nexport interface Release extends PlanItem {\n allowConcurrentReleasesFromTrigger: boolean;\n attachments: Array<Attachment>;\n autoStart: boolean;\n description: string;\n dueDate?: Date;\n endDate?: Date;\n extensions: Array<ReleaseExtension>;\n flagStatus?: string;\n owner?: string;\n passwordVariableValues?: VariableValues;\n phases: Array<Phase>;\n plannedDuration: number;\n queryableEndDate?: Date;\n queryableStartDate?: Date;\n realFlagStatus?: string;\n scheduledStartDate?: Date;\n scriptUserPassword?: string;\n scriptUsername?: string;\n startDate?: Date;\n status: ReleaseStatus;\n summary?: Dashboard;\n tags?: Array<string>;\n teams: Array<Team>;\n variableValues?: VariableValues;\n variables: Array<Variable>;\n}\n\ntype VariableValues = Record<string, any>;\n\nexport interface Variable extends BaseConfigurationItem {\n description?: string;\n folderId?: any;\n key: string;\n label?: string;\n multiline?: boolean;\n referencedType?: string;\n requiresValue?: boolean;\n showOnReleaseStart?: boolean;\n value?: unknown;\n valueProvider?: VariableValueProvider;\n}\n\nexport interface VariableValueProvider {\n id: string;\n type?: string;\n values?: unknown;\n variable: string;\n}\n\nexport interface Duration {\n days: number;\n hours: number;\n month: number;\n}\n\nexport interface Container extends PlanItem {\n tasks: Array<Task>;\n}\n\nexport interface Phase extends Container {\n color: string;\n description: string;\n dueDate?: Date;\n endDate?: Date;\n plannedDuration: number;\n scheduledStartDate?: Date;\n startDate: Date;\n status: PhaseStatus;\n}\n\nexport interface Dependency extends PlanItem {\n archivedAsResolved: boolean;\n archivedTargetId: string;\n archivedTargetTitle: string;\n target: {\n id: string;\n type: string;\n };\n targetId: string;\n}\nexport interface Folder extends PlanItem {\n children?: Array<Folder>;\n teams?: Array<FixtureTeam>;\n variables?: Array<Variable>;\n}\n\nexport interface Task extends PlanItem {\n addresses: Array<string>;\n attachments: Array<Attachment>;\n body?: string;\n comments: Array<Comment>;\n conditions: Array<Condition>;\n delayDuringBlackout: boolean;\n dependencies: Array<Dependency>;\n description?: string;\n dueDate?: Date;\n endDate?: Date;\n failuresCount: number;\n flagStatus?: string;\n folderId?: string;\n links: Array<Link>;\n locked: boolean;\n newReleaseTitle?: string;\n originalScheduledStartDate: string;\n owner?: string;\n plannedDuration: number;\n precondition: string;\n pythonScript?: PythonScript;\n scheduledStartDate?: Date;\n script: string;\n startDate?: Date;\n status: TaskStatus;\n subject?: string;\n tags?: Array<string>;\n tasks: Array<Task>;\n team: string;\n templateId?: string;\n templateVariables?: Array<Variable>;\n variableMapping: VariableValues;\n variables?: Array<Variable>;\n waitForScheduledStartDate?: boolean;\n}\n\ninterface Condition extends PlanItem {\n checked?: boolean;\n}\n\ntype Link = PlanItem;\n//type Comment = PlanItem;\ntype Attachment = PlanItem;\n\ninterface Comment extends PlanItem {\n author?: string;\n date?: Date;\n text?: string;\n}\n\nexport interface Dashboard extends BaseConfigurationItem {\n owner?: string;\n parentId?: string;\n tiles: Array<Tile>;\n title?: string;\n}\n\ntype ReleaseExtension = BaseConfigurationItem;\n\nexport interface Tile extends BaseConfigurationItem {\n col: number;\n password?: string;\n row: number;\n title: string;\n username?: string;\n variableMapping: Record<string, any>;\n width: number;\n}\n\ninterface PythonScript extends BaseConfigurationItem {\n customScriptTask: string;\n password?: string;\n result: string;\n stringList: Array<string>;\n stringMap: Map<string, string>;\n stringSet: Set<string>;\n}\n\ntype ReleaseStatus = 'TEMPLATE' | 'PLANNED' | 'IN_PROGRESS' | 'PAUSED' | 'FAILING' | 'FAILED' | 'COMPLETED' | 'ABORTED';\ntype PhaseStatus = 'PLANNED' | 'IN_PROGRESS' | 'COMPLETED' | 'FAILING' | 'FAILED' | 'SKIPPED' | 'ABORTED';\ntype TaskStatus =\n | 'IN_PROGRESS'\n | 'PLANNED'\n | 'SKIPPED_IN_ADVANCE'\n | 'COMPLETED_IN_ADVANCE'\n | 'COMPLETED'\n | 'SKIPPED'\n | 'ABORTED'\n | 'PENDING'\n | 'FACET_CHECK_IN_PROGRESS'\n | 'FAILED'\n | 'FAILING'\n | 'FAILURE_HANDLER_IN_PROGRESS'\n | 'ABORT_SCRIPT_IN_PROGRESS'\n | 'PRECONDITION_IN_PROGRESS'\n | 'QUEUED'\n | 'ABORT_SCRIPT_QUEUED'\n | 'WAITING_FOR_INPUT'\n | 'FAILURE_HANDLER_QUEUED';\n\nexport interface Team extends BaseConfigurationItem {\n members: Array<string> | Array<principals>;\n permissions: Array<string>;\n roles?: Array<FixtureRoles>;\n teamName: string;\n}\n\nexport type FixtureTeam = Omit<Team, 'id'>;\n\nexport interface principals {\n name: string;\n type: string;\n}\n\ntype FeatureType = 'xlrelease.TaskDrawer'; // add more as needed\nexport interface FixtureFeature {\n enabled: boolean;\n id: string;\n type: FeatureType;\n}\n\ntype DeepPartial<T> = {\n [P in keyof T]?: DeepPartial<T[P]>;\n};\n\n// for fixtures we allow releases with everything optional expect the `id`\nexport type FixtureRelease = DeepPartial<Release> & Pick<Release, 'id'>;\n\nexport interface FixtureConfiguration extends PlanItem {\n accessTokenUrl?: string;\n address?: string;\n apiToken?: string;\n authenticationMethod?: string;\n clientId?: string;\n folderId?: string;\n password?: string;\n port?: number;\n proxyHost?: string;\n proxyPassword?: string;\n proxyPort?: string;\n proxyUsername?: string;\n scriptLocation?: string;\n url?: string;\n username?: string;\n}\n\nexport interface FixtureCi extends PlanItem {\n apiToken?: string;\n defaultProfile?: boolean;\n documentationPage?: string;\n enabled?: boolean;\n externalIdLabel?: string;\n url?: string;\n username?: string;\n}\n\nexport interface FixtureTrigger extends PlanItem {\n count?: number;\n description?: string;\n enabled?: boolean;\n folderId?: string;\n gitRepository?: string;\n jql?: string;\n password?: string;\n periodicity?: number | string;\n pollType?: string;\n releaseTitle: string;\n server?: string;\n template: string;\n username?: string;\n}\n\nexport interface FixtureActivityLog extends PlanItem {\n activityType: string;\n eventTime: Date;\n id: string;\n message: string;\n targetId?: string;\n type: string;\n username: string;\n}\n\nexport interface FixtureRoles {\n principals?: Array<string>;\n role?: Array<FixtureRole>;\n}\n\nexport interface FixtureRole {\n id: number;\n name: string;\n}\n\nexport interface FixturePermissions {\n permissions?: Array<string>;\n role?: Array<FixtureRole>;\n}\n\nexport interface FixtureGlobalRole {\n id: string | null;\n name: string;\n permissions: Array<string>;\n principals: Array<FixturePrincipal>;\n}\n\nexport interface FixturePrincipal {\n fullname: string;\n username: string;\n}\n\nexport interface ReleaseGroup extends PlanItem {\n endDate: Date;\n folderId: string;\n releaseIds?: Array<string>;\n startDate: Date;\n}\n\nexport interface RiskProfile extends PlanItem {\n riskProfileAssessors?: Array<RiskProfile>;\n}\n\nexport interface Delivery extends PlanItem {\n deliveryPattern?: string;\n endDate?: Date;\n folderId: string;\n patternId?: string;\n patternTitle?: string;\n plannedDuration?: number;\n shouldResetPattern?: boolean;\n stages: Array<Stage>;\n startDate?: Date;\n status?: string;\n trackedItems?: Array<TrackedItem>;\n transitions?: Array<Transition>;\n}\n\nexport interface Stage {\n description?: string;\n endDate?: Date;\n id?: null | string;\n items?: Array<Task>;\n plannedDuration?: number;\n startDate?: Date;\n status?: string;\n title?: string;\n transition?: Transition;\n type: string;\n}\n\nexport interface Transition {\n id?: null | string;\n title?: string;\n type: string;\n}\n\nexport interface TrackedItem extends PlanItem {\n createdDate: Date;\n description?: string;\n endDate?: Date;\n folderId?: string;\n owner?: string;\n startDate?: Date;\n status?: string;\n}\n\nexport interface Reservation {\n applications?: Array<ApplicationFixture> | string;\n endDate: string;\n environment: Array<EnvironmentFixture> | string;\n id?: null | string;\n note?: string;\n startDate: string;\n type?: string;\n}\n\nexport interface ApplicationFixture {\n environments?: Array<EnvironmentFixture>;\n folderId?: string | null;\n id?: string | null;\n title?: string;\n type?: string;\n}\n\nexport interface EnvironmentFixture {\n description?: string;\n folderId?: string | null;\n id: null | string;\n labels?: Array<Label>;\n stage?: Stage;\n title?: string;\n type?: string;\n}\n\nexport interface Label extends PlanItem {\n color: string;\n title: string;\n}\n\nexport interface Facet extends BaseConfigurationItem {\n analysisDate?: string;\n applicationId?: Array<ApplicationFixture> | string;\n build?: string;\n build_url?: string;\n complianceData?: string;\n createdBy?: string;\n creationDate?: string;\n duration?: string;\n endDate?: string;\n environmentId?: Array<EnvironmentFixture> | string;\n outcome?: string;\n priority?: string;\n project?: string;\n project_url?: string;\n record?: string;\n record_url?: string;\n serverUrl?: string;\n serverUser?: string;\n startDate?: string;\n status?: string;\n targetId?: string;\n ticket?: string;\n ticketType?: string;\n ticket_url?: string;\n title?: string;\n updatedDate?: string;\n version?: string;\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { Util } from '../common/util';\nimport { Duration } from '../../types';\n\nexport class FolderPatternPage extends WithPage {\n util: Util;\n addName: Locator;\n addDescription: Locator;\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n this.addName = page.locator('.xl-react-components input[placeholder=\"Add...\"]');\n this.addDescription = page.getByPlaceholder('Set description...');\n }\n\n async clickNewDeliveryPattern(): Promise<void> {\n await this.page.getByRole('button', { name: 'New delivery pattern' }).click();\n await expect(this.page.getByRole('heading', { name: 'Create delivery pattern' })).toBeVisible();\n }\n\n async setPatternName(patternName: string): Promise<void> {\n await this.addName.click();\n await this.addName.clear();\n await this.addName.fill(patternName);\n }\n\n async setPatternDescription(patternDescription: string): Promise<void> {\n await this.page.getByPlaceholder('Set description...').click();\n await this.page.getByPlaceholder('Set description...').clear();\n await this.page.getByPlaceholder('Set description...').fill(patternDescription);\n }\n\n async enableAutoComplete(): Promise<void> {\n await this.page.getByRole('checkbox').check();\n }\n\n async disableAutoComplete(): Promise<void> {\n await this.page.getByRole('checkbox').uncheck();\n }\n\n async setDuration({ month, days, hours }: Duration): Promise<void> {\n await this.page.getByRole('group', { name: 'Pattern details' }).getByRole('textbox').click();\n await this.page.locator('input[name=\"months\"]').click();\n await this.page.locator('input[name=\"months\"]').fill(month.toString());\n await this.page.locator('input[name=\"days\"]').click();\n await this.page.locator('input[name=\"days\"]').fill(days.toString());\n await this.page.locator('input[name=\"hours\"]').click();\n await this.page.locator('input[name=\"hours\"]').fill(hours.toString());\n }\n\n async createNewPattern(patternName: string, patternDescription: string, duration?: Duration): Promise<void> {\n await this.clickNewDeliveryPattern();\n await this.setPatternName(patternName);\n await this.setPatternDescription(patternDescription);\n if (duration) {\n await this.setDuration(duration);\n }\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' }).click({ force: true });\n await expect(this.page.getByLabel('breadcrumb').getByText('Delivery flow')).toBeVisible();\n }\n\n async clickEditPatternIcon(patternName: string): Promise<void> {\n await this.page.locator('.delivery-pattern-row').filter({ hasText: patternName }).locator('.edit').click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Delivery flow')).toBeVisible();\n }\n\n async clickCopyPatternIcon(patternName: string): Promise<void> {\n await this.page.locator('.delivery-pattern-row').filter({ hasText: patternName }).locator('.copy').click();\n await expect(this.page.getByText('Copy delivery pattern')).toBeVisible();\n }\n\n async filterPatternByName(patternName: string): Promise<void> {\n await this.page.getByPlaceholder('Filter by name...').click();\n await this.page.getByPlaceholder('Filter by name...').clear();\n await this.page.getByPlaceholder('Filter by name...').fill(patternName);\n await this.page.getByPlaceholder('Filter by name...').press('Enter');\n }\n\n async openProperties(): Promise<Properties> {\n await this.util.openSideNavMenu('Properties');\n return new Properties(this.page);\n }\n\n async openTrackedItems(): Promise<Properties> {\n await this.util.openSideNavMenu('Tracked items');\n return new Properties(this.page);\n }\n\n async addTrackedItem(trackedItemName: string): Promise<Properties> {\n await this.page.getByRole('button', { name: 'Add tracked item' }).click();\n await this.page.getByPlaceholder('Add...').fill(trackedItemName);\n await this.page.getByRole('button', { name: 'Create' }).click();\n await expect(this.page.getByText(trackedItemName)).toBeVisible();\n return new Properties(this.page);\n }\n\n async editTrackedItemName(oldName: string, newName: string): Promise<void> {\n // Open the edit modal for the given tracked item\n await this.page.locator('.track-panel', { hasText: oldName }).locator('.action-label', { hasText: 'Edit' }).click();\n\n // Wait for modal to be visible\n const modal = this.page.locator('.xl-react-modal .xl-react-modal-content');\n await expect(modal).toBeVisible();\n\n // Clear the input and type new name\n const nameInput = modal.locator('input[type=\"text\"]');\n await nameInput.clear();\n await nameInput.fill(newName);\n\n // Click Save\n await modal.locator('button.xl-react-button.button.primary', { hasText: 'Save' }).click();\n\n // Verify the updated name appears in the tracked items list\n await expect(this.page.locator('.track-panel')).toContainText(newName);\n }\n\n async back(): Promise<void> {\n await this.page.getByTestId('back-button').click();\n }\n\n async copyPattern(existingPatternName: string): Promise<void> {\n await this.clickCopyPatternIcon(existingPatternName);\n await this.page.getByRole('button', { name: 'Continue' }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Delivery flow')).toBeVisible();\n await expect(this.page.getByRole('link', { name: `${existingPatternName} (1)` })).toBeVisible();\n }\n\n async clickDeletePattern(patternName: string): Promise<void> {\n await this.page.locator('.delivery-pattern-row').filter({ hasText: patternName }).locator('.delete').click();\n await expect(this.page.getByText('Delete delivery pattern', { exact: true })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.delivery-pattern-row').filter({ hasText: patternName })).not.toBeVisible();\n }\n\n async expectPatternIsVisible(patternName: string): Promise<void> {\n await expect(this.page.locator('.delivery-pattern-row').filter({ hasText: patternName })).toBeVisible();\n }\n\n async expectPatternIsNotVisible(patternName: string): Promise<void> {\n await expect(this.page.locator('.delivery-pattern-row').filter({ hasText: patternName })).toBeHidden();\n }\n\n noPatternsMessageIsVisible(): Promise<void> {\n return expect(this.page.getByText('No delivery patterns found')).toBeVisible();\n }\n\n async createNewDelivery(deliveryName: string, deliveryDes?: string, setAutoComplete?: true): Promise<void> {\n await this.page.getByRole('button', { name: 'New delivery' }).click();\n await this.addName.fill(deliveryName);\n await this.addDescription.click();\n if (deliveryDes) await this.addDescription.fill(deliveryDes);\n else await this.addDescription.fill('Description');\n if (setAutoComplete) await this.page.getByRole('checkbox').check();\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' }).click({ force: true });\n await expect(this.page.locator('.MuiBreadcrumbs-li').getByRole('link', { name: `${deliveryName}` })).toBeVisible();\n }\n}\nclass Properties extends WithPage {\n addName: Locator;\n addDescription: Locator;\n constructor(page: Page) {\n super(page);\n this.addName = page.locator('.xl-react-components input[placeholder=\"Add...\"]');\n this.addDescription = page.getByPlaceholder('Set description...');\n }\n\n async editName(name: string): Promise<void> {\n await this.addName.click();\n await this.addName.clear();\n await this.addName.fill(name);\n }\n\n async editDescription(description: string): Promise<void> {\n await this.page.getByPlaceholder('Set description...').click();\n await this.page.getByPlaceholder('Set description...').clear();\n await this.page.getByPlaceholder('Set description...').fill(description);\n }\n\n async editDuration(month: number, days: number, hours: number): Promise<void> {\n await this.page.getByRole('group', { name: 'Pattern details' }).getByRole('textbox').click();\n await this.page.locator('input[name=\"months\"]').click();\n await this.page.locator('input[name=\"months\"]').fill(month.toString());\n await this.page.locator('input[name=\"days\"]').click();\n await this.page.locator('input[name=\"days\"]').fill(days.toString());\n await this.page.locator('input[name=\"hours\"]').click();\n await this.page.locator('input[name=\"hours\"]').fill(hours.toString());\n }\n\n async save(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n expect(await this.page.locator('.saved-text').textContent()).toContain('Last saved on ');\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { Util } from '../common/util';\nimport { WithPage } from '../WithPage';\n\nexport class FolderNotificationPage extends WithPage {\n inheritCheckbox: Locator;\n util: Util;\n constructor(page: Page) {\n super(page);\n this.inheritCheckbox = page.getByRole('checkbox');\n this.util = new Util(page);\n }\n\n async checkInheritNotifications(): Promise<void> {\n await this.inheritCheckbox.click();\n if (await this.page.getByText('Override notification settings').isVisible()) {\n await this.page.getByRole('button', { name: 'Ok' }).click();\n }\n await expect(this.page.getByRole('checkbox')).toBeChecked();\n await expect(this.page.locator('.xl-icon.edit-icon')).not.toBeVisible();\n }\n\n async uncheckInheritNotifications(): Promise<void> {\n await this.inheritCheckbox.dblclick();\n await expect(this.page.getByRole('checkbox')).not.toBeChecked();\n await expect(this.page.locator('.xl-icon.edit-icon').first()).toBeVisible();\n }\n\n async expectRecipientsNotToBeEditable(eventName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await expect(this.page.locator(`[data-test=\"${eventName}\"]`).getByText('Edit Message')).not.toBeVisible();\n }\n\n async deleteTeam(eventName: string, teamName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page\n .locator(`[data-test=\"${eventName}\"] div.role`)\n .filter({ hasText: teamName })\n .locator('a.tag-close')\n .click();\n }\n\n async expectEditMessageIsVisible(eventName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await expect(this.page.locator(`[data-test=\"${eventName}\"]`).getByText('Edit Message')).toBeVisible();\n }\n\n async addTeam(eventName: string, teamName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByPlaceholder('Add...').click();\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByPlaceholder('Add...').fill(teamName);\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByText(teamName).click();\n }\n\n async clickEditMessage(eventName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByText('Edit Message').click();\n await expect(this.page.getByText('Edit message: Active task')).toBeVisible();\n }\n\n async editPriority(eventName: string, priority: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page.getByRole('combobox').locator('i').click();\n await this.page.getByRole('option', { name: priority }).click();\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { FolderDeliveryPage } from './folder/folderDeliveryPage';\nimport { FolderGroupsPage } from './folder/folderGroupPage';\nimport { FolderPatternPage } from './folder/folderPatternPage';\nimport { FolderNotificationPage } from './folder/folderNotificationPage';\nimport { Util } from './common/util';\nimport { VariablePage } from './variablePage';\nimport { WithPage } from './WithPage';\n\nexport class FolderPage extends WithPage {\n deliveryPage: FolderDeliveryPage;\n expandButton: Locator;\n notificationPage: FolderNotificationPage;\n patternPage: FolderPatternPage;\n folderGroupsPage: FolderGroupsPage;\n util: Util;\n variables: VariablePage;\n\n constructor(page: Page) {\n super(page);\n this.deliveryPage = new FolderDeliveryPage(page);\n this.expandButton = this.page.getByRole('button', { name: ' Expand' });\n this.folderGroupsPage = new FolderGroupsPage(page);\n this.notificationPage = new FolderNotificationPage(page);\n this.patternPage = new FolderPatternPage(page);\n this.util = new Util(page);\n this.variables = new VariablePage(page);\n }\n\n getFolderSearchInputLocator(): Locator {\n return this.page.locator('.folder-list .folder-list-search input');\n }\n\n async openFoldersPage(): Promise<this> {\n await this.page.goto('./#/folders');\n await expect(this.page).toHaveTitle('Folders / Home - Digital.ai Release');\n return this;\n }\n\n async backToAllFolders(): Promise<this> {\n await this.page.locator('.icon-back.dot-i').click();\n await expect(this.page).toHaveTitle('Folders - Digital.ai Release');\n return this;\n }\n\n async createFolder(folderName: string): Promise<this> {\n await this.page.getByRole('button', { name: ' Add folder' }).click();\n await expect(this.page.getByText('Create a new folder in root')).toBeVisible();\n await this.page.getByRole('textbox').fill(folderName);\n await this.page.getByRole('button', { name: 'Create' }).click();\n await expect(this.page.getByRole('link', { name: folderName })).toBeVisible();\n return this;\n }\n\n async openFolder(folderName: string): Promise<this> {\n await this.page.getByTitle(folderName).waitFor({ timeout: 1000 });\n await this.page.getByTitle(folderName).click();\n await expect(this.page.locator('.MuiBreadcrumbs-li').getByRole('link', { name: `${folderName}` })).toBeVisible();\n return this;\n }\n\n async openGroups(): Promise<FolderGroupsPage> {\n await this.util.openSideNavMenu('Groups');\n await expect(this.page.getByLabel('breadcrumb').getByText('Groups')).toBeVisible();\n return this.folderGroupsPage;\n }\n\n async createGroup(groupName: string): Promise<this> {\n await this.page.locator(\"//button[normalize-space()='New release group']\").click();\n await this.page.locator('#title').type(groupName);\n await this.page.locator(\"button[type='submit']\").click();\n return this;\n }\n\n async selectPlannedStatus(): Promise<this> {\n await this.page.locator('.remaining-tags').click();\n await this.page.locator('.xl-react-link:text-is(\"Clear all\")').click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.locator(`.yt-option[title=Planned]`).click();\n await this.page.locator(\"//span[normalize-space()='Status']\").click();\n return this;\n }\n\n async expectReleaseGroupisDisplayed(title: string): Promise<this> {\n //await this.page.locator(`.fc-list-item-title-wrapper .fc-list-item-title strong:text-is('${title}`).isVisible()\n await this.page.waitForSelector(`.fc-list-item-title-wrapper .fc-list-item-title strong:text-is('${title}')`);\n return this;\n }\n\n async createSubFolder(parentFolder: string, subFolderName: string): Promise<void> {\n await this.clickExpandButton();\n await this.page.getByRole('link', { name: parentFolder }).hover();\n await this.clickFolderOptions(parentFolder, 'add');\n await this.page.getByRole('textbox').fill(subFolderName);\n await this.page.getByRole('button', { name: 'Create' }).click();\n await expect(this.page.getByRole('link', { name: subFolderName })).toBeVisible();\n }\n\n async renameFolder(existingFolderName: string, newFolderName: string): Promise<void> {\n await this.clickExpandButton();\n await this.page.getByRole('link', { name: existingFolderName }).hover();\n await this.clickFolderOptions(existingFolderName, 'edit');\n await this.page.getByRole('tab', { name: existingFolderName }).getByRole('textbox').fill(newFolderName);\n await this.page.keyboard.press('Enter');\n await expect(this.page.getByRole('link', { name: newFolderName })).toBeVisible();\n }\n\n async deleteFolder(folderName: string): Promise<void> {\n await this.clickExpandButton();\n await this.page.locator('folder-list-page').getByRole('link', { name: folderName }).hover();\n await this.clickFolderOptions(folderName, 'delete');\n await expect(this.page.getByRole('heading', { name: 'Delete folder' }).locator('span')).toBeVisible();\n await expect(\n this.page\n .locator('.xl-react-modal .confirmation-content')\n .getByText(\n 'You are about to delete the folder ' +\n folderName +\n '. Folders nested in ' +\n folderName +\n ' will also be deleted.',\n ),\n ).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.getByRole('link', { name: folderName })).not.toBeVisible();\n }\n\n async searchFolderByName(folderName: string): Promise<void> {\n await this.getFolderSearchInputLocator().click();\n await this.getFolderSearchInputLocator().clear();\n await this.getFolderSearchInputLocator().fill(folderName);\n await expect(this.page.getByRole('link', { name: folderName })).toBeVisible();\n }\n\n async openPatterns(): Promise<FolderPatternPage> {\n await this.util.openSideNavMenu('Deliveries');\n await this.util.openNestedMenuItem('Patterns');\n await expect(this.page.getByLabel('breadcrumb').getByText('Patterns')).toBeVisible();\n return this.patternPage;\n }\n\n async clickFolderOptions(folderName: string, option: string): Promise<void> {\n await this.page\n .locator('.folder-list-row-wrapper', { hasText: folderName })\n .locator(`.xl-icon.${option}-icon`)\n .click();\n }\n\n async clickExpandButton(): Promise<void> {\n if (await this.expandButton.isEnabled()) {\n await this.expandButton.click();\n }\n }\n\n async openDeliveriesOverview(): Promise<FolderDeliveryPage> {\n await this.util.openSideNavMenu('Deliveries');\n await this.util.openNestedMenuItem('Deliveries overview');\n await expect(this.page.getByLabel('breadcrumb').getByText('Deliveries')).toBeVisible();\n return this.deliveryPage;\n }\n\n async openNotifications(): Promise<void> {\n await this.util.openSideNavMenu('Notifications');\n await expect(this.page.getByLabel('breadcrumb').getByText('Notifications')).toBeVisible();\n }\n\n async openTemplates(): Promise<void> {\n await this.util.openSideNavMenu('Templates');\n await expect(this.page.getByLabel('breadcrumb').getByText('Templates')).toBeVisible();\n }\n\n async openRelease(): Promise<void> {\n await this.util.openSideNavMenu('Releases');\n await expect(this.page.getByLabel('breadcrumb').getByText('Releases')).toBeVisible();\n }\n\n async expectReleaseStarted(releaseName: string): Promise<void> {\n await expect(\n this.page\n .locator('.release')\n .filter({ hasText: releaseName })\n .locator('.release-status')\n .filter({ hasText: 'In progress' }),\n ).toBeVisible();\n }\n\n async openVariables(): Promise<VariablePage> {\n await this.util.openSideNavMenu('Variables');\n await expect(this.page.getByLabel('breadcrumb').getByText('Variables')).toBeVisible();\n return this.variables;\n }\n\n async openCustomDashboard(): Promise<void> {\n await this.util.openSideNavMenu('Custom dashboards');\n await expect(this.page.getByLabel('breadcrumb').getByText('Custom dashboards')).toBeVisible();\n }\n\n async openReleaseByName(releaseName: string): Promise<void> {\n await this.page.getByTitle(releaseName).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { DateUtil } from './common/dateUtil';\n\nexport class GlobalVariable extends WithPage {\n addListValue: Locator;\n listAddButton: Locator;\n addVariableValue: Locator;\n addVariablelabel: Locator;\n constructor(page: Page) {\n super(page);\n this.addListValue = this.page.locator('.variable-selector .xl-components-input-full input');\n this.addVariableValue = this.page.locator('.variable-value .xl-components-input-full input');\n this.addVariablelabel = this.page.locator('.variable-label input');\n this.listAddButton = this.page.getByRole('button', { name: 'Add' });\n }\n\n async addVariableText(valuename: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('StringVariable');\n await this.page.locator('.variable-value').type(valuename);\n await this.submitTheVariable();\n }\n async addVariableListbox(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n await this.addListValue.fill(possiblevalue);\n await this.listAddButton.click();\n await this.page.getByRole('combobox').nth(1).selectOption(possiblevalue);\n await this.submitTheVariable();\n }\n async addVariablePassword(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('PasswordStringVariable');\n await this.page.locator('input[type=\"password\"]').type(possiblevalue);\n await this.submitTheVariable();\n }\n async addVariableCheckbox(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('BooleanVariable');\n await this.page.getByRole('checkbox').check();\n await this.submitTheVariable();\n }\n async addVariableNumber(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('IntegerVariable');\n await this.page.locator('input[ng-model=\"var.value\"]').fill(possiblevalue);\n await this.submitTheVariable();\n }\n async addVariableList(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('ListStringVariable');\n await this.addVariableValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addVariableValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.submitTheVariable();\n }\n async addVariableMultiList(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MultiSelectListBox');\n await this.addListValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addListValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.getByText('Select all', { exact: true }).click();\n await this.submitTheVariable();\n }\n async addVariableDate(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DateVariable');\n await this.page.getByText('Select date').click();\n }\n\n async setDate(date?: string, monthYear?: string): Promise<void> {\n const dateUtil = new DateUtil(this.page);\n await dateUtil.setDate(date, monthYear);\n }\n\n async addVariableKeyValueMap(keys1: string, values1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MapStringStringVariable');\n await this.page.getByPlaceholder('key').fill(keys1);\n await this.page.getByPlaceholder('Value').fill(values1);\n await this.listAddButton.click();\n await this.page.locator('.xl-map-string-string-div-buttons .search-icon').click();\n await this.page.getByRole('row', { name: 'Search' }).getByRole('textbox').fill(keys1);\n const detail = await this.page.locator('table.table-condensed span').allInnerTexts();\n await expect(detail[0]).toEqual(keys1);\n await expect(detail[1]).toEqual(values1);\n await this.submitTheVariable();\n }\n async addVariableSet(possiblevalue1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('SetStringVariable');\n await this.page.locator('.dip-input input').fill(possiblevalue1);\n await this.listAddButton.click();\n await this.submitTheVariable();\n }\n async addNewVariable(variableName: string, labelname: string, description: string): Promise<void> {\n await this.page.getByRole('button', { name: 'New global variable' }).click();\n await this.page.locator(`div.input-group > input`).type(variableName);\n await this.addVariablelabel.fill(labelname);\n await this.page.locator('.variable-description input').fill(description);\n }\n\n async verifyGlobalVariableCreation(variableName: string): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await expect(this.page.locator('.variable.ui-sortable-handle').filter({ hasText: variableName })).toBeVisible();\n }\n async submitTheVariable(): Promise<void> {\n const pagesubmit = await this.page.locator('.button.save');\n await pagesubmit.hover();\n await pagesubmit.click();\n }\n async deleteGlobalVariable(variableName: string): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Delete').click();\n await expect(this.page.locator('h4.ng-binding')).toContainText(variableName);\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n await this.verifyGlobalVariableCreation(variableName);\n await this.page.getByText('Delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n async editVariable(variableName: string, editedvariabletext: string): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Edit').click();\n await this.addVariablelabel.clear();\n await this.addVariablelabel.fill(editedvariabletext);\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(\n this.page.locator('.variable.ui-sortable-handle').getByText(editedvariabletext, { exact: true }),\n ).toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class HomePage extends WithPage {\n configureButton: Locator;\n viewModeButton: Locator;\n constructor(page: Page) {\n super(page);\n this.configureButton = this.page.getByRole('button', { name: 'Configure' });\n this.viewModeButton = this.page.getByRole('button', { name: 'back icon Back to view mode' });\n }\n\n async verifyHomePage(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Digital.ai Release Home' })).toBeVisible();\n }\n\n async verifyConfigureButton(): Promise<void> {\n await this.configureButton.click();\n await expect(this.viewModeButton).toBeVisible();\n await this.viewModeButton.click();\n }\n\n async addReleaseTiles(): Promise<void> {\n await this.configureButton.click();\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByPlaceholder('Search...').fill('releases');\n await this.page.getByPlaceholder('Search...').click();\n await this.page.getByText('Release tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Release tile (Global) Add See' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Releases' }).first()).toBeVisible();\n }\n\n async addWorkflowTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Workflow tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Workflow tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Introducing Workflows' }).first()).toBeVisible();\n }\n\n async addApplicationTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Application tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Application tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Applications' }).first()).toBeVisible();\n }\n\n async addTemplateTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Template tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Template tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Templates' }).first()).toBeVisible();\n }\n\n async addAnnouncementTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Announcement tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Announcement tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Getting started' }).first()).toBeVisible();\n }\n\n async addAnaslyticsTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Analytics tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Analytics tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('button', { name: 'View Analytics' }).nth(1)).toBeVisible();\n }\n /**\n * Remove the tiles from the home page\n * @param tileName name of the tile to be removed\n * tileName TileName should be \"Releases\", \"Workflows\", \"Applications\", \"Templates\", \"Announcements\", \"Analytics\"\n */\n async removeTiles(tileName: string): Promise<void> {\n await this.configureButton.click();\n await this.page\n .locator('.xlr-tile-container[data-title=\"' + tileName + '\"]')\n .last()\n .hover();\n await this.page\n .locator('[data-title=\"' + tileName + '\"] .delete-icon')\n .last()\n .click();\n await expect(this.page.getByRole('heading', { name: 'Delete tile' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await this.viewModeButton.click();\n }\n\n async verifyWhatsNewButton(): Promise<void> {\n await this.page.getByText(`What's new`).waitFor({ state: 'visible' });\n await this.page.getByText(`What's new`).click();\n await expect(this.page.getByText('Introducing Analytics')).toBeVisible();\n await this.page.getByLabel('Close').click();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { Util } from './common/util';\n\nexport class HeaderPage extends WithPage {\n announcementIcon: Locator;\n settingsIcon: Locator;\n aboutMenu: Locator;\n util: Util;\n\n constructor(page: Page) {\n super(page);\n this.announcementIcon = this.page.getByLabel('Open Resource Center');\n this.settingsIcon = this.page.locator('i[aria-label=\"settings-admin-opaque icon\"]');\n this.aboutMenu = this.page.getByText('About Digital.ai Release');\n this.util = new Util(page);\n }\n\n async verifyVersionNumber(versionNumber: string): Promise<void> {\n const year = new Date().getFullYear();\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n await expect(this.page.getByText('Version ' + versionNumber)).toBeVisible();\n await expect(this.page.getByRole('img', { name: 'Release' })).toBeVisible();\n await expect(this.page.getByText(`ⓒ ${year} Digital.ai Software,`)).toBeVisible();\n await this.util.clickCloseIcon();\n }\n\n async verifyProductAnnouncements(): Promise<void> {\n await expect(this.announcementIcon).toBeVisible();\n await this.announcementIcon.click();\n await expect(this.page.locator('#pendo-guide-container')).toContainText('Product updates');\n }\n\n async clickHelpIcon(): Promise<void> {\n await this.page.getByTestId('right-side-nav').getByRole('button', { name: 'Help' }).click();\n }\n\n async verifyOnlineDocumentation(): Promise<void> {\n const versionNumber = await this.getVersionNumber();\n await this.clickHelpIcon();\n const page2Promise = this.page.waitForEvent('popup');\n await expect(this.page.getByText('Online documentation')).toBeVisible();\n await this.page.getByText('Online documentation').click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain(\n 'https://docs.digital.ai/release/docs/' + versionNumber.substring(8, 12) + '/how-to/get-started-with-xl-release',\n );\n await this.page.bringToFront();\n }\n\n async verifySupportRequest(): Promise<void> {\n await expect(this.page.getByRole('menuitem', { name: 'Submit a support request' })).toBeVisible();\n const page2Promise = this.page.waitForEvent('popup');\n await this.page.getByRole('menuitem', { name: 'Submit a support request' }).click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain('https://support.digital.ai/hc/en-us/');\n await this.page.bringToFront();\n }\n\n async verifySuggestAFeature(): Promise<void> {\n await expect(this.page.getByText('Suggest a feature')).toBeVisible();\n const page2Promise = this.page.waitForEvent('popup');\n await this.page.getByText('Suggest a feature').click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain('https://ideas.digital.ai/devops');\n await this.page.bringToFront();\n }\n\n async verifyDigitalAiWebsite(): Promise<void> {\n await expect(this.page.getByText('Digital.ai website')).toBeVisible();\n const page2Promise = this.page.waitForEvent('popup');\n await this.page.getByText('Digital.ai website').click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain('https://digital.ai/');\n await this.page.bringToFront();\n }\n\n async clickAvatarIcon(username: string): Promise<void> {\n await this.page.getByLabel(username, { exact: true }).click();\n }\n\n async verifyUser(userFullName: string): Promise<void> {\n await this.page.locator('li').getByLabel(userFullName).click();\n await expect(this.page.getByRole('heading', { name: 'Personal settings for admin' })).toBeVisible();\n }\n\n async clickAccessTokens(): Promise<void> {\n await this.page.getByText('Access tokens').click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Access tokens')).toBeVisible();\n }\n\n async getVersionNumber(): Promise<string> {\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n const versionNumber = await this.page.locator('.version-text').innerText();\n await this.util.clickCloseIcon();\n return versionNumber;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { Util } from './common/util';\n\nexport class ManagePluginsPage extends WithPage {\n util: Util;\n\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n }\n\n async openPluginGallery(): Promise<void> {\n await this.util.openSideNavMenu('Plugin gallery');\n await expect(this.page.getByLabel('breadcrumb').getByText('Plugin gallery')).toBeVisible();\n }\n\n async openInstalledPlugins(): Promise<void> {\n await this.util.openSideNavMenu('Installed plugins');\n await expect(this.page.getByLabel('breadcrumb').getByText('Installed plugins')).toBeVisible();\n }\n\n async searchForPlugins(searchText: string): Promise<void> {\n await this.page.getByPlaceholder('Search for plugin').fill(searchText);\n expect(await this.page.locator('.PluginTile__title-and-version___1HsNr span').count()).toBeGreaterThan(0);\n }\n\n async refreshPluginList(): Promise<void> {\n await expect(this.page.getByTestId('plugin-refresh-btn')).toBeVisible();\n await this.page.getByTestId('plugin-refresh-btn').click();\n }\n\n async clickInstallNow(pluginName: string): Promise<void> {\n await this.page\n .locator('div')\n .filter({ hasText: 'Install now' + pluginName })\n .getByRole('button')\n .click();\n }\n\n async expectRestartInfo(): Promise<void> {\n await expect(this.page.getByText('Restart Digital.ai Release to finish installing the plugin.')).toBeVisible();\n }\n\n async expectNewPluginInstallationInfo(pluginName: string): Promise<void> {\n await expect(this.page.getByText('New plugin installedPlugin')).toBeVisible();\n await expect(\n this.page.getByText(`release-${pluginName.toLowerCase()}-integration has been installed`),\n ).toBeVisible();\n }\n\n async clickUpload(): Promise<void> {\n await this.page.locator('button', { hasText: 'Upload' }).click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class PersonalAccessTokenPage extends WithPage {\n async openPersonalAccessTokenPage(): Promise<this> {\n // await this.page.locator(\"button.dot-avatar\").click()\n // await this.page.locator(\"//div[normalize-space()='Access tokens']\").click()\n await this.page.goto('./#/personal-access-token');\n await expect(this.page).toHaveTitle('Access tokens / Personal settings - Digital.ai Release');\n return this;\n }\n\n async addNewToken(tokenName: string): Promise<this> {\n //await expect(this.page).toHaveTitle('Access tokens / Personal settings - Digital.ai Release')\n\n await this.page.locator('#tokenText').fill(tokenName);\n await this.page.locator(\"button[type='submit']\").click();\n return this;\n }\n}\n","import { Util } from './common/util';\nimport { WithPage } from './WithPage';\nimport { Page, expect } from '@playwright/test';\n\nexport class PersonalSettingsPage extends WithPage {\n util: Util;\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n }\n\n async openProfile(): Promise<void> {\n await this.util.openSideNavMenu('Profile');\n }\n\n async openAccessToken(): Promise<void> {\n await this.util.openSideNavMenu('Access tokens');\n }\n\n async expectEmailDefined(email: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('#email')).toHaveValue(email);\n return this;\n }\n\n async expectNoEmailDefined(): Promise<PersonalSettingsPage> {\n return this.expectEmailDefined('');\n }\n\n async expectFullNameDefined(fullName: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('#full-name')).toHaveValue(fullName);\n return this;\n }\n\n async expectNoFullNameDefined(): Promise<PersonalSettingsPage> {\n return this.expectFullNameDefined('');\n }\n\n async expectPasswordNotToBe(password: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('input[data-test=\"password-input\"]')).not.toHaveValue(password);\n return this;\n }\n\n async expectDateFormatToBe(dateFormat: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('select[ng-model=\"$ctrl.profile.dateFormat\"]')).toHaveValue(dateFormat);\n return this;\n }\n\n async expectTimeFormatToBe(timeFormat: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('select[ng-model=\"$ctrl.profile.timeFormat\"]')).toHaveValue(timeFormat);\n return this;\n }\n\n async expectFirstDayOfWeekToBe(firstDayOfWeek: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('select[ng-model=\"$ctrl.profile.firstDayOfWeek\"]')).toHaveValue(firstDayOfWeek);\n return this;\n }\n\n async save(): Promise<PersonalSettingsPage> {\n await this.page.locator('action-toolbar button:has-text(\"Save\"):enabled').click();\n await this.page.locator('.saved-text').waitFor({ state: 'visible' });\n return this;\n }\n\n async setEmail(email: string): Promise<PersonalSettingsPage> {\n await this.page.locator('#email').fill(email);\n return this.save();\n }\n\n async setFullName(fullName: string): Promise<PersonalSettingsPage> {\n await this.page.locator('#full-name').fill(fullName);\n return this.save();\n }\n\n async setPassword(previousPassword: string, password: string): Promise<PersonalSettingsPage> {\n await this.page.locator('#previousPassword').fill(previousPassword);\n await this.page.locator('input[data-test=\"password-input\"]').fill(password);\n await this.page.locator('#passwordConfirmation').fill(password);\n return this.save();\n }\n\n async refresh(): Promise<PersonalSettingsPage> {\n await this.page.reload();\n await this.page.waitForSelector('#profileForm');\n return this;\n }\n\n async editUserProfile(email: string): Promise<void> {\n await this.page.getByLabel('Email address').click();\n await this.page.getByLabel('Email address').fill(email);\n await this.page.getByText('Save').click();\n expect(await this.page.locator('.saved-text').textContent()).toContain('Last saved on ');\n }\n\n async generateNewAccessToken(tokenName: string, expiryOptions: string): Promise<void> {\n await this.page.getByRole('button', { name: 'Generate token' }).click();\n await this.page.getByLabel('Token name').click();\n await this.page.getByLabel('Token name').fill(tokenName);\n await this.page\n .getByRole('textbox', { name: 'Token expiration' })\n .getByLabel('Token expiration')\n .selectOption(expiryOptions);\n await this.page\n .locator('label')\n .filter({ hasText: 'Use all permissions' })\n .getByTestId('RadioButtonCheckedIcon')\n .click();\n await this.page.getByRole('button', { name: 'Generate', exact: true }).click();\n await expect(this.page.getByTestId('alert-button-tooltip').getByTestId('dot-button')).toBeVisible();\n await expect(this.page.getByText(tokenName)).toBeVisible();\n }\n\n async deleteAccessToken(tokenName: string): Promise<void> {\n await this.page.locator('.MuiTableRow-root').filter({ hasText: tokenName }).getByTestId('button-icon-i').click();\n await expect(this.page.getByRole('heading', { name: 'Delete token' })).toBeVisible();\n await expect(this.page.getByLabel('Delete token')).toContainText('Delete token');\n await this.page.getByRole('button', { name: 'delete icon Delete' }).click();\n await expect(this.page.getByText(tokenName)).not.toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class UserModal extends WithPage {\n userName: Locator;\n name: Locator;\n email: Locator;\n password: Locator;\n cnfPassword: Locator;\n saveButton: Locator;\n cancelButton: Locator;\n deleteButton: Locator;\n constructor(page: Page) {\n super(page);\n this.userName = page.locator('#username');\n this.name = page.locator('#fullName');\n this.email = page.locator('#email');\n this.password = page.locator('#password');\n this.cnfPassword = page.locator('#confirmPassword');\n this.saveButton = page.getByRole('button', { name: 'Save' });\n this.cancelButton = page.getByRole('button', { name: 'Cancel' });\n this.deleteButton = page.getByRole('button', { name: 'Delete' });\n }\n\n async setUserName(username: string): Promise<void> {\n return await this.userName.fill(username);\n }\n\n async setFullName(fullName: string): Promise<void> {\n return await this.name.fill(fullName);\n }\n\n async setEmail(email: string): Promise<void> {\n return await this.email.fill(email);\n }\n\n async setPassword(password: string): Promise<void> {\n return await this.password.fill(password);\n }\n\n async setCurrentPassword(password: string): Promise<void> {\n const currentPasswordField = this.page.locator('#previousPassword');\n await currentPasswordField.fill(password);\n await expect(currentPasswordField).toHaveValue(password);\n }\n\n async setConfirmPassword(cnfPassword: string): Promise<void> {\n return await this.cnfPassword.fill(cnfPassword);\n }\n\n async save(): Promise<void> {\n await this.saveButton.isEnabled();\n await expect(this.saveButton).not.toBeDisabled();\n await this.saveButton.focus();\n await this.saveButton.click();\n }\n\n async cancel(): Promise<void> {\n await this.cancelButton.click();\n }\n\n async delete(): Promise<void> {\n await this.deleteButton.click();\n }\n\n async expectSaveButtonEnabled(): Promise<void> {\n await expect(this.saveButton).toBeEnabled();\n }\n\n async expectSaveButtonDisabled(): Promise<void> {\n await expect(this.saveButton).toBeDisabled();\n }\n\n async expectErrorMessage(errorMsg: string): Promise<void> {\n await expect(this.page.locator('.dot-dialog-content [role=\"alert\"]')).toContainText(errorMsg);\n }\n\n async expectNewPasswordBoxDisabled(): Promise<this> {\n await expect(this.page.locator('#password')).toBeDisabled();\n return this;\n }\n\n async expectConfirmPasswordHelperText(text: string): Promise<void> {\n const helperText = this.page.locator('#confirmPassword-helper-text');\n await expect(helperText).toBeVisible();\n await expect(helperText).toHaveText(text);\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { UserModal } from './userModal';\nimport { Util } from '../common/util';\n\nexport class UsersPage extends WithPage {\n page: Page;\n modal: UserModal;\n util: Util;\n constructor(page: Page) {\n super(page);\n this.page = page;\n this.modal = new UserModal(page);\n this.util = new Util(page);\n }\n\n async openUsersPage(): Promise<void> {\n this.page.goto('./#/users', { timeout: 1000 });\n }\n\n async toggleLoginPermission(username: string): Promise<void> {\n await this.page\n .getByRole('row', { name: '' + username + '' })\n .getByRole('checkbox')\n .click();\n await expect(this.page.getByRole('row', { name: '' + username + '' }).locator('.Mui-checked')).toBeChecked();\n }\n\n async addUser(): Promise<UserModal> {\n await this.page.locator('.new-user-btn').click();\n return this.modal;\n }\n\n async createUser(username: string, password: string): Promise<void> {\n await this.modal.setUserName(username);\n await this.modal.setFullName(username);\n await this.modal.setEmail('testuser@company.com');\n await this.modal.setPassword(password);\n await this.modal.setConfirmPassword(password);\n await this.modal.save();\n }\n\n async filterUser(username: string): Promise<void> {\n await this.page.getByPlaceholder('Filter...').fill(username);\n }\n\n async expectToHaveFilteredUser(username: string): Promise<void> {\n return await expect(this.page.getByRole('row', { name: '' + username + '' })).toBeVisible();\n }\n\n async expectToHaveLoginPermission(username: string): Promise<void> {\n return await expect(this.page.getByRole('row', { name: '' + username + '' }).getByRole('checkbox')).toBeChecked();\n }\n\n async deleteUser(username: string): Promise<void> {\n await this.page.getByTestId(`delete-btn-${username}`).click();\n await this.modal.delete();\n }\n async openRoles(): Promise<void> {\n await this.util.openSideNavMenu('Roles');\n await expect(this.page.getByLabel('breadcrumb').getByText('Roles')).toBeVisible();\n }\n\n async openPermissions(): Promise<void> {\n await this.util.openSideNavMenu('Permissions');\n await expect(this.page.locator('.permissions-table-v2')).toBeVisible();\n }\n\n async openTaskAccess(): Promise<void> {\n await this.util.openSideNavMenu('Task access');\n await expect(this.page.getByLabel('breadcrumb').getByText('Task access')).toBeVisible();\n }\n\n async expectUsers(\n users: Array<{ email?: string; external: boolean; externalId?: string; fullName?: string; name: string }>,\n ): Promise<void> {\n for (const user of users) {\n await this.filterUser(user.name);\n const type = user.external ? 'External' : 'Internal';\n expect(await this.page.locator(`tr`).filter({ hasText: user.name }).count()).toBeGreaterThan(0);\n expect(\n await this.page.locator(`tr`).filter({ hasText: user.name }).locator(`td`).filter({ hasText: type }).count(),\n ).toBeGreaterThan(0);\n\n if (user.email) {\n expect(\n await this.page\n .locator(`tr`)\n .filter({ hasText: user.name })\n .locator(`td`)\n .filter({ hasText: user.email })\n .count(),\n ).toBeGreaterThan(0);\n }\n\n if (user.fullName) {\n expect(\n await this.page\n .locator(`tr`)\n .filter({ hasText: user.name })\n .locator(`td`)\n .filter({ hasText: user.fullName })\n .count(),\n ).toBeGreaterThan(0);\n }\n\n if (user.externalId) {\n expect(\n await this.page\n .locator(`tr`)\n .filter({ hasText: user.name })\n .locator(`td`)\n .filter({ hasText: user.externalId })\n .count(),\n ).toBeGreaterThan(0);\n }\n\n expect(\n await this.page.locator(`tr`).filter({ hasText: user.name }).locator(`td .icon-delete`).count(),\n ).toBeGreaterThan(0);\n }\n }\n\n async expectNoUser(username: string): Promise<void> {\n await this.filterUser(username);\n await expect(this.page.locator(`p[aria-label=${username}]`)).not.toBeVisible();\n }\n\n async updateUser(username: string): Promise<UserModal> {\n await this.filterUser(username);\n await this.page\n .getByRole('row', { name: '' + username + '' })\n .locator('.icon-edit')\n .click();\n return this.modal;\n }\n\n async sortByColumn(columnName: string, columnIndex: number): Promise<this> {\n const table = this.page.getByTestId('users-table');\n const column = table.locator(`th[title=\"${columnName}\"]`);\n const columnClick = this.page.getByRole('button', { name: columnName, exact: true });\n const originalData = await table.locator(`tr td:nth-child(${columnIndex})`).allTextContents();\n await columnClick.click();\n const sort = await column.getAttribute('aria-sort');\n if (sort == 'ascending') {\n const data = await table.locator(`td:nth-child(${columnIndex})`).allTextContents();\n originalData.sort();\n expect(data).toEqual(originalData);\n }\n if (sort == 'descending') {\n const data = await table.locator(`td:nth-child(${columnIndex})`).allTextContents();\n expect(data).toEqual([...data].sort((a, b) => a.localeCompare(b)));\n }\n return this;\n }\n\n async expectColumnVisible(column: string, visible = true): Promise<this> {\n if (visible) {\n await expect(this.page.locator(`thead th`).filter({ hasText: column })).toBeVisible();\n } else {\n await expect(this.page.locator(`thead th`).filter({ hasText: column })).toHaveCount(0);\n }\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class WorkflowCatalogPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async installReleaseRunner(headingName: string): Promise<void> {\n await this.page.locator('.workflow-card').filter({ hasText: headingName }).getByTestId('dot-button').click();\n await expect(this.page.getByRole('heading', { name: 'Choose folder' })).toBeVisible();\n await this.page.locator('.xl__dropdown-indicator-container').click();\n await this.page.getByText('Samples & Tutorials').click();\n await this.page.getByRole('button', { name: 'Run workflow' }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Install additional Digital.ai')).toBeVisible();\n await this.page.getByRole('heading', { name: 'Prepare Digital.ai Release URL' }).waitFor();\n await expect(this.page.getByRole('heading', { name: 'Prepare Digital.ai Release URL' })).toBeVisible();\n await this.page.getByRole('heading', { name: 'Digital.ai Release URL' }).nth(2).waitFor();\n await expect(this.page.getByRole('heading', { name: 'Digital.ai Release URL' }).nth(2)).toBeVisible();\n }\n\n async abortInstallation(): Promise<void> {\n await this.page.getByRole('button', { name: 'Abort' }).click();\n await this.page.getByRole('button', { name: 'cancel icon Abort' }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Install additional Digital.ai')).not.toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { WorkflowCatalogPage } from './workflowCatalogPage';\n\nexport class SettingsMenu extends WithPage {\n settingsIcon: Locator;\n configureSystemMessageMenu: Locator;\n usersAndPermissionMenu: Locator;\n managePluginMenu: Locator;\n systemSettingsMenu: Locator;\n taskManagerMenu: Locator;\n runnerMenu: Locator;\n viewSystemInfoMenu: Locator;\n getDataSupportMenu: Locator;\n renewLicenseMenu: Locator;\n aboutMenu: Locator;\n closeIcon: Locator;\n installRunnerButton: Locator;\n workflowCatalogPage: WorkflowCatalogPage;\n\n constructor(page: Page) {\n super(page);\n this.settingsIcon = this.page.getByRole('button', { name: 'Settings' });\n this.usersAndPermissionMenu = this.page.getByRole('menuitem', { name: 'users icon Users and permissions' });\n this.managePluginMenu = this.page.getByRole('menuitem', { name: 'plugins icon Manage plugins' });\n this.systemSettingsMenu = this.page.getByRole('menuitem', { name: 'System settings' });\n this.runnerMenu = this.page.getByText('Runners');\n this.configureSystemMessageMenu = this.page.getByText('Configure system message');\n this.taskManagerMenu = this.page.getByText('Task manager');\n this.viewSystemInfoMenu = this.page.getByText('View system information');\n this.getDataSupportMenu = this.page.getByText('Get data for support');\n this.renewLicenseMenu = this.page.getByText('Renew license');\n this.aboutMenu = this.page.getByText('About Digital.ai Release');\n this.closeIcon = this.page.locator('.xl-icon.close-icon');\n this.installRunnerButton = this.page.getByTestId('create-btn');\n this.workflowCatalogPage = new WorkflowCatalogPage(page);\n }\n\n async openUsersAndPermissions(): Promise<void> {\n await this.settingsIcon.click();\n await this.usersAndPermissionMenu.click();\n }\n\n async openManagePlugin(): Promise<void> {\n await this.settingsIcon.click();\n await this.managePluginMenu.click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Plugin gallery')).toBeVisible();\n }\n\n async openSystemSettings(): Promise<void> {\n await this.settingsIcon.click();\n await this.systemSettingsMenu.click();\n await expect(this.page.getByLabel('breadcrumb').getByText('System settings')).toBeVisible();\n }\n\n async openRunner(): Promise<void> {\n await this.settingsIcon.click();\n await this.runnerMenu.click();\n await expect(this.page.getByRole('link', { name: 'Runners' })).toBeVisible();\n }\n\n async openConfigureSystemMessage(): Promise<void> {\n await this.settingsIcon.click();\n await this.configureSystemMessageMenu.click();\n await expect(this.page.getByRole('heading', { name: 'System message' })).toBeVisible();\n }\n\n async closeConfigureSystemMessage(): Promise<void> {\n await this.closeIcon.first().click();\n }\n\n async configureSystemMessage(message: string): Promise<void> {\n await this.settingsIcon.click();\n await this.configureSystemMessageMenu.click();\n await this.page.getByLabel('Enable system message').check();\n await this.page.getByLabel('Type here...').locator('div').nth(2).click();\n await this.page.getByLabel('Type here...').fill(message);\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.locator('system-message')).toContainText(message);\n }\n\n async disableSystemMessage(): Promise<void> {\n await this.settingsIcon.click();\n await this.configureSystemMessageMenu.click();\n await this.page.getByLabel('Enable system message').uncheck();\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.getByRole('alert')).not.toBeVisible();\n }\n\n async openTaskManager(): Promise<void> {\n await this.settingsIcon.click();\n await this.taskManagerMenu.click();\n await expect(this.page.getByRole('link', { name: 'Task manager' })).toBeVisible();\n }\n\n async openViewSystemInformation(): Promise<void> {\n const versionNumber = await this.getVersionNumber();\n await this.settingsIcon.click();\n await this.viewSystemInfoMenu.click();\n await expect(this.page.getByRole('heading', { name: 'Release system information' })).toBeVisible();\n await expect(this.page.getByRole('rowgroup')).toContainText(versionNumber);\n }\n\n async openGetDataForSupport(): Promise<void> {\n await this.settingsIcon.click();\n await this.getDataSupportMenu.click();\n await expect(this.page.getByRole('heading', { name: 'Get data for support' })).toBeVisible();\n await expect(this.page.locator('support-accelerator-modal')).toContainText(\n 'See https://support.digital.ai for more information or to open a support request.',\n );\n }\n\n async downloadSupportData(): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n const downloadPromise = this.page.waitForEvent('download');\n await this.page.getByRole('button', { name: 'Download' }).click();\n await downloadPromise;\n }\n\n async openRenewLicense(): Promise<void> {\n await this.settingsIcon.click();\n const page1Promise = this.page.waitForEvent('popup');\n await this.page.getByText('Renew license').click();\n const page1 = await page1Promise;\n expect(page1.url()).toContain('/productregistration');\n await expect(page1.getByRole('button', { name: 'Install license' })).toBeVisible();\n await this.page.bringToFront();\n }\n\n async getVersionNumber(): Promise<string> {\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n const versionNumber = await this.page.locator('.version-text').innerText();\n await this.closeIcon.click();\n return versionNumber;\n }\n\n async openAbout(): Promise<Modal> {\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n await expect(this.page.getByRole('heading', { name: 'About' })).toBeVisible();\n return new Modal(this.page);\n }\n}\n\nexport class Modal {\n modalBody: Locator;\n closeIcon: Locator;\n\n constructor(page: Page) {\n this.modalBody = page.locator('.modal-body');\n this.closeIcon = page.locator('.xl-icon.close-icon');\n }\n\n async closeModal(): Promise<void> {\n await this.closeIcon.click();\n await expect(this.modalBody).not.toBeVisible();\n }\n async validateLicenseInfo(): Promise<void> {\n await expect(this.modalBody).toBeVisible();\n await expect(this.modalBody).toContainText('Expires on');\n await expect(this.modalBody).toContainText('1');\n await expect(this.modalBody).toContainText('35');\n await expect(this.modalBody).toContainText('Licensed to XL Release Dev Team');\n await this.closeModal();\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class TaskDetails extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n}\n","import { expect, Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport moment from 'moment';\nimport { ReleasesHeaderPage } from './ReleaseHeaderPage';\n\nexport class ReleaseCalendarPage extends ReleasesHeaderPage {\n private dayFormat!: string;\n private yearFormat!: number;\n private monthFormat!: string;\n private yearFormatString!: string;\n\n async openReleaseCalendarPage(): Promise<this> {\n await this.page.goto('./#/releases/calendar');\n //Define date format to verify different calendar views\n const today = new Date();\n let options: Intl.DateTimeFormatOptions = {\n weekday: 'long',\n year: 'numeric',\n month: 'short',\n day: 'numeric',\n };\n this.dayFormat = today.toLocaleDateString('en-US', options); // Saturday, September 17, 2016\n this.yearFormat = today.getFullYear();\n this.yearFormatString = this.yearFormat.toString();\n options = { month: 'long', year: 'numeric' };\n this.monthFormat = today.toLocaleDateString('en-US', options);\n this.monthFormat = this.monthFormat.replace(/(\\w+) (\\d+)/, '$1, $2');\n await expect(this.page.locator('.tl-viewport')).toBeVisible();\n return this;\n }\n\n async exportCalendar(): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n await this.page.getByRole('button', { name: 'download icon Export calendar' }).click();\n const downloadPromise = this.page.waitForEvent('download');\n await this.page.getByRole('button', { name: 'Export' }).click();\n await downloadPromise;\n }\n\n async cancelCalendarExport(): Promise<number> {\n let downloadCount = 0;\n // Listen to download events\n this.page.on('download', (_download) => {\n downloadCount++;\n });\n await this.page.getByRole('button', { name: 'download icon Export calendar' }).click();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return downloadCount;\n }\n\n async verifyDayView(): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct day format displayed at the page bottom\n await expect(this.page.getByText(this.dayFormat)).toBeVisible();\n }\n\n async verifyYearView(): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Year' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct Year format displayed at the page bottom\n await expect(this.page.locator('.tl-footer-label').filter({ hasText: this.yearFormatString })).toHaveText(\n this.yearFormatString,\n );\n }\n\n async verifyMonthView(): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Month' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct Year format displayed at the page bottom\n await expect(this.page.locator('.tl-footer-label').filter({ hasText: this.monthFormat })).toHaveText(\n this.monthFormat,\n );\n }\n\n async verifyPageContent(title: string): Promise<void> {\n const view_type = ['Day', 'Week', 'Month', 'Year'];\n for (const view of view_type) {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: view }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct Year format displayed at the page bottom\n await expect(this.page.getByText(title)).toBeVisible();\n }\n }\n\n async viewRelease(release_title: string, release_id: string): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n await expect(async () => {\n await this.page.locator('.tl-event-title').getByText(release_title).scrollIntoViewIfNeeded({ timeout: 1000 });\n await this.page.locator('.tl-event-title').getByText(release_title).click({ timeout: 1000 });\n await expect(this.page.locator('.release-modal-container .xl-icon.release-icon')).toBeVisible({ timeout: 1000 });\n }).toPass();\n\n await this.page.locator('.release-modal-container').locator('.xl-icon.release-icon').click();\n const releaseurl = `/#/releases/${release_id}`;\n // Check if the release name present in redirected URL\n expect(this.page.url()).toContain(releaseurl);\n }\n\n async viewDependency(source_release: string, dest_release: string): Promise<void> {\n const source_text = source_release + 'dependencies';\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n await this.page.getByText(source_release).click();\n await this.page.locator('.release-modal-container').locator('.xl-icon.cluster-dependencies-icon').click();\n await expect(this.page.locator('.tl-drawer-navigation-header')).toHaveText(source_text);\n await expect(this.page.locator('.tl-drawer-dependency-body-title-text')).toHaveText(dest_release);\n }\n\n async downloadIcsCalendar(release_title: string): Promise<number> {\n let downloadCount = 0;\n // Listen to download events\n this.page.on('download', (_download) => {\n downloadCount++;\n });\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n await this.page.getByText(release_title).click();\n await this.page.locator('.release-modal-container').locator('.xl-icon.calendar-icon').click();\n return downloadCount;\n }\n\n async openBlackoutPeriod(date: string): Promise<BlackoutPeriod> {\n return new BlackoutPeriod(date, this.page);\n }\n}\n\nexport class BlackoutPeriod extends WithPage {\n dateField: string;\n\n constructor(date: string, page: Page) {\n super(page);\n this.dateField = date;\n }\n\n async edit(): Promise<this> {\n await this.findBlackout();\n await this.page.locator('.blackout-popover .blackout-popover-footer .edit-icon').click();\n return this;\n }\n\n async delete(): Promise<this> {\n await this.findBlackout();\n await this.page.locator('.blackout-popover .blackout-popover-footer .delete-icon').click({ force: true });\n await this.page.getByRole('button', { name: 'Delete' }).click({ force: true });\n return this;\n }\n\n async findBlackout(): Promise<void> {\n await expect(async () => {\n await this.page\n .locator(`.tl-blackout-start[data-test-date=\"${this.dateField}\"]`)\n .click({ force: true, position: { x: 4, y: 4 } });\n await expect(this.page.locator('.blackout-popover-container')).toBeVisible({ timeout: 1000 });\n }).toPass();\n }\n\n // Have to revisit here fix the date selection for different months\n async setEndDate(date: Date): Promise<this> {\n const cDate = moment(date).format('dddd, MMMM Do, YYYY');\n await this.page\n .locator('.widget-datetime')\n .filter({ hasText: 'End date' })\n .locator('.xl-react-widget-date input')\n .click();\n await this.page.getByLabel(`Choose ${cDate}`).click();\n return this;\n }\n\n async save(): Promise<this> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n return this;\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleaseGroupPage extends WithPage {\n private dayFormat!: string;\n private yearFormat!: number;\n private monthFormat!: string;\n private yearFormatString!: string;\n\n async setStatus(status: string): Promise<void> {\n await this.page.locator('.react-tagsinput').click({ force: true });\n await this.page.getByText('Clear all').click();\n await this.page.locator('.react-tagsinput').click({ force: true });\n if (status === 'Select all') {\n await this.page.getByText(status).click();\n } else {\n await this.page.getByTitle(status).locator('i').first().click();\n }\n }\n\n async openReleaseGroup(title: string): Promise<void> {\n await this.page.locator('xlr-release-group-row').filter({ hasText: title }).getByRole('link').click();\n await this.page.getByTitle(title).click();\n await expect(this.page).toHaveURL(/.*ReleaseGroup/);\n }\n\n async expectReleaseGroupStatus(status: string): Promise<void> {\n await expect(this.page.locator('.release-status')).toContainText(status);\n }\n\n async expectReleaseGroupDisplayed(title: string): Promise<void> {\n await expect(this.page.locator('.row').getByText(title, { exact: true })).toBeVisible();\n }\n\n async expectReleaseGroupNotDisplayed(title: string): Promise<void> {\n await expect(this.page.locator('.row').getByText(title, { exact: true })).not.toBeVisible();\n }\n\n async searchReleaseGroupByTitle(title: string): Promise<void> {\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).click();\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).fill(title);\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).press('Enter');\n }\n\n async deleteReleaseGroup(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async clickReleaseGroupEdit(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-update').click();\n }\n\n async enterReleaseGroupDetails(new_title: string): Promise<void> {\n await this.page.locator('.modal-body').locator('#title').fill(new_title);\n }\n\n async clickSaveButton(): Promise<void> {\n await this.page.locator('.modal-footer').getByRole('button', { name: 'Save' }).click();\n }\n\n async clickCancelButton(): Promise<void> {\n await this.page.locator('.modal-footer').getByRole('button', { name: 'Cancel' }).click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleaseGroupTimelinePage extends WithPage {\n async expectReleaseDisplayed(title: string): Promise<void> {\n await expect(this.page.getByText(title, { exact: true })).toBeVisible();\n }\n\n async expectReleaseNotDisplayed(title: string): Promise<void> {\n await expect(this.page.getByText(title, { exact: true })).not.toBeVisible({ timeout: 10000 });\n }\n\n async expectPhaseDisplayed(title: string): Promise<void> {\n await expect(this.page.getByText(title, { exact: true })).toBeVisible();\n }\n\n async openContextMenu(title: string): Promise<void> {\n await this.page.locator('.timeline-row-name').filter({ hasText: title }).locator('.options-icon').click();\n }\n\n async removeFromReleaseGroup(): Promise<void> {\n await this.page.getByRole('menuitem', { name: 'Remove from group' }).locator('a').click();\n await this.page.getByRole('button', { name: 'Remove' }).click();\n }\n\n async expectNumberOfReleases(num_of_release: number): Promise<void> {\n const elementCount = await this.page.locator('.timeline-row-name-release').count();\n expect(elementCount).toBe(num_of_release);\n }\n\n async openAddReleaseList(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add release' }).click();\n }\n\n async filterReleases(title: string): Promise<void> {\n await this.page.getByPlaceholder('Search for a release...').click();\n await this.page.getByPlaceholder('Search for a release...').fill(title);\n await this.page.waitForTimeout(5000);\n await this.page.getByPlaceholder('Search for a release...').press('Enter');\n }\n\n async expectNumberOfReleasesOnModal(num_of_release: number): Promise<void> {\n const elementCount = await this.page.locator('.release-modal-line').count();\n expect(elementCount).toBe(num_of_release);\n }\n\n async selectAllReleaseCheckbox(): Promise<void> {\n await this.page.getByLabel('Select all').check();\n }\n\n async addReleasesToGroup(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { waitForOneOf } from '../helper';\nimport { DateUtil } from '../common/dateUtil';\n\ntype ExpectWithLocator = (l: Locator) => void;\n\nexport class ReleaseVariablesPage extends WithPage {\n addListValue: Locator;\n addVariableValue: Locator;\n listAddButton: Locator;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.addListValue = this.page.locator('.variable-selector .xl-components-input-full input');\n this.addVariableValue = this.page.locator('.variable-value .xl-components-input-full input');\n this.dateUtil = new DateUtil(page);\n this.listAddButton = this.page.getByRole('button', { name: 'Add' });\n }\n\n async openVariable(variableKey: string): Promise<ReleaseVariableModal> {\n await this.page.locator(`.variables-list .variable`).getByText(variableKey).click();\n return new ReleaseVariableModal(this.page);\n }\n\n async addNewVariable(variableName: string, labelname: string, description?: string): Promise<void> {\n await this.page.locator('#action-toolbar').getByText('New variable').click();\n await this.page.fill(`[name=\"fieldKey\"]`, variableName);\n await this.page.locator('.variable-label input').fill(labelname);\n if (description) await this.page.locator('.variable-description input').fill(description);\n }\n\n async selectVariableTextType(valuename: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('StringVariable');\n await this.page.locator('.variable-value').type(valuename);\n }\n\n async selectVariableListboxType(\n possiblevalue: Array<string> | string,\n defaultValue: string,\n required?: boolean,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n await this.addListValue.fill(value);\n await this.listAddButton.click();\n }\n } else {\n await this.addListValue.fill(possiblevalue);\n await this.listAddButton.click();\n }\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n } else {\n await this.page.getByRole('checkbox').uncheck();\n }\n }\n\n async selectVariablePasswordType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('PasswordStringVariable');\n await this.page.locator('input[type=\"password\"]').type(possiblevalue);\n }\n\n async selectVariableCheckboxType(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('BooleanVariable');\n await this.page.getByRole('checkbox').check();\n }\n\n async selectVariableNumberType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('IntegerVariable');\n await this.page.locator('input[ng-model=\"var.value\"]').fill(possiblevalue);\n }\n\n async selectVariableMultiListType(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MultiSelectListBox');\n await this.addListValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addListValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.getByText('Select all', { exact: true }).click();\n }\n\n async addVariableDate(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DateVariable');\n await this.page.getByText('Select date').click();\n }\n\n async setDate(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async addVariableKeyValueMap(keys1: string, values1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MapStringStringVariable');\n await this.page.getByPlaceholder('key').fill(keys1);\n await this.page.getByPlaceholder('Value').fill(values1);\n await this.listAddButton.click();\n await this.page.locator('.xl-map-string-string-div-buttons .search-icon').click();\n await this.page.getByRole('row', { name: 'Search' }).getByRole('textbox').fill(keys1);\n const detail = await this.page.locator('table.table-condensed span').allInnerTexts();\n expect(detail[0]).toEqual(keys1);\n expect(detail[1]).toEqual(values1);\n }\n\n async addVariableSet(possiblevalue1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('SetStringVariable');\n await this.page.locator('.dip-input input').fill(possiblevalue1);\n await this.listAddButton.click();\n }\n\n async submitTheVariable(): Promise<void> {\n const createButton = this.page.locator('.modal-footer .save');\n await expect(createButton).toBeEnabled();\n await createButton.scrollIntoViewIfNeeded();\n await createButton.click();\n // Expect is needed here to avoid flackiness on clicking create button\n await expect(createButton).not.toBeVisible();\n }\n\n async expectVariableWithNameValueAndType(name: string, value: string, type: string): Promise<void> {\n const rowLocator = await this.page.locator('.variable .data-row').allTextContents();\n expect(rowLocator.toString()).toContain(name);\n expect(rowLocator.toString()).toContain(value);\n expect(rowLocator.toString()).toContain(type);\n }\n\n async clickEditVariable(variableName: string): Promise<ReleaseVariableModal> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Edit').first().click();\n return new ReleaseVariableModal(this.page);\n }\n\n async clickDeleteVariable(variableName: string): Promise<DeleteVariableModel> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.locator('.action .delete-icon').first().click();\n return new DeleteVariableModel(this.page);\n }\n\n async expectVariablesCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.variable .data-row')).toHaveCount(count);\n }\n\n async expectVariableNotPresent(variableName: string): Promise<void> {\n await expect(this.page.locator('.variable').filter({ hasText: variableName })).not.toBeVisible();\n }\n\n async clearSearch(): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").clear();\n }\n\n async switchPossibleValuesToVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n }\n\n async selectVariableListboxTypeWithVariable(\n variableName: string,\n defaultValue: string,\n required?: boolean,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n } else {\n await this.page.getByRole('checkbox').uncheck();\n }\n }\n}\n\nclass ReleaseVariableModal extends WithPage {\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n }\n private async expectValue(locators: Locator[], expectFn: ExpectWithLocator[]): Promise<void> {\n const [index, locator] = await waitForOneOf(locators);\n expectFn[index](locator);\n }\n\n async expectValueToBe(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode .text-container'),\n ],\n [\n (l) => expect(l).toHaveValue(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n ],\n );\n }\n\n async expectValueToContain(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode'),\n ],\n [\n (l) => expect(l.inputValue()).toContain(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n ],\n );\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async expectPossibleValues(possiblevalue: Array<string> | string): Promise<void> {\n const listLocator = await this.page.locator('.editor .xl-list-row').allInnerTexts();\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n expect(listLocator).toContain(value);\n }\n } else {\n expect(listLocator).toContain(possiblevalue);\n }\n }\n\n async expectPossibleVariableValues(possiblevariablevalue: string): Promise<void> {\n await expect(this.page.locator('.variable-dropdown input')).toHaveValue(possiblevariablevalue);\n }\n\n async addPossibleValue(value: Array<string> | string): Promise<void> {\n if (value instanceof Array) {\n for (const li of value) {\n await this.page.locator('.xl-components-input-full input').fill(li);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n } else {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n }\n\n async selectVariableValue(defaultValue: string): Promise<void> {\n await this.page.locator('.variable-value select').selectOption(defaultValue);\n }\n\n async save(): Promise<void> {\n const saveButton = this.page.locator('#modal .modal-footer .save');\n await saveButton.scrollIntoViewIfNeeded();\n await saveButton.click({ delay: 2000 });\n // Expect is needed here to avoid flackiness on clicking save button on modal window\n await expect(saveButton).not.toBeVisible();\n }\n\n async createPossibleValuesVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n }\n\n async expectVariableValueToBe(value: string): Promise<void> {\n expect(await this.page.locator('.variable-value select option[selected=\"selected\"]').textContent()).toBe(value);\n }\n\n async expectNoVariablesInList(): Promise<void> {\n await expect(this.page.getByText('No variables defined.')).toBeVisible();\n }\n\n async expectNameInput(value: string): Promise<void> {\n await expect(this.page.locator(`#modal .variable-name input`)).toHaveValue(value);\n }\n\n async expectLabel(value: string): Promise<void> {\n await expect(this.page.locator('#modal .variable-label input')).toHaveValue(value);\n }\n\n async expectRequired(value: boolean): Promise<void> {\n if (value == true) await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).toBeChecked();\n else await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).not.toBeChecked();\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.variable-description input').click();\n await this.page.locator('.variable-description input').clear();\n await this.page.locator('.variable-description input').fill(description);\n }\n\n async setLabel(labelValue: string): Promise<void> {\n await this.page.locator('.variable-label input').fill(labelValue);\n }\n\n async setDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setValue(value: string): Promise<void> {\n await this.page.locator('.variable-value input').fill(value);\n }\n}\nclass DeleteVariableModel extends WithPage {\n model: ReleaseVariableModal;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.model = new ReleaseVariableModal(page);\n this.dateUtil = new DateUtil(page);\n }\n async deleteVariable(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async replaceItWithVariable(variable: string): Promise<void> {\n await this.model.createPossibleValuesVariable(variable);\n }\n\n async replaceItwithValue(value: string): Promise<void> {\n await this.page.locator('.display').click();\n await this.page.getByLabel('*').fill(value);\n }\n\n async clickReplaceAndDelete(): Promise<void> {\n await this.page.getByRole('button', { name: 'Replace and delete' }).click();\n }\n\n async addValue(value: string): Promise<void> {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n\n async remove(value: string): Promise<void> {\n await this.page.locator('li').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async expectReplacementPromptDisplayed(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async removeItemOnSet(value: string): Promise<void> {\n await this.page.locator('tr').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async addValueForSet(key: string, value: string): Promise<void> {\n await this.page.locator('.input-key').fill(key);\n await this.page.locator('.input-value').fill(value);\n }\n\n async replaceWithIntegerValue(value: string): Promise<void> {\n await this.page.locator('.editable').fill(value);\n }\n\n async replaceForBooleanValue(): Promise<void> {\n await this.page.locator('.editor input').click();\n }\n\n async deleteBySettingDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class TaskListPage extends WithPage {\n commentBox: Locator;\n gridView: GridView;\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.commentBox = this.page.locator(`.input-block-level`);\n this.gridView = new GridView(page);\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async openTask(taskName: string): Promise<void> {\n await this.filterTaskByTitle(taskName);\n await this.page.getByText(taskName).first().click();\n await this.taskDrawer.waitForTaskDrawer();\n }\n\n async complete(taskName: string, comment: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('span.complete').click();\n await this.commentBox.click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Complete', exact: true }).click();\n }\n\n async skip(taskName: string, comment: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('span.skip').click();\n await this.commentBox.click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Skip', exact: true }).click();\n }\n\n async fail(taskName: string, comment: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('span.fail').click();\n await this.commentBox.click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Fail', exact: true }).click();\n }\n\n async waitForTaskFailed(taskName: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`, { hasText: taskName }).getByText('Failed')).toBeVisible();\n }\n\n async waitForTaskInProgress(taskName: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`, { hasText: taskName }).getByText('In progress')).toBeVisible();\n }\n\n async openTaskInReleaseView(taskName: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('a.view-in-release').click();\n }\n\n async openCalendarViaTaskDueDate(taskName: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator(`.calendar-link a`).click();\n }\n\n async openTaskDrawer(taskName: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).getByText(taskName).click();\n await this.taskDrawer.waitForTaskDrawer();\n }\n\n async filterTaskByTitle(taskname: string): Promise<void> {\n await this.page.locator('.searchFilter').click();\n await this.page.locator('.searchFilter').fill(taskname);\n await this.page.locator('.searchFilter').press('Enter');\n await expect(this.page.locator('//div[@data-task-title]').filter({ hasText: taskname }).first()).toBeVisible();\n }\n\n async filterTasksByTag(tag: string, taskTitleForValidation: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').click();\n await this.page.locator('.tag-input').fill(tag);\n await this.page.locator('.tag-input').press('Enter');\n //TODO: Validation can be changed based on actual test case implementation\n await expect(\n this.page.locator('//div[@data-task-title]').filter({ hasText: taskTitleForValidation }),\n ).toBeVisible();\n }\n\n async filterTasksByReleaseTitle(releaseTitle: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').click();\n await this.page.locator('.release-input').fill(releaseTitle);\n await this.page.locator('.release-input').press('Enter');\n await expect(this.page.locator('.group-title').filter({ hasText: releaseTitle })).toBeVisible();\n }\n\n async openSingleTask(taskId: string, showDetails = false): Promise<void> {\n await this.page.goto(`./#/tasks/${taskId}?showDetails=${showDetails}`);\n }\n\n async expectReleaseLinksDisplayed(releaseTitle: string, displayed = true): Promise<void> {\n if (displayed) {\n await expect(this.page.getByRole('link', { name: '' + releaseTitle + '' })).toBeVisible();\n await expect(this.page.locator('.view-in-release')).toBeVisible();\n } else {\n await expect(this.page.getByRole('link', { name: '' + releaseTitle + '' })).not.toBeVisible();\n await expect(this.page.locator('.view-in-release')).not.toBeVisible();\n }\n }\n\n async openTaskList(): Promise<void> {\n await this.page.goto('./#/tasks');\n }\n\n async clickOnAssigneeButton(title: string): Promise<void> {\n await this.page.locator(`.btn-group-filter.btn-group button.btn.btn-flat[title=\"${title}\"]`).click();\n }\n\n async clickOnAssignedToMe(): Promise<void> {\n await this.page.locator(`button[title=\"Assigned to me\"]`).click();\n }\n\n async clickOnAssignedToMyTeams(): Promise<void> {\n await this.page.locator(`button[title=\"Assigned to my teams\"]`).click();\n }\n\n async clickOnAssignedToAllAvailable(): Promise<void> {\n await this.page.locator(`button[title=\"All available\"]`).click();\n }\n\n async expectTaskToNotBeDisplayed(taskTitle: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`).filter({ hasText: taskTitle }).getByText(taskTitle)).toHaveCount(\n 0,\n );\n }\n\n async expectTaskToBeDisplayed(taskTitle: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`).filter({ hasText: taskTitle }).getByText(taskTitle)).toHaveCount(\n 1,\n );\n }\n\n async expectTasksToBeDisplayed(tasks: { [key: string]: boolean }): Promise<void> {\n for (const [taskTitle, shouldBeDisplayed] of Object.entries(tasks)) {\n if (shouldBeDisplayed) {\n await this.expectTaskToBeDisplayed(taskTitle);\n } else {\n await this.expectTaskToNotBeDisplayed(taskTitle);\n }\n }\n }\n\n async expectTasksDisplayedInOrder(\n expectedTasks: { releaseTitle: string; taskPosition: number; taskTitle: string }[],\n ): Promise<void> {\n for (const task of expectedTasks) {\n const taskElement = await this.page\n .locator(`[data-release-title='${task.releaseTitle}'] .row .task`)\n .nth(task.taskPosition);\n await expect(taskElement).toHaveAttribute('data-task-title', task.taskTitle);\n }\n }\n\n async setOrderBy(orderBy: string): Promise<void> {\n await this.page.locator('.order-selector .btn:first-child').click();\n await this.page.locator(`.order-selector .bootstrap-link:has-text('${orderBy}')`).click();\n }\n\n async expectTaskCountForRelease(releaseTitle: string, expectedCount: number): Promise<void> {\n await expect(\n this.page.locator(`#tasks-content #task-list-grouped-view div:has-text('${releaseTitle}') .task`),\n ).toHaveCount(expectedCount);\n }\n\n async setSearchFilter(filterText: string): Promise<void> {\n await this.page.locator('.searchFilter').fill(filterText);\n }\n\n async clearSearchFilter(): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n }\n\n async setTagsFilter(filterText: string): Promise<void> {\n await this.page.locator('.tag-input').fill(filterText);\n await this.page.locator('.tag-input').press('Enter');\n }\n\n async clickOnStatusField(): Promise<void> {\n await this.page.locator('.ci-filter-status.ng-isolate-scope').click();\n }\n\n async clickOnStatus(statusNames: string[]): Promise<void> {\n await this.clickOnStatusClearAll();\n await this.clickOnStatusField();\n for (let i = 0; i < statusNames.length; i++) {\n await this.page.locator(`i.xl-icon.icon-s.checkbox[data='${statusNames[i]}']`).click();\n }\n // Clicking outside to close the grid dropdown\n await this.clickOnTasksLabel();\n }\n\n async clickOnStatusClearAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Clear all' }).click();\n await this.clickOnTasksLabel();\n }\n\n async clickOnStatusSelectAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Select all' }).click();\n await this.clickOnTasksLabel();\n }\n\n async assignTaskToMe(title: string): Promise<void> {\n await this.page.locator(`.task-line`).filter({ hasText: title }).locator(`.assign-to-me`).click();\n await this.page.locator('.modal:visible >> text=\"Assign to me\"').click();\n }\n\n async expectTaskAssignedToMe(title: string): Promise<void> {\n await this.expectTaskAssignedTo(title, 'me');\n }\n\n async expectTaskAssignedTo(title: string, user: string): Promise<void> {\n await expect(this.page.locator(`.task-line:has-text(\"${title}\") >> text=\"${user}\"`).first()).toHaveCount(1);\n }\n\n async expectTaskTitle(taskTitle: string): Promise<void> {\n await expect(this.page.locator('#tasks0')).toContainText(taskTitle);\n }\n\n async clickOnTasksLabel(): Promise<void> {\n await this.page.getByLabel('breadcrumb').getByText('Tasks').click();\n }\n\n async expectGroupView(expected = true): Promise<void> {\n if (expected) {\n await expect(this.page.locator('#group-tasks-by-release')).toBeChecked();\n await expect(this.page.locator('#task-list-grouped-view')).toBeVisible();\n await expect(this.page.locator('#task-ungrouped-view')).not.toBeVisible();\n } else {\n await expect(this.page.locator('#group-tasks-by-release')).not.toBeChecked();\n await expect(this.page.locator('#task-list-grouped-view')).not.toBeVisible();\n await expect(this.page.locator('#task-ungrouped-view')).toBeVisible();\n }\n }\n\n async changeGroupView(): Promise<void> {\n await this.page.locator('#group-tasks-by-release').click();\n }\n\n async enableGroupByReleaseView(): Promise<void> {\n await this.page.getByRole('checkbox', { name: 'Group by release' }).check();\n }\n\n async disableGroupByReleaseView(): Promise<void> {\n await this.page.getByRole('checkbox', { name: 'Group by release' }).uncheck();\n }\n\n async switchToGridView(): Promise<GridView> {\n await this.page.locator('.xl-icon.grid-icon').click();\n return this.gridView;\n }\n}\n\nclass GridView extends WithPage {\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async expectTaskCountInGridView(count: number): Promise<void> {\n await expect(this.page.locator('task-grid .task-wrapper')).toHaveCount(count);\n }\n\n // eslint-disable-next-line max-params\n async expectTaskDetailsInGridView(\n taskId: string,\n taskStatus: string,\n taskTitle: string,\n assignedTo?: string,\n release?: string,\n phase?: string,\n startDate?: string,\n ): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] .label`)).toContainText(taskStatus);\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] .title`)).toContainText(taskTitle);\n if (assignedTo)\n await expect(\n this.page.locator(`[data-test-id=\"${taskId}\"] span`).filter({ hasText: 'Assigned to ' }).first(),\n ).toContainText(assignedTo);\n if (release)\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] [data-test=\"release\"]`)).toContainText(release);\n if (phase)\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] [data-test=\"phase\"] span`)).toContainText(phase);\n if (startDate) {\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] [data-test=\"started\"]`)).toContainText(startDate);\n } else {\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] .caption`).getByText('Started')).not.toBeVisible();\n }\n return this;\n }\n\n async openTaskDrawerFromGridView(taskId: string, taskTitle: string): Promise<TaskDrawer> {\n await this.page.locator(`[data-test-id=\"${taskId}\"] .title`).filter({ hasText: taskTitle }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openContextualMenu(taskId: string): Promise<void> {\n await this.page.locator(`[data-test-id=\"${taskId}\"] .xl-icon.options-icon`).click();\n }\n\n async expectContextMenuHas(taskId: string, enabled: Array<string>, disabled: Array<string>): Promise<this> {\n await this.openContextualMenu(taskId);\n for (const e of enabled) {\n await expect(\n this.page.locator(`[data-test-id=\"${taskId}\"] #context-menu-container li:not(.disabled) a`).getByText(e),\n ).toBeVisible();\n }\n for (const e of disabled) {\n await expect(\n this.page.locator(`[data-test-id=\"${taskId}\"] #context-menu-container li.disabled a`).getByText(e),\n ).toBeVisible();\n }\n return this;\n }\n\n async waitForTaskNotDisplayed(taskId: string): Promise<this> {\n await expect(this.page.locator(`div.task[data-test-id=${taskId}]`)).not.toBeVisible();\n return this;\n }\n\n async triggerContextMenuAction(action: string): Promise<this> {\n await this.page.locator(`#context-menu-container li a`).filter({ hasText: action }).click();\n if (action === 'Complete') {\n await this.page.locator('#modal textarea[mentio]').fill('complete');\n await this.page.locator('#modal button.primary').filter({ hasText: 'Complete' }).click();\n return this;\n }\n return this;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\n\nexport class TemplatePropertiesPage extends WithPage {\n dateUtil: DateUtil;\n scheduledStartDate: Locator;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n this.scheduledStartDate = this.page.locator(`.scheduled-start-date .date`);\n }\n\n async getAttachmentsListCount(): Promise<number> {\n return await this.page.locator('.attachments tr').count();\n }\n\n async uploadFile(filePath: string): Promise<void> {\n const fileChooserPromise = this.page.waitForEvent('filechooser');\n await this.page.locator('input[type=\"file\"]').click();\n const fileChooser = await fileChooserPromise;\n await fileChooser.setFiles(filePath);\n }\n\n async expectWithAttachment(filename: string): Promise<void> {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).toBeVisible();\n }\n\n async expectWithNoAttachment(filename: string): Promise<void> {\n const test = await this.page.locator('.attachments').isVisible();\n if (test) {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).not.toBeVisible();\n }\n }\n\n async downloadFile(filename: string): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n const downloadPromise1 = this.page.waitForEvent('download');\n await this.page.getByText(filename).click();\n const download = await downloadPromise1;\n // Wait for the download process to complete and save the downloaded file in given path.\n await download.saveAs('./core/xlr-ui/build/playwright/' + download.suggestedFilename());\n expect(download.suggestedFilename()).toBe(filename);\n }\n\n async deleteAttachment(fileName: string): Promise<void> {\n await this.page.getByRole('row', { name: fileName }).locator('span').click();\n await this.page.getByText('Remove').click();\n }\n\n async save(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).click({ timeout: 8000 });\n await expect(this.page.locator('.form-footer .last-saved')).toBeVisible();\n }\n\n async reset(): Promise<void> {\n await this.page.getByRole('button', { name: 'Reset' }).waitFor();\n await this.page.getByRole('button', { name: 'Reset' }).click();\n }\n\n async removeDueDate(): Promise<void> {\n await this.page.locator('.due-date .close-icon').click();\n }\n\n async setScheduledStartDate(date: string, monthYear: string): Promise<void> {\n await this.scheduledStartDate.click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setDuration(days?: string, hours?: string, mins?: string): Promise<void> {\n await this.page.locator('.duration-editor').click();\n if (typeof days !== 'undefined') {\n await this.page.locator('.days').fill(days);\n }\n if (typeof hours !== 'undefined') {\n await this.page.locator('.hours').fill(hours);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.minutes').fill(mins);\n }\n }\n\n async expectScheduledStartDateToBe(date: string): Promise<void> {\n expect(await this.page.locator(`.scheduled-start-date .date input`).getAttribute('value')).toBe(date);\n }\n\n async expectDueDateToBe(date: string): Promise<void> {\n expect(await this.page.locator('.due-date .date-editor .date > .light-text').getAttribute('value')).toContain(date);\n }\n\n async expectedDueDateTime(time: string): Promise<void> {\n expect(await this.page.locator('.due-date .date-editor .time-picker-holder input').getAttribute('value')).toContain(\n time,\n );\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.page.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async setUsername(username: string): Promise<void> {\n await this.page.locator('.script-username').click();\n await this.page.locator('user-input-with-variable').getByLabel('*').fill(username);\n await this.page.locator('user-input-with-variable').press('Enter');\n }\n\n async setPassword(password: string): Promise<void> {\n await this.page.locator('.field > .display').click();\n await this.page.locator('input[name=\"scriptUserPassword\"]').fill(password);\n await this.page.locator('input[name=\"scriptUserPassword\"]').press('Enter');\n }\n\n async expectScriptUsernameToBe(username: string): Promise<void> {\n expect(await this.page.locator('.script-username').textContent()).toContain(username);\n }\n\n async expectScriptUserPasswordToBe(password: string): Promise<void> {\n expect(await this.page.locator('span[name=\"scriptUserPassword\"]').textContent()).toContain(password);\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TemplateCreatePage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setName(name: string): Promise<void> {\n await this.page.locator('#release-form-title').fill(name);\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.getByText('Set description...').hover();\n await this.page.locator('.display').filter({ hasText: 'Set description' }).locator('.edit-icon').click();\n await this.page.locator('textarea').click();\n await this.page.locator('textarea').clear();\n await this.page.locator('textarea').fill(description);\n await this.page.getByText('Save', { exact: true }).click();\n }\n\n async create(): Promise<void> {\n await this.page.getByRole('button', { name: 'Create' }).click();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TemplateTriggerPage extends WithPage {\n create: CreateNewTriggerPage;\n constructor(page: Page) {\n super(page);\n this.create = new CreateNewTriggerPage(page);\n }\n\n async expectAllowConcurrentReleasesFromTrigger(expectedValue: boolean): Promise<void> {\n if (expectedValue) {\n await this.page.locator('.col-xs-2 .trigger-item-state').textContent({ timeout: 3000 });\n expect(await this.page.locator('.col-xs-2 .trigger-item-state').textContent()).toContain('Enabled');\n } else {\n await this.page.locator('.col-xs-2 .trigger-item-state').textContent({ timeout: 3000 });\n expect(await this.page.locator('.col-xs-2 .trigger-item-state').textContent()).toContain('Disabled');\n }\n }\n\n async setAllowConcurrentReleasesFromTriggerAndSubmit(checked: boolean): Promise<void> {\n const result = await this.page.locator('.col-xs-2 .trigger-item-state').textContent({ timeout: 3000 });\n if ((result === 'Enabled' && checked === false) || (result == 'Disabled' && checked === true)) {\n await this.page.locator('form[name=\"releaseTriggerOptions\"] label[for=\"cb\"]').click();\n }\n }\n\n async expectTriggersVisible(amount: number): Promise<void> {\n await expect(this.page.locator('.xlr-trigger-row .trigger-row-content')).toHaveCount(amount);\n }\n\n async expectNoNewTriggerButtonShown(): Promise<void> {\n await expect(this.page.locator('.trigger-header a.button.primary')).not.toBeVisible();\n }\n\n async clickAddTrigger(): Promise<CreateNewTriggerPage> {\n await this.page.getByRole('button', { name: 'Add trigger' }).click();\n return new CreateNewTriggerPage(this.page);\n }\n\n async openContextualMenuForTrigger(triggerName: string): Promise<this> {\n await this.page\n .locator('.xlr-trigger-row')\n .filter({ has: this.page.locator('div[data-test-column=\"triggerTitle\"]').getByText(triggerName) })\n .locator('.context-menu-button')\n .click();\n return this;\n }\n\n async selectContextualMenuItem(triggerName: string, menuItem: string): Promise<this> {\n await this.openContextualMenuForTrigger(triggerName);\n await this.page.locator('#context-menu-container').getByRole('menuitem', { name: menuItem }).click();\n return this;\n }\n}\n\nexport class CreateNewTriggerPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setTriggerTitle(title: string): Promise<void> {\n await this.page.locator('#title').fill(title);\n }\n\n async setTriggerType(triggerType: string): Promise<void> {\n await this.page.getByRole('textbox', { name: 'Select trigger type...' }).click();\n await this.page.getByRole('textbox', { name: 'Select trigger type...' }).fill(triggerType);\n await this.page.getByText(triggerType).click();\n }\n\n async setFieldInput(field: string, value: string): Promise<void> {\n await this.page.getByRole('textbox', { name: field }).click();\n await this.page.getByRole('textbox', { name: field }).fill(value);\n }\n\n async setValuesForVariable(variableId: string, value: string): Promise<this> {\n await this.page.locator(`#${variableId}`).scrollIntoViewIfNeeded();\n await this.page.locator(`#${variableId}`).click();\n await this.page.locator(`#${variableId} input`).clear();\n await this.page.locator(`#${variableId} input`).fill(value);\n return this;\n }\n\n async save(): Promise<void> {\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Save' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Save' }).click({ force: true });\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TemplateVariablesPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async clickEditVariable(variableName: string): Promise<TemplateVariableModal> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Edit').click();\n return new TemplateVariableModal(this.page);\n }\n}\n\nclass TemplateVariableModal extends WithPage {\n async setLabel(label: string): Promise<void> {\n await this.page.locator('.variable-label input').fill(label);\n }\n\n async setDefalutValue(value: string): Promise<void> {\n await this.page.locator('.variable-value input').fill(value);\n }\n\n async save(): Promise<void> {\n await this.page.locator('#modal .button.save').click();\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\nimport { TemplatePropertiesPage } from './templatePropertiesPage';\nimport { TemplateCreatePage } from './templateCreatePage';\nimport { TemplateTriggerPage } from './templateTriggerPage';\nimport { TemplateVariablesPage } from './templateVaraiablePage';\nimport { Util } from '../common/util';\nimport { ReleaseGanttPage } from '../releases/releaseGanttPage';\n\nexport class TemplatePage extends WithPage {\n taskDrawer: TaskDrawer;\n phaseTitle: Locator;\n properties: TemplatePropertiesPage;\n createTemplatePage: TemplateCreatePage;\n triggers: TemplateTriggerPage;\n util: Util;\n variables: TemplateVariablesPage;\n plannerView: ReleaseGanttPage;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n this.phaseTitle = page.locator('.phase .phase-title');\n this.properties = new TemplatePropertiesPage(page);\n this.createTemplatePage = new TemplateCreatePage(page);\n this.triggers = new TemplateTriggerPage(page);\n this.util = new Util(page);\n this.variables = new TemplateVariablesPage(page);\n this.plannerView = new ReleaseGanttPage(page);\n }\n\n private async openTemplateMenu(menuItem: string): Promise<void> {\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).click();\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromTableView(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.name-cell-title').getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromGrantt(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.gantt_tree_content').getByText(taskName, { exact: true }).dblclick();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openProperties(): Promise<void> {\n await this.util.openSideNavMenu('Properties');\n await expect(this.page.getByLabel('breadcrumb').getByText('Properties')).toBeVisible();\n }\n\n async openVariables(): Promise<void> {\n await this.util.openSideNavMenu('Variables');\n await expect(this.page.getByLabel('breadcrumb').getByText('Variables')).toBeVisible();\n }\n\n async openRelationships(): Promise<void> {\n await this.util.openSideNavMenu('Relationships');\n await expect(this.page.getByLabel('breadcrumb').getByText('Relationships')).toBeVisible();\n }\n\n async openTeamsPermissions(): Promise<void> {\n await this.util.openSideNavMenu('Teams & Permissions');\n await expect(this.page.getByLabel('breadcrumb').getByText('Teams & Permissions')).toBeVisible();\n }\n\n async openDashboard(): Promise<void> {\n await this.util.openSideNavMenu('Dashboard');\n await expect(this.page.getByLabel('breadcrumb').getByText('Dashboard')).toBeVisible();\n }\n\n async openHistory(): Promise<void> {\n await this.util.openSideNavMenu('History');\n await expect(this.page.getByLabel('breadcrumb').getByText('History')).toBeVisible();\n }\n\n async openTriggers(): Promise<void> {\n await this.openTemplateMenu('Triggers');\n await expect(this.page.getByLabel('breadcrumb').getByText('Triggers', { exact: true })).toBeVisible();\n }\n\n async backToTemplate(): Promise<void> {\n await this.page.locator('.icon-back').click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Templates')).toBeVisible();\n }\n\n async expectTemplateLabelToBePresent(): Promise<void> {\n await expect(this.page.getByTestId('template-workflow-pill').getByText('Template')).toBeVisible();\n }\n\n async expectSubPage(menuItem: string, toBePresent: boolean): Promise<void> {\n if (toBePresent)\n await expect(this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true })).toBeVisible();\n else\n await expect(\n this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }),\n ).not.toBeVisible();\n }\n\n async openFlowView(): Promise<void> {\n await this.util.openSideNavMenu('Flow');\n await expect(this.page.locator('#release-content')).toBeVisible();\n }\n\n async openTableView(): Promise<void> {\n await this.util.openSideNavMenu('Table');\n await expect(this.page.locator('.release-grid-container')).toBeVisible();\n }\n\n async openPlannerView(): Promise<ReleaseGanttPage> {\n await this.util.openSideNavMenu('Planner');\n await expect(this.page.locator('.gantt-container')).toBeVisible();\n return this.plannerView;\n }\n\n async openCodeView(): Promise<void> {\n await this.util.openSideNavMenu('Code');\n await expect(this.page.getByLabel('breadcrumb').getByText('Code')).toBeVisible();\n }\n\n async expandGanttFolder(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('.gantt_tree_icon.gantt_open');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandGanttFolder();\n }\n }\n }\n\n async addNewPhase(phaseName?: string): Promise<void> {\n await this.page.getByTestId('add-phase-btn').click();\n if (phaseName) {\n await this.phaseTitle.getByText('New Phase').click();\n await this.phaseTitle.getByRole('textbox').clear();\n await this.phaseTitle.getByRole('textbox').fill(phaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: phaseName })).toBeVisible();\n }\n }\n\n async renamePhase(oldPhaseName: string, newPhaseName: string): Promise<void> {\n await this.phaseTitle.getByText(oldPhaseName).click();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').clear();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').fill(newPhaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: newPhaseName })).toBeVisible();\n }\n\n async clickNewRelease(): Promise<void> {\n await this.page.getByTestId('new-release-btn').click();\n await expect(this.page.locator('.release-properties-form')).toBeVisible();\n }\n\n getPhase(phaseName: string): Phase {\n return new Phase(this.page, phaseName);\n }\n}\nclass Phase extends WithPage {\n private readonly phaseLocator: Locator;\n\n constructor(page: Page, phaseName: string) {\n super(page);\n this.phaseLocator = page.locator('.phase', { hasText: phaseName });\n }\n\n async setTitle(title: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header .display').click();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').clear();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').fill(title);\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').blur();\n }\n\n async expectTaskBorderWithColor(taskName: string, color: string): Promise<void> {\n await expect(this.page.locator(`.task-box:has-text('${taskName}')`)).toHaveCSS('border-top-color', color);\n }\n\n /**\n *\n * @param taskTitle Title of the task\n * @param taskType : Type of the task\n * @param taskTypeSelector : Selector of the task\n */\n\n async addTaskInPhase(taskTitle: string, taskGroup: string, taskType: string): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.page.locator('#task-selector').hover();\n await this.page.locator('button[aria-label=\"Clear\"]').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.locator('.icon-close').click();\n await this.page.locator('#task-title').fill(taskTitle);\n await this.page.getByTestId('save-select-task-btn').click();\n await this.page.locator('#release-header').click();\n await expect(this.phaseLocator.locator('.task-title').filter({ hasText: taskTitle })).toBeVisible();\n }\n\n async getNumberOfTasks(): Promise<number> {\n return await this.phaseLocator.locator('.task').count();\n }\n\n async expectToHaveNoneditableTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title > span')).toContainText(phaseTitle);\n }\n\n async expectToHaveTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title')).toContainText(phaseTitle);\n }\n\n async deleteTaskInPhase(taskName: string): Promise<void> {\n await this.page.locator('.task').filter({ hasText: taskName }).locator('.xl-icon.options-icon').click();\n await this.page.locator('.remove-task-button').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Task' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.phaseLocator.locator('li').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async deletePhase(phaseName: string): Promise<void> {\n await this.page.locator('.phase-header').filter({ hasText: phaseName }).locator('.actions').hover();\n await this.page.locator('.phase-header').filter({ hasText: phaseName }).locator('.delete-icon').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Phase' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.phase-header').filter({ hasText: phaseName })).not.toBeVisible();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { TemplatePage } from './templates/templatePage';\n\nexport class TemplateListPage extends WithPage {\n templatePage: TemplatePage;\n constructor(page: Page) {\n super(page);\n this.templatePage = new TemplatePage(page);\n }\n\n async openTemplatesList(filter: string): Promise<void> {\n let url = '/templates';\n if (filter) {\n url += `?has_filter&filter=${filter}`;\n }\n await this.page.goto(url);\n }\n\n async searchBy(criteria: string): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n await this.page.locator('.searchFilter').fill(criteria);\n }\n\n async copy(originTitle: string, targetTitle: string): Promise<void> {\n await this.page.locator('.title').filter({ hasText: originTitle }).locator('.copy').click();\n await this.page.getByLabel('Template name').clear();\n await this.page.getByLabel('Template name').fill(targetTitle);\n await this.page.getByLabel('Description').clear();\n await this.page.getByLabel('Description').fill('description');\n await this.page.getByRole('button', { name: 'Continue' }).click();\n await expect(this.page.getByTestId('template-workflow-pill').getByText('Template')).toBeVisible();\n }\n\n async move(templateName: string, targetFolder: string): Promise<void> {\n await this.page.locator('.template').filter({ hasText: templateName }).locator('.template-actions .move').click();\n await expect(this.page.getByText('Move template to')).toBeVisible();\n if (await this.page.getByRole('button', { name: 'Expand' }).isEnabled())\n await this.page.getByRole('button', { name: 'Expand' }).click();\n await this.page.getByPlaceholder('Search folder...').click();\n await this.page.getByPlaceholder('Search folder...').fill(targetFolder);\n await this.page.getByRole('button', { name: targetFolder }).click();\n await this.page.getByRole('button', { name: 'Move' }).click();\n await expect(this.page.getByText('Add', { exact: true })).toBeVisible();\n await expect(this.page.getByText('Remove')).toBeVisible();\n await this.page.getByRole('button', { name: 'Move' }).click();\n }\n\n async metaInformation(templateName: string, validationMsg?: string): Promise<void> {\n await this.page.locator('.title').filter({ hasText: templateName }).locator('.template-context-menu').click();\n await this.page.getByRole('menuitem', { name: 'Meta information' }).locator('a').click();\n await expect(this.page.getByRole('heading', { name: 'Meta information - ' + templateName })).toBeVisible();\n if (validationMsg) {\n await expect(this.page.getByText(validationMsg)).toBeVisible();\n }\n await expect(this.page.getByRole('button', { name: 'Close' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Close' }).click();\n }\n\n async expectTemplateVisible(title: string, expected = true): Promise<void> {\n if (expected) {\n await this.page.locator('.template').filter({ hasText: title }).waitFor();\n expect(this.page.locator('.template').filter({ hasText: title })).toBeVisible();\n } else {\n await this.page.locator('.template').filter({ hasText: title }).waitFor();\n expect(this.page.locator('.template').filter({ hasText: title })).not.toBeVisible();\n }\n }\n\n async delete(title: string): Promise<void> {\n await this.searchBy(title);\n await this.page.locator('.title').filter({ hasText: title }).locator('.delete').waitFor();\n await this.page.locator('.title').filter({ hasText: title }).locator('.delete').click();\n await this.page.locator('.modal .modal-content').waitFor({ state: 'visible' });\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.title').filter({ hasText: title })).not.toBeVisible();\n }\n\n async clickCreateNewTemplate(): Promise<void> {\n await this.page.locator('.action-toolbar-actions').getByRole('button', { name: 'New template' }).click();\n await this.page.locator('.action-toolbar-actions').getByRole('menuitem', { name: 'Create new template' }).click();\n }\n\n async openTemplateByName(templateName: string): Promise<void> {\n await this.filterByTitle(templateName);\n await this.page.locator(`.template`).filter({ hasText: templateName }).locator(`.raised-link`).waitFor();\n await this.page.locator(`.template`).filter({ hasText: templateName }).locator(`.raised-link`).click();\n }\n\n async clickNewReleaseIcon(templateName: string): Promise<void> {\n await this.page\n .locator('xlr-template-row-component')\n .filter({ hasText: templateName })\n .locator('.link .add-icon')\n .click();\n await expect(this.page.getByRole('heading', { name: 'Create new release' })).toBeVisible();\n }\n\n async createTemplate(templateName: string, description: string): Promise<void> {\n await this.clickCreateNewTemplate();\n await this.templatePage.createTemplatePage.setName(templateName);\n await this.templatePage.createTemplatePage.setDescription(description);\n await this.templatePage.createTemplatePage.create();\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n\n async filterByTitle(templateName: string): Promise<void> {\n await this.page.getByPlaceholder('Filter by title...', { exact: true }).click();\n await this.page.getByPlaceholder('Filter by title...', { exact: true }).fill(templateName);\n await this.page.getByPlaceholder('Filter by title...', { exact: true }).press('Enter');\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class RolesModal extends WithPage {\n roleName: Locator;\n newRoleName: Locator;\n addPrincipal: Locator;\n saveButton: Locator;\n editIcon: Locator;\n deleteButton: Locator;\n searchRoles: Locator;\n constructor(page: Page) {\n super(page);\n this.roleName = page.locator('Role name *');\n this.newRoleName = page.locator('Role name *');\n this.addPrincipal = page.locator('Add a principal...');\n this.saveButton = page.getByRole('button', { name: 'Save' });\n this.editIcon = page.getByRole('row', { name: '' }).getByLabel('Edit', { exact: true });\n this.deleteButton = page.getByRole('button', { name: 'Delete' });\n this.searchRoles = page.getByPlaceholder('Search roles...');\n }\n\n async setRoleName(roleName: string): Promise<void> {\n return await this.page.getByLabel('Role name *').fill(roleName, { timeout: 1000 });\n }\n\n async editRoleName(newRoleName: string): Promise<void> {\n return await this.page.getByLabel('Role name *').fill(newRoleName, { timeout: 1000 });\n }\n\n async setPrincipal(addPrincipal: string): Promise<void> {\n await this.page.getByPlaceholder('Add a principal...').fill(addPrincipal, { timeout: 1000 });\n }\n\n async searchRoleByRoleName(searchRoles: string): Promise<void> {\n await this.page.getByPlaceholder('Search roles...').fill(searchRoles, { timeout: 1000 });\n }\n async save(): Promise<void> {\n await this.saveButton.isEnabled();\n await expect(this.saveButton).not.toBeDisabled();\n await this.saveButton.focus();\n await this.saveButton.click();\n }\n\n async delete(): Promise<void> {\n await this.deleteButton.click();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { RolesModal } from './rolesModal';\n\nexport class RolesPage extends WithPage {\n page: Page;\n newRoleButton: Locator;\n modal: RolesModal;\n\n constructor(page: Page) {\n super(page);\n this.page = page;\n this.newRoleButton = this.page.getByTestId('new-role-btn');\n this.modal = new RolesModal(page);\n }\n\n async createRole(roleName: string, addPrincipal: string): Promise<void> {\n await this.newRoleButton.click();\n await this.modal.setRoleName(roleName);\n await this.modal.setPrincipal(addPrincipal);\n await this.modal.save();\n await this.expectToViewCreatedRole(roleName);\n }\n\n async editRole(roleName: string, newRoleName: string): Promise<void> {\n await this.page.getByRole('row', { name: roleName }).getByLabel('Edit', { exact: true }).click();\n await this.modal.editRoleName(newRoleName);\n await this.modal.save();\n }\n\n async searchRoleByRoleName(searchRoles: string): Promise<void> {\n await this.page.getByPlaceholder('Search roles...').fill(searchRoles, { timeout: 1000 });\n }\n\n async searchRoleByAssignedUsername(searchRolesByUsername: string): Promise<void> {\n await this.page\n .getByPlaceholder('Search assigned usernames or external groups...')\n .fill(searchRolesByUsername, { timeout: 1000 });\n }\n\n async deleteRole(roleName: string): Promise<void> {\n await this.page.getByRole('row', { name: roleName }).getByLabel('Delete', { exact: true }).click();\n await this.modal.delete();\n }\n\n async expectToViewRolesPage(): Promise<void> {\n await expect(this.page.locator('text=Principals')).toBeVisible();\n }\n\n async expectToViewCreatedRole(roleName: string): Promise<void> {\n await expect(this.page.getByRole('cell', { name: roleName })).toBeVisible();\n }\n\n async expectToViewEditedRole(roleName: string): Promise<void> {\n await expect(this.page.getByRole('cell', { name: roleName })).toBeVisible();\n }\n\n async expectRoleToBeDeleted(roleName: string): Promise<void> {\n await expect(this.page.getByRole('cell', { name: roleName })).toBeHidden();\n }\n\n async expectToViewSearchedRole(roleName: string): Promise<void> {\n await expect(this.page.locator('roles-page')).toContainText(roleName);\n }\n\n async expectToViewSearchedRoleByUsername(userName: string): Promise<void> {\n await expect(this.page.locator('roles-page')).toContainText(userName);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class RisksPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async getValue(classIdentifier: string): Promise<string> {\n return await this.page.locator(`.rz-bubble.${classIdentifier}-label`).innerText();\n }\n\n async setPointerValue(elem: Locator, value: number, isIncrease: boolean): Promise<void> {\n await elem.waitFor({ state: 'visible' });\n await elem.click();\n for (let i = 0; i < value; i++) {\n if (isIncrease) {\n await this.page.keyboard.press('ArrowRight');\n } else {\n await this.page.keyboard.press('ArrowLeft');\n }\n await elem.click();\n }\n }\n\n async setValue(identifier: string, newValue: number): Promise<void> {\n const value = await this.getValue(identifier);\n const initialDiff = newValue - parseInt(value);\n const elem = this.page.locator(`.rz-pointer-${identifier}`);\n const diffValue = Math.abs(initialDiff);\n await this.setPointerValue(elem, diffValue, initialDiff > 0);\n await this.checkValue(identifier, newValue);\n }\n\n async checkValue(identifier: string, value: number): Promise<void> {\n expect(await this.getValue(identifier)).toEqual(value.toString());\n }\n\n async shouldHaveEditButton(present = true): Promise<void> {\n const locator = this.page.locator('#editRisk');\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async shouldHaveSaveButton(present = true): Promise<void> {\n const locator = this.page.getByTestId('save-btn');\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async startEditGlobalRiskThreshold(): Promise<void> {\n await this.page.locator('#editRisk').click();\n }\n\n async setInitialValues(): Promise<void> {\n await this.setValue('min', 10);\n await this.setValue('max', 50);\n }\n\n async changeValuesAndSave(minValue: number, maxValue: number): Promise<void> {\n await this.setValue('min', minValue);\n await this.setValue('max', maxValue);\n await this.page.locator('#submit').click();\n }\n\n async checkValuesChanged(minValue: number, maxValue: number): Promise<void> {\n await this.checkValue('min', minValue);\n await this.checkValue('max', maxValue);\n }\n\n async expectRiskProfileToBePresent(title: string, present = true): Promise<void> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n const locator = this.page.locator('.risk-profile .data-row').filter({ hasText: title });\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async expectDefaultRiskProfileToBeFirst(): Promise<void> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n await expect(this.page.locator('.risk-profile .data-row .ng-binding').first()).toHaveText('Default risk profile');\n }\n\n async openRiskProfile(title: string): Promise<RisksProfilePage> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).click();\n return new RisksProfilePage(this.page);\n }\n\n async shouldHaveCopyButtonEnabledForRiskProfile(title: string, enabled = true): Promise<void> {\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).waitFor({ state: 'visible' });\n const locator = this.page.locator('.risk-profile .data-row').filter({ hasText: title }).locator('.copy-action');\n if (enabled) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async shouldHaveDeleteButtonEnabledForRiskProfile(title: string, enabled = true): Promise<void> {\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).waitFor({ state: 'visible' });\n const locator = this.page.locator(`.risk-profile .data-row`).filter({ hasText: title }).locator(`.remove-action`);\n if (enabled) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async clickNewRiskProfile(): Promise<RisksProfilePage> {\n await this.page.getByTestId('new-risk-btn').waitFor({ state: 'visible' });\n await this.page.getByTestId('new-risk-btn').click();\n return new RisksProfilePage(this.page);\n }\n\n async deleteRiskProfile(title: string): Promise<void> {\n await this.page\n .locator('.risk-profile .data-row')\n .filter({ hasText: title })\n .locator('.remove-action')\n .waitFor({ state: 'visible' });\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).locator('.remove-action').click();\n await this.page.locator('.modal-footer .button.save').click();\n }\n\n async expectSuccessMessageOnRisksPage(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Risk Profile Created Successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async copyRiskProfile(title: string): Promise<void> {\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).waitFor({ state: 'visible' });\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).locator('.copy-action').click();\n }\n\n async expectSuccessMessageOnUpdateRiskProfile(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Risk Profile Updated Successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async filter(filterText: string): Promise<void> {\n await this.page.locator('#risk-profile-filter').waitFor({ state: 'visible' });\n await this.page.locator('#risk-profile-filter').clear();\n await this.page.locator('#risk-profile-filter').fill(filterText);\n }\n\n async shouldHaveNVisibleRiskProfiles(numberOfVisibleRiskProfiles: number): Promise<void> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n expect(await this.page.locator('#risk-profile-table .data-row').count()).toEqual(numberOfVisibleRiskProfiles);\n }\n\n async shouldHaveNewRiskProfileButton(present = true): Promise<void> {\n const locator = this.page.getByTestId('new-risk-btn');\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async closeNotificationBanner(): Promise<void> {\n const closeIcon = this.page.getByTestId(`CloseIcon`);\n if (await closeIcon.isVisible()) {\n await closeIcon.click();\n }\n }\n}\n\nclass RisksProfilePage extends WithPage {\n async shouldBeEditable(editable: boolean): Promise<void> {\n const elem = this.page.locator('#riskProfileTitle');\n if (editable) {\n await expect(elem).toBeEnabled();\n } else {\n await expect(elem).toBeDisabled();\n }\n }\n\n async setName(name: string): Promise<void> {\n await this.page.locator('#riskProfileTitle').waitFor({ state: 'visible' });\n await this.page.locator('#riskProfileTitle').click();\n await this.page.locator('#riskProfileTitle').clear();\n await this.page.locator('#riskProfileTitle').fill(name);\n }\n\n async save(): Promise<void> {\n await this.page.getByTestId('save-btn').click();\n await expect(this.page.locator('#risk-profile-table')).toBeVisible();\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class advancedSettingsPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class experimentalSettingsPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async getFeatureControl(feature: string, control: string): Promise<Locator> {\n return this.page.locator(`.settings-card`).filter({ hasText: feature }).locator(`#${control}`);\n }\n\n async expectFeatureToBeEnabled(feature: string, state: boolean, control: string): Promise<this> {\n if (state) await expect(await this.getFeatureControl(feature, control)).toBeChecked();\n else await expect(await this.getFeatureControl(feature, control)).not.toBeChecked();\n return this;\n }\n\n async expectSaveToBeEnabled(state: boolean): Promise<this> {\n if (state) await expect(this.page.getByTestId(`save-button`)).toBeEnabled();\n else await expect(this.page.getByTestId(`save-button`)).not.toBeEnabled();\n return this;\n }\n\n async expectResetToBeEnabled(state: boolean): Promise<this> {\n if (state) await expect(this.page.getByTestId('reset-button')).toBeEnabled();\n else await expect(this.page.getByTestId('reset-button')).not.toBeEnabled();\n return this;\n }\n\n async disableFeature(feature: string, control: string): Promise<this> {\n await this.page.locator(`.settings-card`).filter({ hasText: feature }).locator(`#${control}`).uncheck();\n return this;\n }\n\n async expectToBeSaved(): Promise<this> {\n await expect(this.page.locator('.dot-snackbar[severity=\"success\"]')).toBeVisible();\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class TaskSettingsPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async setStatusPollingInterval(value: string): Promise<this> {\n await this.page.locator('#taskStatusInterval').clear();\n await this.page.locator('#taskStatusInterval').fill(value);\n return this;\n }\n\n async setListPollingInterval(value: string): Promise<this> {\n await this.page.locator('#taskListInterval').clear();\n await this.page.locator('#taskListInterval').fill(value);\n return this;\n }\n\n async expectStatusPollingInterval(value: string): Promise<this> {\n await expect(this.page.locator('#taskStatusInterval')).toHaveValue(value);\n return this;\n }\n\n async expectListPollingInterval(value: string): Promise<this> {\n await expect(this.page.locator('#taskListInterval')).toHaveValue(value);\n return this;\n }\n\n async restoreDefaultPollingSettings(): Promise<this> {\n const defaultTaskStatusInterval = '1';\n const defaultTaskListInterval = '30';\n\n await this.setStatusPollingInterval(defaultTaskStatusInterval);\n await this.setListPollingInterval(defaultTaskListInterval);\n\n await this.settings.save();\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class ReportsSettingsPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async setWarningThreshold(value: string): Promise<this> {\n await this.page.locator('#warningThreshold').clear();\n await this.page.locator('#warningThreshold').fill(value);\n return this;\n }\n\n async setErrorThreshold(value: string): Promise<this> {\n await this.page.locator('#errorThreshold').clear();\n await this.page.locator('#errorThreshold').fill(value);\n return this;\n }\n\n async setCriticalPhaseThreshold(value: string): Promise<this> {\n await this.page.locator('#criticalPhaseThreshold').clear();\n await this.page.locator('#criticalPhaseThreshold').fill(value);\n return this;\n }\n\n async expectWarningThreshold(value: string): Promise<this> {\n await expect(this.page.locator('#warningThreshold')).toHaveValue(value);\n return this;\n }\n\n async expectErrorThreshold(value: string): Promise<this> {\n await expect(this.page.locator('#errorThreshold')).toHaveValue(value);\n return this;\n }\n\n async expectCriticalPhaseThreshold(value: string): Promise<this> {\n await expect(this.page.locator('#criticalPhaseThreshold')).toHaveValue(value);\n return this;\n }\n\n async restoreDefaultReportSettings(): Promise<void> {\n const defaultWarningThreshold = '2';\n const defaultErrorThreshold = '4';\n const defaultCriticalPhaseThreshold = '6';\n\n await this.setWarningThreshold(defaultWarningThreshold);\n await this.setErrorThreshold(defaultErrorThreshold);\n await this.setCriticalPhaseThreshold(defaultCriticalPhaseThreshold);\n\n await this.settings.save();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class ReleaseAndTriggersPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async setArchivingSettingsDeleteIntervalUnit(value: string): Promise<this> {\n const setDeleteInterval = this.page.locator('select#time-selector-releaseAgeToDeleteFromJcr');\n await setDeleteInterval.scrollIntoViewIfNeeded();\n await setDeleteInterval.selectOption(value);\n return this;\n }\n\n async expectArchivePurgeEnableState(value: boolean): Promise<this> {\n if (value) {\n await expect(this.page.locator('#purgingEnabled')).toBeChecked();\n } else {\n await expect(this.page.locator('#purgingEnabled')).not.toBeChecked();\n }\n return this;\n }\n\n async setArchivePurgeEnableState(value: boolean): Promise<this> {\n if (value) {\n await this.page.locator('#purgingEnabled').check({ force: true });\n } else {\n await this.page.locator('#purgingEnabled').uncheck({ force: true });\n }\n return this;\n }\n\n async expectConfirmEnableArchivePurgeModal(): Promise<this> {\n await expect(this.page.getByRole('heading', { name: 'Verify archive purge change' })).toBeVisible();\n await expect(this.page.locator('.dot-dialog')).toBeVisible();\n return this;\n }\n\n async confirmEnableArchivePurgeModal(): Promise<this> {\n await expect(this.page.getByRole('button', { name: 'Confirm' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Confirm' }).click();\n return this;\n }\n\n async cancelEnableArchivePurgeModal(): Promise<this> {\n await expect(this.page.getByRole('button', { name: 'Cancel' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async setMaxArchiveRetentionPeriodIntervalUnit(value: string): Promise<this> {\n await this.page.locator('#time-selector-maximumArchiveRetentionPeriod').selectOption(value);\n return this;\n }\n\n async setMaxArchiveRetentionPeriodInterval(value: string): Promise<this> {\n await this.page.getByRole('spinbutton', { name: 'Maximum archive retention' }).fill(value);\n return this;\n }\n\n async expectInputFieldToBeDisabled(fieldName: string): Promise<this> {\n await expect(this.page.getByRole('spinbutton', { name: fieldName })).toHaveAttribute('readonly', '');\n return this;\n }\n}\n","import { WithPage } from './WithPage';\nimport { expect, Locator, Page } from '@playwright/test';\n\nexport class NotificationPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async getTasksTableElement(): Promise<Locator> {\n return this.page.locator('.tasks-table table');\n }\n\n async getTasksTableRows(): Promise<Locator> {\n return (await this.getTasksTableElement()).locator('tbody tr');\n }\n\n async getEventElement(eventName: string): Promise<Locator> {\n return this.page.locator(`tbody > tr `).filter({ hasText: eventName });\n }\n\n async getEventRowElement(eventName: string): Promise<Locator> {\n return (await this.getEventElement(eventName)).locator('td');\n }\n\n async findAddTagInputElementOnRow(eventRowElement: Locator): Promise<Locator> {\n return eventRowElement.locator('input[type=text].tag-input');\n }\n\n async getTasksEventIdSearchInput(): Promise<Locator> {\n return (await this.getTasksTableElement()).locator('.with-search > input[type=text]').first();\n }\n\n async getSuggestedRoleElement(roleName: string): Promise<Locator> {\n return this.page.locator(`.xlr-tags-suggestions .tag-label`).filter({ hasText: roleName });\n }\n\n async getRoleElementFromEvent(eventName: string, roleName: string): Promise<Locator> {\n return (await this.getEventRowElement(eventName)).locator(`.role-cell .tag.role`).filter({ hasText: roleName });\n }\n\n async getCloseTagElements(): Promise<Locator> {\n return this.page.locator('.tag.role a.tag-close');\n }\n\n async getEditMessageElements(): Promise<Locator> {\n return this.page.locator('a.action.link').filter({ hasText: 'Edit Message' });\n }\n\n async findEditMessageLinkElementOnRow(eventRowElement: Locator): Promise<Locator> {\n return eventRowElement.locator('a.action.link').filter({ hasText: 'Edit Message' });\n }\n\n async typeRoleTagNameInEventInput(eventName: string, roleName: string): Promise<this> {\n const eventRowElement = await this.getEventRowElement(eventName);\n await (await this.findAddTagInputElementOnRow(eventRowElement)).fill(roleName);\n return this;\n }\n\n async clearRoleTagNameInEventInput(eventName: string): Promise<this> {\n const eventRowElement = await this.getEventRowElement(eventName);\n await (await this.findAddTagInputElementOnRow(eventRowElement)).clear();\n return this;\n }\n\n async filterTaskTableByEventId(filterText: string): Promise<this> {\n await (await this.getTasksEventIdSearchInput()).fill(filterText);\n return this;\n }\n\n async expectSuggestedRoleToBeVisible(roleName: string, shouldBeVisible = true): Promise<this> {\n shouldBeVisible\n ? expect(await this.getSuggestedRoleElement(roleName)).toBeTruthy()\n : expect(await this.getSuggestedRoleElement(roleName)).toBeFalsy();\n return this;\n }\n\n async expectRoleTagToBePresentOnEvent(eventName: string, roleName: string, shouldBePresent = true): Promise<this> {\n shouldBePresent\n ? await expect(await this.getRoleElementFromEvent(eventName, roleName)).toBeVisible()\n : await expect(await this.getRoleElementFromEvent(eventName, roleName)).not.toBeVisible();\n return this;\n }\n\n async expectTaskEventTableToHaveNumberOfRows(numberOfRows: number): Promise<this> {\n await expect(await this.getTasksTableRows()).toHaveCount(numberOfRows);\n return this;\n }\n\n async expectTablesToBeInReadOnlyMode(shouldBeReadOnly = true): Promise<this> {\n if (shouldBeReadOnly) {\n await expect(await this.getEditMessageElements()).toHaveCount(0);\n await expect(await this.getCloseTagElements()).toHaveCount(0);\n } else {\n expect(await (await this.getEditMessageElements()).count()).toBeGreaterThan(0);\n expect(await (await this.getCloseTagElements()).count()).toBeGreaterThan(0);\n }\n return this;\n }\n\n async removeRoleTagFromEvent(eventName: string, roleName: string): Promise<this> {\n await this.page\n .locator(`[data-test=\"${await this.toConstantFormat(eventName)}\"] div .tag.role`)\n .filter({ hasText: roleName })\n .locator('a.tag-close')\n .click();\n return this;\n }\n\n async toConstantFormat(input: string): Promise<string> {\n return input.trim().toUpperCase().replace(/\\s+/g, '_');\n }\n}\n\nexport class NotificationModalPage extends NotificationPage {\n constructor(page: Page) {\n super(page);\n }\n\n async findBodySaveElement(): Promise<Locator> {\n return this.page.locator(`.modal-body .actions-wrapper button[data-testid=\"save-button\"]`);\n }\n\n async findBodyCloseElement(): Promise<Locator> {\n return this.page.locator(`.modal-body .actions-wrapper button[data-testid=\"cancel-button\"]`);\n }\n\n async expectBodyTextareaControlsToExist(shouldExist = true): Promise<this> {\n if (shouldExist) {\n expect(await (await this.findBodySaveElement()).count()).toBeGreaterThan(0);\n expect(await (await this.findBodyCloseElement()).count()).toBeGreaterThan(0);\n } else {\n await expect(await this.findBodySaveElement()).toHaveCount(0);\n await expect(await this.findBodyCloseElement()).toHaveCount(0);\n }\n return this;\n }\n\n async getPriorityDropdownElement(): Promise<Locator> {\n return this.page.locator('.priority-group .xlr-react-select');\n }\n\n async getPriorityDropdownItemElement(priority: string): Promise<Locator> {\n return this.page.locator(`.ant-select-dropdown .ant-select-dropdown-menu-item`).filter({ hasText: priority });\n }\n\n async getModalCancelButtonElement(): Promise<Locator> {\n return this.page.locator('.modal-footer .button.cancel');\n }\n\n async getModalSaveButtonElement(): Promise<Locator> {\n return this.page.locator('.modal-footer .button.primary');\n }\n\n async setPriority(priority: string): Promise<this> {\n await (await this.getPriorityDropdownElement()).click();\n await (await this.getPriorityDropdownItemElement(priority)).click();\n return this;\n }\n\n async expectModalSaveButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n if (shouldBeEnabled) {\n await expect(await this.getModalSaveButtonElement()).toBeEnabled();\n } else {\n await expect(await this.getModalSaveButtonElement()).toBeDisabled();\n }\n return this;\n }\n\n async expectModalCancelButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n if (shouldBeEnabled) {\n await expect(await this.getModalCancelButtonElement()).toBeEnabled();\n } else {\n await expect(await this.getModalCancelButtonElement()).toBeDisabled();\n }\n return this;\n }\n\n async hasPriority(priority: string): Promise<this> {\n await expect(this.page.locator('.ant-select-selection-selected-value')).toHaveText(priority);\n return this;\n }\n\n async setSubject(subject: string): Promise<this> {\n const subjectElem = this.page.getByRole('textbox');\n await subjectElem.click();\n await subjectElem.clear();\n await subjectElem.fill(subject);\n return this;\n }\n\n async hasSubject(subject: string): Promise<this> {\n await expect(this.page.locator(`input[name=\"subject\"]`)).toHaveValue(subject);\n return this;\n }\n\n async writeIntoBodyTextarea(bodyText: string): Promise<this> {\n await this.page.getByLabel('Double-click to edit').waitFor({ timeout: 10000 });\n await this.page.getByLabel('Double-click to edit').hover();\n await this.page.locator('.markdown-viewer-actions').getByTestId('edit-button').click();\n const bodyTextareaElem = this.page.locator(`textarea[id=\"body-input\"]`);\n await bodyTextareaElem.clear();\n await bodyTextareaElem.fill(bodyText);\n return this;\n }\n\n async saveTextInsideOfBodyTextarea(): Promise<this> {\n await expect(this.page.getByTestId('save-button')).toBeVisible();\n await this.page.getByTestId('save-button').click();\n return this;\n }\n\n async setBody(body: string): Promise<this> {\n await this.writeIntoBodyTextarea(body);\n await this.expectBodyTextareaControlsToExist();\n await this.saveTextInsideOfBodyTextarea();\n return this;\n }\n\n async hasBody(body: string): Promise<this> {\n await expect(this.page.locator('.markdown-wrapper')).toContainText(body);\n return this;\n }\n\n async save(): Promise<this> {\n await (await this.getModalSaveButtonElement()).click();\n return this;\n }\n\n async cancel(): Promise<this> {\n await (await this.getModalCancelButtonElement()).click();\n return this;\n }\n\n async confirmLeave(): Promise<this> {\n await this.page.locator('.leave-confirmation-dialog').getByRole('button', { name: 'Leave' }).click();\n return this;\n }\n\n async expectNotificationSettingsModalToBeVisible(shouldBeVisible = true): Promise<this> {\n const modal = this.page.locator(`[role='dialog'] .xl-react-widget-modal-dialog`);\n if (shouldBeVisible) {\n await expect(modal).toBeVisible();\n } else {\n await expect(modal).toHaveCount(0);\n }\n return this;\n }\n\n async expectModalControlButtonsToBeEnabled(shouldBeEnabled = true): Promise<this> {\n await this.expectModalSaveButtonToBeEnabled(shouldBeEnabled);\n await this.expectModalCancelButtonToBeEnabled(shouldBeEnabled);\n return this;\n }\n\n async changeEmailDataWithAssertion(priority: string, subject: string, body: string): Promise<this> {\n await this.expectBodyTextareaControlsToExist(false);\n await this.setPriority(priority);\n await this.expectModalCancelButtonToBeEnabled();\n await this.hasPriority(priority);\n await this.expectModalCancelButtonToBeEnabled();\n await this.setSubject(subject);\n await this.expectModalCancelButtonToBeEnabled();\n await this.hasSubject(subject);\n await this.setBody(body);\n await this.expectModalCancelButtonToBeEnabled();\n await this.hasBody(body);\n await this.expectModalControlButtonsToBeEnabled();\n return this;\n }\n\n async changeEmailDataSaveChangesAndAssert(priority: string, subject: string, body: string): Promise<this> {\n await this.changeEmailDataWithAssertion(priority, subject, body);\n await this.save();\n await this.expectNotificationSettingsModalToBeVisible(false);\n return this;\n }\n\n async changeEmailDataCancelChangesAndAssert(priority: string, subject: string, body: string): Promise<this> {\n await this.changeEmailDataWithAssertion(priority, subject, body);\n await this.cancel();\n await this.expectLeaveConfirmationModalToBeVisible();\n await this.confirmLeave();\n return this;\n }\n\n async expectLeaveConfirmationModalToBeVisible(shouldBeVisible = true): Promise<this> {\n shouldBeVisible\n ? await expect(this.page.locator('.leave-confirmation-dialog')).toBeVisible()\n : await expect(this.page.locator('.leave-confirmation-dialog')).toHaveCount(0);\n return this;\n }\n\n async openModalAndExpectData(priority: string, subject: string, body: string): Promise<this> {\n await this.hasPriority(priority);\n await this.hasSubject(subject);\n await this.hasBody(body);\n return this;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { NotificationModalPage, NotificationPage } from '../notificationPage';\n\nexport class NotificationSettingsPage extends NotificationPage {\n constructor(page: Page) {\n super(page);\n }\n\n async getResetButtonElement(): Promise<Locator> {\n return this.page.getByTestId('reset-btn');\n }\n\n async getSaveButtonElement(): Promise<Locator> {\n return this.page.getByTestId('save-btn');\n }\n\n async getSuggestionTag(): Promise<Locator> {\n return this.page.locator('.xlr-tags-suggestions .tag-label');\n }\n\n async getSuggestedRoleElement(roleName: string): Promise<Locator> {\n return this.page.locator(`.xlr-tags-suggestions .tag-label`).filter({ hasText: roleName });\n }\n\n async selectSuggestedRole(roleName: string): Promise<this> {\n await (await this.getSuggestedRoleElement(roleName)).click();\n return this;\n }\n\n async getEventElement(eventName: string): Promise<Locator> {\n return this.page.locator(`tbody > tr `).filter({ hasText: eventName });\n }\n\n async getEventRowElement(eventName: string): Promise<Locator> {\n return (await this.getEventElement(eventName)).locator('td');\n }\n\n async getRoleElementFromEvent(eventName: string, roleName: string): Promise<Locator> {\n return (await this.getEventRowElement(eventName))\n .locator(`.role-cell .tag.role span`)\n .filter({ hasText: roleName });\n }\n\n async expectResetButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n shouldBeEnabled\n ? await expect(await this.getResetButtonElement()).toBeEnabled()\n : await expect(await this.getResetButtonElement()).toBeDisabled();\n return this;\n }\n\n async expectSaveButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n shouldBeEnabled\n ? await expect(await this.getSaveButtonElement()).toBeEnabled()\n : await expect(await this.getSaveButtonElement()).toBeDisabled();\n return this;\n }\n\n async expectTableWithRecipients(tableTitle: string, recipientEnabled: boolean): Promise<this> {\n const countElement = this.page\n .locator(`.collapsible-component`)\n .filter({ hasText: tableTitle })\n .locator(`.tags.react-tags-wrapper`);\n recipientEnabled\n ? expect(await countElement.count()).toBeGreaterThan(0)\n : expect(await countElement.count()).toBe(0);\n return this;\n }\n\n async typeRoleText(eventId: string, roleText: string): Promise<this> {\n await this.page.locator(`.events-permissions-table input#${eventId}`).fill(roleText);\n return this;\n }\n\n async addRoleToEvent(eventId: string, roleName: string): Promise<this> {\n await this.typeRoleText(eventId, roleName);\n await this.selectSuggestedRole(roleName);\n return this;\n }\n\n async removeRoleFromEvent(eventId: string, roleName: string): Promise<this> {\n const roleElem = await this.getRoleElementFromEvent(roleName, eventId);\n await roleElem.locator('.role .tag-close').click();\n return this;\n }\n\n async expectSuggestionTagToHaveText(expectedText: string): Promise<this> {\n await expect(await this.getSuggestionTag()).toHaveText(expectedText);\n return this;\n }\n\n async expectCancelAndSaveButtonsToBeEnabled(shouldBeEnabled = true): Promise<this> {\n shouldBeEnabled\n ? await expect(await this.getResetButtonElement()).toBeEnabled()\n : await expect(await this.getSaveButtonElement()).toBeDisabled();\n return this;\n }\n\n async addRoleToEventWithAssertions(eventName: string, roleName: string): Promise<this> {\n await this.typeRoleTagNameInEventInput(eventName, roleName);\n await this.expectSuggestedRoleToBeVisible(roleName);\n await this.selectSuggestedRole(roleName);\n await this.expectRoleTagToBePresentOnEvent(eventName, roleName);\n await this.expectCancelAndSaveButtonsToBeEnabled();\n return this;\n }\n\n async removeRoleAndAssert(eventName: string, roleName: string): Promise<this> {\n await this.expectTablesToBeInReadOnlyMode(false);\n await this.removeRoleTagFromEvent(eventName, roleName);\n await this.expectRoleTagToBePresentOnEvent(eventName, roleName, false);\n await this.expectCancelAndSaveButtonsToBeEnabled();\n return this;\n }\n\n async openEditMessageFromEvent(eventName: string): Promise<NotificationModalPage> {\n await this.page\n .locator(`[data-test=\"${await this.toConstantFormat(eventName)}\"]`)\n .getByText('Edit Message')\n .click();\n return new NotificationModalPage(this.page);\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { RisksPage } from './systemSettings/risksProfilePage';\nimport { WithPage } from './WithPage';\nimport { Util } from './common/util';\nimport { advancedSettingsPage } from './systemSettings/advancedSettingsPage';\nimport { experimentalSettingsPage } from './systemSettings/experimentalSettingsPage';\nimport { TaskSettingsPage } from './systemSettings/taskSettingsPage';\nimport { ReportsSettingsPage } from './systemSettings/reportsSettingsPage';\nimport { ReleaseAndTriggersPage } from './systemSettings/releaseAndTriggersPage';\nimport { NotificationSettingsPage } from './systemSettings/notificationSettingsPage';\n\nexport class SystemSettingsPage extends WithPage {\n util: Util;\n risksPage: RisksPage;\n constructor(page: Page) {\n super(page);\n this.risksPage = new RisksPage(page);\n this.util = new Util(page);\n }\n\n async openGeneralSettings(): Promise<GeneralSettings> {\n await this.util.openSideNavMenu('General');\n await expect(this.page.getByLabel('breadcrumb').getByText('General')).toBeVisible();\n return new GeneralSettings(this.page);\n }\n\n async openReleasesAndTriggers(): Promise<ReleaseAndTriggersPage> {\n await this.util.openSideNavMenu('Releases and Triggers');\n await expect(this.page.getByLabel('breadcrumb').getByText('Releases and Triggers')).toBeVisible();\n return new ReleaseAndTriggersPage(this.page);\n }\n\n async openTasks(): Promise<TaskSettingsPage> {\n await this.util.openSideNavMenu('Tasks');\n await expect(this.page.getByLabel('breadcrumb').getByText('Tasks')).toBeVisible();\n return new TaskSettingsPage(this.page);\n }\n\n async openReports(): Promise<ReportsSettingsPage> {\n await this.util.openSideNavMenu('Reports');\n await expect(this.page.getByLabel('breadcrumb').getByText('Reports')).toBeVisible();\n return new ReportsSettingsPage(this.page);\n }\n\n async openAdvanced(): Promise<advancedSettingsPage> {\n await this.util.openSideNavMenu('Advanced');\n await expect(this.page.getByLabel('breadcrumb').getByText('Advanced')).toBeVisible();\n return new advancedSettingsPage(this.page);\n }\n\n async openExperimental(): Promise<experimentalSettingsPage> {\n await this.util.openSideNavMenu('Experimental');\n await expect(this.page.getByLabel('breadcrumb').getByText('Experimental')).toBeVisible();\n return new experimentalSettingsPage(this.page);\n }\n\n async openNotifications(): Promise<NotificationSettingsPage> {\n await this.util.openSideNavMenu('Notifications');\n await expect(this.page.getByLabel('breadcrumb').getByText('Notifications')).toBeVisible();\n return new NotificationSettingsPage(this.page);\n }\n\n async openRiskProfiles(): Promise<RisksPage> {\n await this.util.openSideNavMenu('Risk profiles');\n await expect(this.page.getByLabel('breadcrumb').getByText('Risk profiles')).toBeVisible();\n return new RisksPage(this.page);\n }\n\n async openWorkflowCategories(): Promise<void> {\n await this.util.openSideNavMenu('Workflow categories');\n await expect(this.page.getByLabel('breadcrumb').getByText('Workflow categories')).toBeVisible();\n }\n\n async openSMTPServer(): Promise<void> {\n await this.util.openSideNavMenu('SMTP server');\n await expect(this.page.getByLabel('breadcrumb').getByText('SMTP server')).toBeVisible();\n }\n\n async _saveDoNotAssert(): Promise<void> {\n // Check if the \"Save\" button is enabled and save if needed\n const saveButton = await this.page.getByTestId('save-button').isDisabled();\n if (!saveButton) {\n await this.page.getByTestId('save-button').click();\n }\n }\n\n async expectCards(cardTitles: string[] | string): Promise<this> {\n await expect(this.page.locator(`.settings-card .dot-card-header-title`)).toHaveCount(cardTitles.length);\n for (let i = 0; i < cardTitles.length; i++) {\n const cardTitle = cardTitles[i];\n await expect(\n this.page.locator(`.settings-card .dot-card-header-title`).filter({ hasText: cardTitle }),\n ).toBeVisible();\n }\n return this;\n }\n\n async save(): Promise<this> {\n await expect(this.page.getByTestId('save-button')).toBeVisible();\n await this.page.getByTestId('save-button').click();\n await expect(this.page.locator('.success').filter({ hasText: 'Changes saved successfully' })).toBeVisible();\n await this.page.locator('.success').getByRole('button').click();\n await expect(this.page.locator('.success').filter({ hasText: 'Changes saved successfully' })).not.toBeVisible();\n return this;\n }\n\n async reset(): Promise<this> {\n await this.page.getByTestId(`reset-button`).click();\n await expect(this.page.getByTestId('reset-button')).toBeDisabled();\n return this;\n }\n}\n\nexport class GeneralSettings extends SystemSettingsPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setInstanceName(value: string): Promise<this> {\n await this.page.locator('input#headerName').click({ force: true });\n await this.page.getByRole('textbox', { name: 'Instance name' }).fill(value);\n return this;\n }\n\n async setLoginMessage(message: string): Promise<this> {\n await this.page.locator('div#loginMessage').click({ force: true });\n const input = this.page.locator('input#loginMessage');\n\n const currentValue = await input.inputValue();\n if (currentValue.trim() !== '') {\n await input.fill('');\n }\n\n await input.fill(message);\n await input.press('Tab');\n return this;\n }\n\n async clearLoginMessage(): Promise<this> {\n await this.page.locator('div#loginMessage').click({ force: true });\n const input = this.page.locator('input#loginMessage');\n await input.fill('');\n await input.press('Tab');\n return this;\n }\n\n async setHeaderColor(colorName: string): Promise<this> {\n await this.page.locator('.color-picker button').click({ force: true });\n await this.page.locator(`.color-picker-list-item`).getByText(colorName).click({ force: true });\n return this;\n }\n\n async clickNotificationsMenu(): Promise<void> {\n await this.util.openSideNavMenu('Notifications');\n }\n\n async expectInstanceName(value: string): Promise<this> {\n await expect(this.page.locator('top-toolbar .dot-pill')).toHaveText(value);\n return this;\n }\n\n async restoreDefaultThemeSettings(): Promise<void> {\n await this._clearHeaderInstanceName();\n await this.setHeaderColor('Green');\n await this._saveDoNotAssert();\n }\n\n async _clearHeaderInstanceName(): Promise<void> {\n await this.page.locator('input#headerName').click({ force: true });\n await this.page.locator('input#headerName').clear();\n }\n\n async expectHeaderColor(value: string): Promise<this> {\n await expect(this.page.locator('top-toolbar .dot-app-toolbar')).toHaveAttribute(\n 'style',\n `border-bottom-color: ${value};`,\n );\n return this;\n }\n\n async expectConfirmationPopUp(): Promise<this> {\n await expect(this.page.getByRole('heading', { name: 'Confirm leave' })).toBeVisible();\n await expect(this.page.getByRole('paragraph')).toContainText('You have unsaved changes that will be lost.');\n await this.page.getByRole('button', { name: 'Leave without saving' }).click();\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ConnectionsPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async addNewInstance(typeName: string): Promise<ConfigurationInstancePage> {\n await this.page\n .locator(`.configuration-type`)\n .filter({ hasText: typeName })\n .locator(`.new-instance .button`)\n .first()\n .click({ force: true });\n return new ConfigurationInstancePage(this.page);\n }\n\n async expectInstanceDisplayed(instanceName: string): Promise<this> {\n await this.page.locator('#configuration').waitFor({ state: 'visible', timeout: 200000 });\n await expect(this.page.locator(`.configuration-instance`).filter({ hasText: instanceName })).toBeVisible();\n return this;\n }\n\n async expectInstanceNotDisplayed(instanceName: string): Promise<this> {\n await this.page.locator('#configuration').waitFor({ state: 'visible' });\n await expect(this.page.locator(`.configuration-instance`).filter({ hasText: instanceName })).not.toBeVisible();\n return this;\n }\n\n async openInstance(instanceName: string): Promise<ConfigurationInstancePage> {\n await this.page\n .locator(`.configuration-instance`)\n .filter({ hasText: instanceName })\n .locator(`.edit-instance`)\n .click({ force: true });\n return new ConfigurationInstancePage(this.page);\n }\n\n async deleteInstance(instanceName: string): Promise<this> {\n await this.page\n .locator(`.configuration-instance`)\n .filter({ hasText: instanceName })\n .locator(`.delete-instance`)\n .click({ force: true });\n return this;\n }\n\n async expectSuccessMsgToBeDisplayed(text: string): Promise<this> {\n await expect(this.page.locator('.success')).toContainText(text);\n await this.page.locator('.success').getByRole('button').click();\n return this;\n }\n\n async clearFilter(): Promise<this> {\n await this.page.locator('.search-input-filter input').clear({ force: true });\n return this;\n }\n\n async searchInstances(instanceName: string): Promise<this> {\n await this.page.getByPlaceholder('Search...').click();\n await this.page.getByPlaceholder('Search...').fill(instanceName);\n return this;\n }\n\n async expectErrorDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal-header h4')).toContainText('Error');\n await this.page.locator('.modal-header .xl-icon.close-icon').click();\n }\n}\n\nclass ConfigurationInstancePage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setTextField(fieldName: string, fieldValue: string): Promise<this> {\n await this.page.locator(`input[name=${fieldName}]`).clear({ force: true });\n await this.page.locator(`input[name=${fieldName}]`).fill(fieldValue, { force: true });\n return this;\n }\n\n async setNumberField(fieldName: string, fieldValue: number): Promise<this> {\n await this.page.locator(`#${fieldName}`).clear({ force: true });\n await this.page.locator(`#${fieldName}`).fill(fieldValue.toString(), { force: true });\n return this;\n }\n\n async selectFromDropdown(fieldName: string, element: string): Promise<this> {\n await this.page.getByLabel(fieldName).click();\n await this.page.getByRole('option', { name: element }).click();\n return this;\n }\n\n async save(): Promise<this> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.getByLabel('success')).toBeVisible();\n return this;\n }\n\n async test(): Promise<this> {\n await this.page.getByRole('button', { name: 'Test' }).click();\n return this;\n }\n\n async cancel(): Promise<this> {\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async expectResultBanner(message: string): Promise<this> {\n await expect(this.page.locator('.configuration-result-banner')).toBeVisible();\n await expect(this.page.locator('.configuration-result-banner')).toContainText(message);\n return this;\n }\n\n async expectDropdownToBe(fieldName: string, fieldValue: string): Promise<this> {\n const value = await this.page.locator(`#${fieldName}`).getAttribute('value');\n expect(value).toBe(fieldValue);\n return this;\n }\n\n async clearDropdown(fieldName: string): Promise<this> {\n await this.page.locator(`input[id=${fieldName}]`).click({ force: true });\n await this.page.getByRole(`button`, { name: 'Clear' }).click();\n return this;\n }\n\n async clickField(fieldName: string): Promise<this> {\n await this.page.getByLabel(fieldName).click();\n return this;\n }\n\n async expectTextFieldNotToExist(fieldName: string): Promise<this> {\n const locator = this.page.locator(`.input-scalar[data-test-id=\"${fieldName}\"]`);\n await expect(locator).toHaveCount(0);\n return this;\n }\n\n // To avoid flakiness and clicking around the page, we can directly click on the header\n async clickHeader(): Promise<void> {\n await this.page.locator('.configuration-instance-page h2').click();\n }\n\n async expectTextFieldToBe(fieldName: string, fieldValue: string): Promise<this> {\n expect(await this.page.locator(`input[name=${fieldName}]`).getAttribute('value')).toContain(fieldValue);\n return this;\n }\n\n async setStringList(value: Array<string> | string): Promise<this> {\n await this.page.locator('.input-list input#stringList').click();\n if (value instanceof Array) {\n for (const val of value) {\n await this.page.locator('.input-list input#stringList').fill(val);\n await this.page.locator('[data-test-id=\"stringList\"]').getByLabel('add icon button').click();\n }\n } else {\n await this.page.locator('.input-list input#stringList').fill(value);\n }\n return this;\n }\n\n async expectStringListCountToBe(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"stringList\"] .list`).count()).toBe(count);\n return this;\n }\n\n async removeString(value: string): Promise<this> {\n await this.page.locator('li').filter({ hasText: value }).getByLabel('close icon button').click();\n return this;\n }\n\n async setStringSet(value: Array<string> | string): Promise<this> {\n await this.page.locator('.input-list input#stringSet').click();\n if (value instanceof Array) {\n for (const val of value) {\n await this.page.locator('.input-list input#stringSet').fill(val);\n await this.page.locator('[data-test-id=\"stringSet\"]').getByLabel('add icon button').click();\n }\n } else {\n await this.page.locator('.input-list input#stringSet').fill(value);\n }\n return this;\n }\n\n async expectStringSetCountToBe(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"stringSet\"] .list`).count()).toBe(count);\n return this;\n }\n\n async setStringMap(pairs: { key: string; value: string }): Promise<void> {\n await this.page\n .locator('[data-test-id=\"stringMap\"]')\n .getByTestId('icon-button-tooltip')\n .getByLabel('Add key-value pair')\n .click();\n await this.page.locator('#new-row-key-input').fill(pairs.key);\n await this.page.locator('#new-row-value-input').fill(pairs.value);\n await this.page.getByRole('button', { name: 'check-line icon' }).click();\n }\n\n async expectStringMapCountToBe(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"stringMap\"] .map-data-row`).count()).toBe(count);\n return this;\n }\n\n async expectTestButtonToBeDisabled(): Promise<this> {\n await expect(this.page.locator('action-toolbar button').filter({ hasText: 'Test' })).toBeDisabled();\n return this;\n }\n\n async togglePasswordFieldVariable(fieldName: string): Promise<this> {\n await this.page.locator(`.input-with-variables[data-test-id=\"${fieldName}\"] button`).click({ force: true });\n return this;\n }\n\n async setPasswordFieldVariable(fieldName: string, fieldValue: string): Promise<this> {\n await this.page.locator(`.input-with-variables[data-test-id=\"${fieldName}\"] input`).click({ force: true });\n await this.page\n .locator(`.input-with-variables[data-test-id=\"${fieldName}\"] li`)\n .filter({ hasText: fieldValue })\n .click();\n return this;\n }\n\n async expectFieldsToNotBeVisible(fieldNames: Array<string> | string): Promise<this> {\n if (typeof fieldNames !== 'string') {\n for (const fName of fieldNames) {\n await expect(this.page.locator(`#${fName}`)).not.toBeVisible();\n }\n } else {\n await expect(this.page.locator(`#${fieldNames}`)).not.toBeVisible();\n }\n return this;\n }\n\n async expectFieldsToBeVisible(fieldNames: Array<string> | string): Promise<this> {\n if (typeof fieldNames !== 'string') {\n for (const fName of fieldNames) {\n await expect(this.page.locator(`input[name=${fName}]`)).toBeVisible();\n }\n } else {\n await expect(this.page.locator(`input[name=${fieldNames}]`)).toBeVisible();\n }\n return this;\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TaskAccessPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setTaskAvailableToAllUsers(taskName: string, enable?: boolean): Promise<void> {\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .scrollIntoViewIfNeeded();\n const checkboxElement = this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox');\n const isChecked = await checkboxElement.isChecked();\n if (isChecked && !enable) {\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .scrollIntoViewIfNeeded();\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .click();\n await this.page.getByTestId('save-btn').click();\n await this.page.locator('.saved-text').waitFor();\n } else if (!isChecked && enable) {\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .scrollIntoViewIfNeeded();\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .click();\n await this.page.getByTestId('save-btn').click();\n await this.page.locator('.saved-text').waitFor();\n }\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { ReleasePage } from './releases/ReleasePage';\nimport { ApplicationsPage } from './ApplicationsPage';\nimport { DataRandomGenerator } from './common/dataRandomGenerator';\nimport { DateUtil } from './common/dateUtil';\nimport { FolderPage } from './FolderPage';\nimport { GlobalVariable } from './globalVariablePage';\nimport { HomePage } from './homePage';\nimport { HeaderPage } from './headerPage';\nimport { ManagePluginsPage } from './managePluginsPage';\nimport { PersonalAccessTokenPage } from './PersonalAccessTokenPage';\nimport { PersonalSettingsPage } from './personalSettingsPage';\nimport { UsersPage } from './users/usersPage';\nimport { SettingsMenu } from './settingsMenu';\nimport { TaskDetails } from './taskDetails';\nimport { ReleaseCalendarPage } from './ReleaseCalendarPage';\nimport { ReleaseGroupPage } from './ReleaseGroupPage';\nimport { ReleaseGroupTimelinePage } from './ReleaseGroupTimelinePage';\nimport { ReleasesListPage } from './ReleasesListPage';\nimport { ReleaseVariablesPage } from './releases/ReleaseVariablesPage';\nimport { TaskListPage } from './tasks/taskListPage';\nimport { TemplatePage } from './templates/templatePage';\nimport { TemplateListPage } from './templateListPage';\nimport { Util } from './common/util';\nimport { RolesPage } from './users/rolesPage';\nimport { WorkflowCatalogPage } from './workflowCatalogPage';\nimport { SystemSettingsPage } from './systemSettingsPage';\nimport { ReleaseGanttPage } from './releases/releaseGanttPage';\nimport { ConnectionsPage } from './connectionsPage';\nimport { TaskAccessPage } from './tasks/taskAccessPage';\nimport { FolderDeliveryPage } from './folder/folderDeliveryPage';\n\nexport class Navigation {\n private readonly page: Page;\n connections: ConnectionsPage;\n dataRandomGenerator: DataRandomGenerator;\n dateUtil: DateUtil;\n folderPage: FolderPage;\n globalvariable: GlobalVariable;\n homePage: HomePage;\n header: HeaderPage;\n managePluginsPage: ManagePluginsPage;\n releasePage: ReleasePage;\n settingsMenu: SettingsMenu;\n systemSettingsPage: SystemSettingsPage;\n usersPage: UsersPage;\n applicationPage: ApplicationsPage;\n taskDetailsPage: TaskDetails;\n taskListPage: TaskListPage;\n templatePage: TemplatePage;\n templateListPage: TemplateListPage;\n personalSettingsPage: PersonalSettingsPage;\n releaseCalendarPage: ReleaseCalendarPage;\n releaseGroupPage: ReleaseGroupPage;\n releaseGroupTimelinePage: ReleaseGroupTimelinePage;\n releaseGanttPage: ReleaseGanttPage;\n releaseListPage: ReleasesListPage;\n rolesPage: RolesPage;\n util: Util;\n workflowCatalogPage: WorkflowCatalogPage;\n taskAccessPage: TaskAccessPage;\n\n constructor(page: Page) {\n this.page = page;\n this.connections = new ConnectionsPage(page);\n this.dataRandomGenerator = new DataRandomGenerator();\n this.dateUtil = new DateUtil(page);\n this.folderPage = new FolderPage(page);\n this.globalvariable = new GlobalVariable(page);\n this.homePage = new HomePage(page);\n this.header = new HeaderPage(page);\n this.managePluginsPage = new ManagePluginsPage(page);\n this.releasePage = new ReleasePage(page);\n this.settingsMenu = new SettingsMenu(page);\n this.systemSettingsPage = new SystemSettingsPage(page);\n this.usersPage = new UsersPage(page);\n this.applicationPage = new ApplicationsPage(page);\n this.taskDetailsPage = new TaskDetails(page);\n this.taskListPage = new TaskListPage(page);\n this.templatePage = new TemplatePage(page);\n this.templateListPage = new TemplateListPage(page);\n this.personalSettingsPage = new PersonalSettingsPage(page);\n this.releaseCalendarPage = new ReleaseCalendarPage(page);\n this.releaseGroupPage = new ReleaseGroupPage(page);\n this.releaseGroupTimelinePage = new ReleaseGroupTimelinePage(page);\n this.releaseListPage = new ReleasesListPage(page);\n this.releaseGanttPage = new ReleaseGanttPage(page);\n this.rolesPage = new RolesPage(page);\n this.util = new Util(page);\n this.workflowCatalogPage = new WorkflowCatalogPage(page);\n this.taskAccessPage = new TaskAccessPage(page);\n }\n\n async openTemplate(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, false);\n }\n\n async openFolder(id: string): Promise<FolderPage> {\n await this.page.goto(`./#/folders/${id}/releases`);\n await this.page.waitForSelector('#releases-content');\n return new FolderPage(this.page);\n }\n\n async openProfilePage(): Promise<PersonalSettingsPage> {\n await this.page.goto(`./#/profile`);\n return new PersonalSettingsPage(this.page);\n }\n\n async openVariablesOnReleasePage(releaseId: string): Promise<ReleaseVariablesPage> {\n await this.page.goto(`./#/releases/${releaseId}/variables`);\n await this.page.waitForSelector('#release-variables');\n return new ReleaseVariablesPage(this.page);\n }\n\n async openRelease(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, true);\n }\n\n async openPlannerView(releaseId: string): Promise<ReleaseGanttPage> {\n await this.page.goto(`#/releases/${releaseId}/planner`);\n return new ReleaseGanttPage(this.page);\n }\n\n async openApplicationsPage(): Promise<ApplicationsPage> {\n return new ApplicationsPage(this.page).goToApplicationsPage();\n }\n\n async openPersonalAccessTokenPage(): Promise<PersonalAccessTokenPage> {\n return new PersonalAccessTokenPage(this.page).openPersonalAccessTokenPage();\n }\n\n async gotoHomePage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Home', { exact: true }).click();\n }\n\n async gotoFolderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Folders', { exact: true }).click();\n }\n\n async gotoTaskPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Tasks', { exact: true }).click();\n }\n\n async gotoReleasePage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Releases', { exact: true }).click();\n }\n\n async gotoWorkflowCatalogPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Workflow catalog', { exact: true }).click();\n }\n\n async gotoWorkflowsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Workflows', { exact: true }).click();\n }\n\n async gotoGroupsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Groups', { exact: true }).click();\n }\n\n async gotoReleaseCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Release calendar', { exact: true }).click();\n }\n\n async gotoDeliveriesPage(): Promise<FolderDeliveryPage> {\n await this.page.locator('ul.side-nav li').getByLabel('Deliveries', { exact: true }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Deliveries')).toBeVisible();\n return new FolderDeliveryPage(this.page);\n }\n\n async gotoTriggersPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Triggers', { exact: true }).click();\n }\n\n async gotoDigitalAnalyticsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Digital.ai Analytics', { exact: true }).click();\n }\n\n async gotoReportsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Reports', { exact: true }).click();\n }\n\n async gotoTemplatesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Templates', { exact: true }).click();\n }\n\n async gotoEnvironmentsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Environments', { exact: true }).click();\n }\n\n async gotoEnvironmentsCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Environments calendar', { exact: true }).click();\n }\n\n async gotoGobalVariablesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Global variables', { exact: true }).click();\n }\n\n async gotoConnectionsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Connections', { exact: true }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Connections')).toBeVisible();\n }\n\n private async openReleaseOrTemplate(id: string, release: boolean): Promise<ReleasePage> {\n const url = release ? 'releases' : 'templates';\n await this.page.goto(`./#/${url}/${id}`);\n await this.page.waitForSelector('#release');\n return new ReleasePage(this.page);\n }\n\n async collapseSideView(): Promise<void> {\n await this.page.getByLabel('Collapse Q').click();\n await expect(this.page.getByLabel('Collapse Q')).not.toBeVisible();\n }\n\n async expandSideView(): Promise<void> {\n await this.page.getByLabel('Expand Q').click();\n await expect(this.page.getByLabel('Expand Q')).not.toBeVisible();\n }\n\n async openRisksProfile(): Promise<void> {\n await this.page.goto('./#/risks');\n }\n\n async openConnection(): Promise<void> {\n await this.page.goto('./#/configuration');\n await expect(this.page.getByLabel('breadcrumb').getByText('Connections')).toBeVisible();\n }\n\n async clickOnPrimaryLogo(): Promise<void> {\n await this.page.getByTestId('primary-logo').click();\n }\n async gotoTaskAccessPage(): Promise<TaskAccessPage> {\n await this.page.goto('#/task-access');\n return new TaskAccessPage(this.page);\n }\n}\n","import { expect, Locator } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class LoginPage extends WithPage {\n /**\n * Login with username and password\n * @param userName\n * @param password\n */\n async login(userName: string, password: string): Promise<void> {\n await this.page.goto('./#/login');\n await expect(this.page).toHaveTitle('Digital.ai Release');\n await this.page.getByPlaceholder('User').fill(userName, { timeout: 1000 });\n await this.page.getByPlaceholder('Password').fill(password, { timeout: 10000 });\n await this.page.getByRole('button', { name: 'Log in' }).click({ timeout: 10000 });\n await this.page.waitForTimeout(1000);\n await this.closePendoModalWindow();\n }\n\n async loginWithoutReload(userName: string, password: string): Promise<void> {\n let loadTriggered = false;\n this.page.on('load', () => {\n loadTriggered = true;\n });\n await this.page.evaluate(() => {\n window.location.hash = '#tasks';\n });\n expect(loadTriggered).toBe(false);\n await this.login(userName, password);\n }\n\n /**\n * Logout as authenticated user\n */\n async logout(): Promise<void> {\n await this.page.locator('button.dot-avatar').click();\n await this.page.getByText('Log out', { exact: true }).click();\n }\n\n /**\n * Expect login to be restricted for a user\n */\n async expectLoginDisallowed(): Promise<void> {\n const val = await this.page.textContent('.error-content span[ng-show=\"loginInfo.failedStatus == 403\"]');\n expect(val).toContain(\"You do not have 'login' permission.\");\n }\n\n /**\n * Expect the respective user is logged In\n * @param username\n */\n async expectToBeLogged(username: string): Promise<void> {\n const val = await this.page.locator('top-toolbar .avatar-wrapper span.dot-tooltip').getAttribute('aria-label');\n expect(val).toContain(username);\n }\n\n async closePendoModalWindow(): Promise<void> {\n await this.page.waitForTimeout(1000);\n if ((await this.page.locator('._pendo-close-guide').count()) > 0) {\n await this.page.locator('._pendo-close-guide').click();\n }\n }\n\n async expectUserNotVisible(): Promise<void> {\n const tooltip: Locator = this.page.locator('top-toolbar .avatar-wrapper .dot-tooltip');\n await tooltip.waitFor({ state: 'hidden' });\n }\n\n async expectUserVisible(): Promise<void> {\n const tooltip: Locator = this.page.locator('top-toolbar .avatar-wrapper .dot-tooltip');\n await tooltip.waitFor({ state: 'visible' });\n }\n\n async expectLoginPage(): Promise<void> {\n await expect(this.page).toHaveURL('./#/login');\n await expect(this.page.getByPlaceholder('User')).toBeVisible();\n await expect(this.page.getByPlaceholder('Password')).toBeVisible();\n await expect(this.page.getByRole('button', { name: 'Log in' })).toBeVisible();\n }\n}\n","import isUndefined from 'lodash/isUndefined';\nimport each from 'lodash/each';\nimport forEach from 'lodash/forEach';\nimport defaults from 'lodash/defaults';\nimport toPairs from 'lodash/toPairs';\n\nimport { Container, Dashboard, Phase, Release, Task, Tile, Variable, VariableValueProvider } from '../types';\n\nexport const initReleaseDefaults = (function () {\n const RELEASE_TYPE = 'xlrelease.Release';\n const PHASE_TYPE = 'xlrelease.Phase';\n const TEAM_TYPE = 'xlrelease.Team';\n const TASK_TYPE = 'xlrelease.Task';\n const COMMENT_TYPE = 'xlrelease.Comment';\n const CONDITION_TYPE = 'xlrelease.GateCondition';\n const DEPENDENCY_TYPE = 'xlrelease.Dependency';\n const LINK_TYPE = 'xlrelease.Link';\n const ATTACHMENT_TYPE = 'xlrelease.Attachment';\n const DASHBOARD_TYPE = 'xlrelease.Dashboard';\n const _TRIGGER_TYPE = 'xlrelease.ReleaseTrigger';\n const JIRA_TYPE = 'jira.CreateIssue';\n const DEFAULT_TASK_OWNER = 'Itchy';\n\n const processTasks = (task: Task, container: Container, index: number): void => {\n if (isUndefined(task.type)) task.type = TASK_TYPE;\n task.id = task.id || `${container.id}/Task${index}`;\n if (isUndefined(task.owner) && task.type !== JIRA_TYPE) task.owner = DEFAULT_TASK_OWNER;\n if (task.owner === null) delete task.owner;\n\n each(task.conditions, function (condition, idx) {\n condition.type = CONDITION_TYPE;\n condition.id = `${task.id}/GateCondition${idx}`;\n });\n each(task.dependencies, function (dependency, idx) {\n dependency.type = DEPENDENCY_TYPE;\n dependency.id = `${task.id}/Dependency${idx}`;\n });\n each(task.links, function (link, idx) {\n link.type = LINK_TYPE;\n link.id = `${task.id}/Link${idx}`;\n });\n each(task.comments, function (comment, idx) {\n comment.type = COMMENT_TYPE;\n comment.id = `${task.id}/Comment${idx}`;\n });\n each(task.tasks, function (subTask, idx) {\n processTasks(subTask, task, idx);\n });\n each(task.templateVariables, function (variable, idx) {\n if (variable.value !== undefined) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n defaults(variable, getVariableEntity(variable.value, variable.key, task.id, idx));\n }\n });\n each(task.attachments, function (attachment, idx) {\n attachment.type = ATTACHMENT_TYPE;\n attachment.id = `${task.id}/Attachment${idx}`;\n });\n if (task.pythonScript) {\n const pythonScript = task.pythonScript;\n pythonScript.id = `${task.id}/PythonScript`;\n pythonScript.customScriptTask = task.id;\n }\n };\n\n const processPhases = (phase: Phase, release: Release, index: number): void => {\n phase.type = PHASE_TYPE;\n phase.id = `${release.id}/Phase${index}`;\n\n forEach(phase.tasks, (task, idx): void => {\n processTasks(task, phase, idx);\n });\n };\n\n const getVariableEntity = (\n value: string | Array<string> | boolean,\n key: string,\n containerId: string,\n index: number,\n password?: boolean,\n // eslint-disable-next-line max-params\n ): Variable => {\n const keyNoSyntax = key.replace('${', '').replace('}', '');\n return {\n id: `${containerId}/Variable${index}`,\n key: keyNoSyntax,\n requiresValue: true,\n showOnReleaseStart: true,\n type: password ? 'xlrelease.PasswordStringVariable' : 'xlrelease.StringVariable',\n value: value,\n };\n };\n\n const getValueProviderConfigurationEntity = function (containerId: string): VariableValueProvider {\n return {\n id: `${containerId}/valueProvider`,\n variable: containerId,\n };\n };\n\n const getDashboardExtension = (dashboard: Dashboard, releaseId: string): Dashboard => {\n const dashboardExtension: Dashboard = {\n id: `${releaseId}/summary`,\n type: DASHBOARD_TYPE,\n tiles: [],\n };\n if (dashboard.tiles) {\n forEach(dashboard.tiles, function (tile, index) {\n dashboardExtension.tiles.push(getTileEntity(tile, `${releaseId}/summary`, index));\n });\n }\n return dashboardExtension;\n };\n\n function getTileEntity(tile: Tile, containerId: string, index: number): Tile {\n tile.id = tile.id || `${containerId}/Tile${index}`;\n return tile;\n }\n\n return function (release: Release) {\n release.type = RELEASE_TYPE;\n if (release.id.indexOf('Applications/') === -1) {\n release.id = `Applications/${release.id}`;\n }\n if (release.startDate) {\n release.queryableStartDate = release.startDate;\n } else if (release.scheduledStartDate) {\n release.queryableStartDate = release.scheduledStartDate;\n }\n if (release.endDate) {\n release.queryableEndDate = release.endDate;\n } else if (release.dueDate) {\n release.queryableEndDate = release.dueDate;\n }\n if (isUndefined(release.owner)) release.owner = 'Itchy'; // default release manager\n\n forEach(release.phases, function (phase, index) {\n processPhases(phase, release, index);\n });\n forEach(release.teams, function (team, index) {\n team.type = TEAM_TYPE;\n team.id = `${release.id}/Team${index}`;\n });\n forEach(release.attachments, function (attachment, index) {\n attachment.type = ATTACHMENT_TYPE;\n attachment.id = `${release.id}/Attachment${index}`;\n });\n forEach(release.variables, function (variable: Variable, index) {\n if (variable.value !== undefined) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n defaults(variable, getVariableEntity(variable.value, variable.key, release.id, index));\n }\n if (variable.valueProvider) {\n defaults(variable.valueProvider, getValueProviderConfigurationEntity(variable.id));\n }\n });\n forEach(toPairs(release.variableValues), function (keyValue, index) {\n if (!release.variables) release.variables = [];\n release.variables.push(getVariableEntity(keyValue[1], keyValue[0], release.id, 1000 + index));\n release.variableValues = undefined;\n });\n forEach(toPairs(release.passwordVariableValues), function (keyValue, index) {\n if (!release.variables) release.variables = [];\n release.variables.push(getVariableEntity(keyValue[1], keyValue[0], release.id, 1500 + index, true));\n release.passwordVariableValues = undefined;\n });\n\n if (release.summary) {\n release.extensions = [getDashboardExtension(release.summary, release.id)];\n release.summary = undefined;\n }\n };\n})();\n","import { test as base, expect, Page, APIResponse } from '@playwright/test';\nimport { execFile } from 'child_process';\nimport { APIRequestContext } from 'playwright-core';\nimport isNil from 'lodash/isNil';\nimport { Navigation } from '../pages';\nimport { LoginPage } from '../pages/login-page';\nimport { initReleaseDefaults } from './helper';\nimport * as process from 'process';\nimport {\n Delivery,\n Dashboard,\n Facet,\n FixtureActivityLog,\n FixtureCi,\n FixtureConfiguration,\n FixtureFeature,\n FixtureGlobalRole,\n FixturePermissions,\n FixtureRelease,\n FixtureRoles,\n FixtureTrigger,\n Folder,\n Release,\n RiskProfile,\n Variable,\n ReleaseGroup,\n FixtureTeam,\n EnvironmentFixture,\n Reservation,\n ApplicationFixture,\n} from '../types';\n\nconst JIRA_ISSUE_API_URL = 'https://digitalai.atlassian.net/rest/api/2/issue';\n\nconst adminHeaders = {\n Authorization: 'Basic YWRtaW46YWRtaW4=',\n Cookie: 'XSRF-TOKEN=1;',\n 'X-XSRF-TOKEN': '1',\n};\n\ntype ReleaseFixtures = {\n fixtures: Fixtures;\n loginPage: LoginPage;\n navigation: Navigation;\n};\n\nexport const test = base.extend<ReleaseFixtures>({\n fixtures: async ({ request, page }, use) => {\n const fixtures = new Fixtures(request, page);\n await use(fixtures);\n return fixtures;\n },\n loginPage: async ({ page }, use) => {\n const loginPage = new LoginPage(page);\n await use(loginPage);\n return loginPage;\n },\n navigation: async ({ page }, use) => {\n const navigationPage = new Navigation(page);\n await use(navigationPage);\n return navigationPage;\n },\n});\n\nclass Fixtures {\n private readonly request: APIRequestContext;\n private readonly page: Page;\n\n private applicationIds: Array<string> = [];\n private archivedReleaseIds: Array<string> = [];\n private ciIds: Array<string> = [];\n private environmentIds: Array<string> = [];\n private environmentStageIds: Array<string> = [];\n private releaseIds: Array<string> = [];\n private riskProfiles: Array<string> = [];\n private reservationIds: Array<string> = [];\n private triggerIds: Array<string> = [];\n private configurationIds: Array<string> = [];\n private globalVariableIds: Array<string> = [];\n private folderIds: Array<string> = [];\n private usernames: Array<string> = [];\n private userProfiles: Array<string> = [];\n private folderVariableIds: Array<string> = [];\n\n constructor(request: APIRequestContext, page: Page) {\n this.request = request;\n this.page = page;\n }\n\n release(release: FixtureRelease): Promise<APIResponse> {\n this.initDefaults(release);\n this.releaseIds.push(release.id);\n return this.deleteRelease(release.id)\n .then(() => this.deleteArchivedRelease(release.id))\n .then(() => this.doPost('fixtures/release', release));\n }\n\n archivedRelease(release: FixtureRelease): Promise<APIResponse> {\n this.initDefaults(release);\n this.archivedReleaseIds.push(release.id);\n return this.doPost('fixtures/archived', release);\n }\n\n configuration(ci: FixtureConfiguration): Promise<APIResponse> {\n this.configurationIds.push(ci.id);\n return this.doPost('fixtures/shared', [ci]);\n }\n\n ci(ci: FixtureCi): Promise<APIResponse> {\n this.configurationIds.push(ci.id);\n return this.doPost('fixtures', [ci]);\n }\n\n async deleteCI(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/configuration/${id}`);\n }\n\n getParentId(id: string): string {\n return id.substring(0, id.lastIndexOf('/'));\n }\n\n addSystemTeams(teams: Array<FixtureTeam>): Array<FixtureTeam> {\n const systemTeams = ['Folder Owner', 'Release Admin', 'Template Owner'];\n const teamsToUpdate = teams.map((team) => team.teamName);\n systemTeams.forEach((teamName) => {\n if (teamsToUpdate.indexOf(teamName) === -1) {\n teams.push({\n type: 'xlrelease.Team',\n teamName,\n members: [],\n permissions: [],\n });\n }\n });\n return teams;\n }\n\n async folder(folder: Folder): Promise<APIResponse> {\n const parentId = this.getParentId(folder.id);\n folder.type = 'xlrelease.Folder';\n\n let teams = folder.teams;\n delete folder.teams;\n\n const children = folder.children || [];\n delete folder.children;\n\n const folderVariables = (folder.variables || []).map((variable) => {\n variable.folderId = folder.id;\n return variable;\n });\n delete folder.variables;\n\n const response = await this.doPost(`api/v1/folders/${parentId}`, folder);\n\n // Add the folder ID to the list\n this.folderIds.push(folder.id);\n\n // If teams are provided, send a request to add teams to the folder\n if (teams) {\n teams = this.addSystemTeams(teams);\n return await this.doPost(`api/v1/folders/${folder.id}/teams`, teams);\n }\n\n if (children && children.length > 0) {\n await this.folderVariable(folderVariables);\n return await this.folder(children[0]);\n }\n\n if (folderVariables && folderVariables.length > 0) {\n return await this.folderVariable(folderVariables);\n }\n\n return response;\n }\n\n createFolder(folderJson: Folder): Promise<APIResponse> {\n folderJson.type = 'xlrelease.Folder';\n if (folderJson.id) {\n this.folderIds.push(folderJson.id);\n }\n return this.doPost(`fixtures/folders`, [folderJson]);\n }\n\n async folderVariable(variable: any[]): Promise<APIResponse> {\n // Flatten and process the variables\n const variables = ([] as any[])\n .concat(variable)\n .flat()\n // eslint-disable-next-line @typescript-eslint/no-shadow\n .map((variable: any) => {\n variable.id = null;\n variable.type = variable.type || 'xlrelease.StringVariable';\n variable.requiresValue = false;\n variable.showOnReleaseStart = false;\n return variable;\n });\n return await this.doPost('fixtures/folders/variables', variables);\n }\n\n trigger(trigger: FixtureTrigger): Promise<APIResponse> {\n this.triggerIds.push(trigger.id);\n return this.doPost('fixtures/trigger', trigger);\n }\n\n roles(rolePrincipals: FixtureRoles): Promise<APIResponse> {\n return this.doPost('fixtures/roles/principals', rolePrincipals);\n }\n\n permissions(rolePermissions: FixturePermissions): Promise<APIResponse> {\n return this.doPost('fixtures/roles/permissions/global', rolePermissions);\n }\n\n globalRoles(rolePrincipals: FixtureGlobalRole): Promise<APIResponse> {\n return this.doPost(`api/v1/roles/${rolePrincipals.name}`, rolePrincipals);\n }\n\n dashboard(dashboard: Dashboard): Promise<APIResponse> {\n return this.doPost('fixtures/dashboard', dashboard);\n }\n\n deleteGlobalRole(roleName: string): Promise<APIResponse> {\n return this.doDelete(`api/v1/roles/${roleName}`);\n }\n\n updateUserProfile(username: string, profile: any): Promise<APIResponse> {\n profile.id = username;\n profile.type = 'xlrelease.UserProfile';\n profile.canonicalId = username.toLowerCase();\n if (this.userProfiles.indexOf(profile.canonicalId) === -1) {\n this.userProfiles.push(profile.canonicalId);\n }\n return this.doPut('fixtures/userProfile', profile);\n }\n\n deleteRole(roleName: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/role/${roleName}`);\n }\n\n deleteArchivedRelease(id: string): Promise<APIResponse> {\n const releaseId = id.includes('Applications/') ? id : `Applications/${id}`;\n return this.doDelete('fixtures/cis', [\n {\n id: releaseId,\n type: 'xlrelease.Release',\n },\n ]);\n }\n\n deleteRelease(id: string): Promise<APIResponse> {\n const releaseId = id.includes('Applications/') ? id : `Applications/${id}`;\n return this.doDelete(`fixtures/${releaseId}`);\n }\n\n async deleteWelcomeRelease(username: string): Promise<void> {\n await this.deleteReleaseWithTitle(`Welcome ${username}`);\n }\n\n async deleteReleaseWithTitle(title: string): Promise<void> {\n const response = await this.doPost(`api/v1/releases/search`, { title });\n const releasesFromUser: Release[] = await response.json();\n for (const releasesFromUserElement of releasesFromUser) {\n await this.deleteRelease(releasesFromUserElement.id);\n }\n }\n\n deleteUser(username: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/user/${username}`);\n }\n\n deleteUserProfile(userProfile: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/userProfile/${userProfile}`);\n }\n\n deleteReleaseGroup(releaseGroup: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/release-groups/${releaseGroup}`);\n }\n\n deleteTrigger(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/trigger/${id}`);\n }\n\n deleteConfiguration(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/shared`, [id]);\n }\n\n deleteFolder(folderId: string): Promise<APIResponse> {\n return this.doDelete(`api/v1/folders/${folderId}`);\n }\n\n deleteGlobalVariables(): Promise<APIResponse> {\n return this.doDelete('fixtures/globalVariables');\n }\n\n deleteGlobalVariable(id: string): Promise<APIResponse> {\n return this.doDelete(`api/v1/config/${id}`);\n }\n\n activityLogs(id: string, logs: Array<FixtureActivityLog>): Promise<APIResponse> {\n return this.doPost(`fixtures/activityLogs/${id}`, logs);\n }\n\n globalVariable(variable: Variable): Promise<APIResponse> {\n variable.id = variable.id || `Configuration/variables/global/Variable_${variable.key}`;\n this.globalVariableIds.push(variable.id);\n variable.requiresValue = false;\n variable.showOnReleaseStart = false;\n return this.doPost('api/v1/config/Configuration/variables/global', variable);\n }\n\n addDefaultSmtpServer(): Promise<APIResponse> {\n const defaultSmtpServer = [\n {\n type: 'xlrelease.SmtpServer',\n id: 'Configuration/mail/SmtpServer',\n host: 'localhost',\n port: '25',\n fromAddress: 'foo@bar.com',\n authentication: {\n id: 'Configuration/mail/SmtpServer/authentication',\n type: 'xlrelease.NoSmtpAuthentication',\n },\n },\n ];\n return this.doPost('fixtures/', defaultSmtpServer);\n }\n\n riskProfile(riskProfile: RiskProfile): Promise<APIResponse> {\n this.riskProfiles.push(riskProfile.id);\n return this.doPost('fixtures/riskProfiles', riskProfile);\n }\n\n deleteRiskProfile(riskProfileId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/riskProfiles/${riskProfileId}`);\n }\n\n // Release delivery pattern\n createDeliveryPattern(delivery: Delivery, shouldResetPattern = true): Promise<APIResponse> {\n return this.doPost(`fixtures/deliveries/patterns/${shouldResetPattern}`, delivery);\n }\n\n // Release deliveries\n createDelivery(delivery: Delivery): Promise<APIResponse> {\n return this.doPost('fixtures/deliveries', delivery);\n }\n\n async facet(facet: Facet): Promise<APIResponse> {\n return this.doPost('fixtures/facets', facet);\n }\n\n async application(application: ApplicationFixture): Promise<APIResponse> {\n const response = await this.doPost('fixtures/application', application);\n const json = await response.json();\n this.applicationIds.push(json.id);\n return json;\n }\n\n async environment(environment: EnvironmentFixture): Promise<APIResponse> {\n const response = await this.doPost('fixtures/environment', environment);\n const json = await response.json();\n this.environmentIds.push(json.id);\n this.environmentStageIds.push(json.stage);\n return json;\n }\n\n async reservation(reservation: Reservation): Promise<APIResponse> {\n const response = await this.doPost('fixtures/reservation', reservation);\n const json = await response.json();\n this.reservationIds.push(json.id);\n return json;\n }\n\n deleteDelivery(delivery: Delivery): Promise<APIResponse> {\n return this.doDelete(`fixtures/deliveries/${delivery}`);\n }\n\n async deleteApplication(applicationId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/application/${applicationId}`);\n }\n\n async deleteEnvironment(environmentId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/environment/${environmentId}`);\n }\n\n async deleteEnvironmentStage(environmentStageId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/environment/${environmentStageId}`);\n }\n\n async clearCalendar(): Promise<APIResponse> {\n return this.doDelete('fixtures/calendar');\n }\n\n async deleteReservation(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/reservation/${id}`);\n }\n\n async cleanAll(): Promise<void> {\n for (const username of this.usernames) {\n await this.deleteUser(username);\n await this.deleteWelcomeRelease(username);\n }\n for (const userProfile of this.userProfiles) {\n await this.deleteUserProfile(userProfile);\n }\n for (const triggerId of this.triggerIds) {\n await this.deleteTrigger(triggerId);\n }\n for (const releaseId of this.releaseIds.reverse()) {\n await this.deleteRelease(releaseId);\n }\n for (const confId of this.configurationIds) {\n await this.deleteConfiguration(confId);\n }\n for (const folderId of this.folderIds.reverse()) {\n await this.deleteFolder(folderId);\n }\n for (const globalVariableId of this.globalVariableIds) {\n await this.deleteGlobalVariable(globalVariableId);\n }\n for (const reservationId of this.reservationIds) {\n await this.deleteReservation(reservationId);\n }\n for (const applicationId of this.applicationIds) {\n await this.deleteApplication(applicationId);\n }\n for (const environmentId of this.environmentIds) {\n await this.deleteEnvironment(environmentId);\n }\n for (const environmentStageId of this.environmentStageIds) {\n await this.deleteEnvironmentStage(environmentStageId);\n }\n for (const ci of this.ciIds) {\n await this.deleteCI(ci);\n }\n\n this.applicationIds = [];\n this.configurationIds = [];\n this.environmentIds = [];\n this.environmentStageIds = [];\n this.globalVariableIds = [];\n this.folderIds = [];\n this.releaseIds = [];\n this.reservationIds = [];\n this.triggerIds = [];\n this.usernames = [];\n this.userProfiles = [];\n this.ciIds = [];\n }\n\n async addJiraTask(): Promise<string> {\n const data = {\n fields: {\n project: { key: 'RIT' },\n summary: 'Test Task',\n description: 'Test task description',\n issuetype: { name: 'Task' },\n },\n };\n const headers = {\n Authorization: `Basic ${btoa('xlr-jira-testuser@xebialabs.com:zgsXK6c3oLVkJxrWVJQy9DB7')}`,\n Origin: 'https://digitalai.atlassian.net/',\n };\n const response = await this.request.post(JIRA_ISSUE_API_URL, { data, headers });\n const json = await response.json();\n return json.key;\n }\n\n async addBlackout(name: string, from: Date, to: Date): Promise<APIResponse> {\n return this.doPost('calendar/blackouts', {\n label: name,\n startDate: from,\n endDate: to,\n type: 'xlrelease.Blackout',\n id: null,\n });\n }\n\n async addUser(username: string, password: string): Promise<void> {\n this.usernames.push(username);\n await this.doPost('fixtures/user', { username, password });\n }\n\n async addUserProfile(username: string, profile?: any): Promise<void> {\n if (!profile) {\n profile = {};\n }\n profile.id = username;\n profile.type = 'xlrelease.UserProfile';\n profile.canonicalId = username.toLowerCase();\n this.userProfiles.push(profile.canonicalId);\n await this.doPost('fixtures/userProfile', profile);\n }\n\n async resetAdminProfile(): Promise<APIResponse> {\n return this.resetUserProfile('admin', 'Release Administrator');\n }\n\n async resetUserProfile(username: string, fullName?: string): Promise<APIResponse> {\n this.usernames.push(username);\n return this.updateProfile({\n username,\n external: false,\n profileId: username,\n email: '',\n fullName: fullName ? fullName : username,\n loginAllowed: true,\n // dateFormat: \"dd/MM/yy\",\n dateFormat: 'M/d/yy',\n // timeFormat: \"HH:mm\",\n timeFormat: 'h:mm a',\n firstDayOfWeek: 0,\n });\n }\n\n async updateProfile(profile: {\n dateFormat: string;\n email: string;\n external: boolean;\n firstDayOfWeek: number;\n fullName: string;\n loginAllowed: boolean;\n profileId: string;\n timeFormat: string;\n username: string;\n }): Promise<APIResponse> {\n return this.doPut('profile', profile);\n }\n\n async expectJiraTaskStatus(taskId: string, expectedStatus: string): Promise<void> {\n const headers = {\n Authorization: `Basic ${btoa('xlr-jira-testuser@xebialabs.com:zgsXK6c3oLVkJxrWVJQy9DB7')}`,\n Origin: 'https://digitalai.atlassian.net/',\n };\n const response = await this.request.get(`${JIRA_ISSUE_API_URL}/${taskId}`, { headers });\n const json = await response.json();\n const status = json.fields.status.name;\n expect(status).toBe(expectedStatus);\n }\n\n async expectJiraTaskSummary(taskId: string, expectedSummary: string): Promise<void> {\n const headers = {\n Authorization: `Basic ${btoa('xlr-jira-testuser@xebialabs.com:zgsXK6c3oLVkJxrWVJQy9DB7')}`,\n Origin: 'https://digitalai.atlassian.net/',\n };\n const response = await this.request.get(`${JIRA_ISSUE_API_URL}/${taskId}`, { headers });\n const json = await response.json();\n const summary = json.fields.summary;\n expect(summary).toBe(expectedSummary);\n }\n\n async expectContainingAttachments(releaseId: string, tempFile: string): Promise<void> {\n if (releaseId.indexOf('Applications/') === -1) {\n releaseId = 'Applications/' + releaseId;\n }\n await expect(async () => {\n const resp = await this.doPost(`fixtures/expectContainingAttachments/${releaseId}`, {\n name: tempFile,\n expectedContent: tempFile,\n });\n expect(resp).toBe(true);\n }).toPass();\n }\n\n async waitForReleaseStarted(releaseTitle: string): Promise<void> {\n await expect(async () => {\n const resp = await this.doPost('releases/search', {\n inProgress: true,\n paused: true,\n failing: true,\n failed: true,\n title: releaseTitle,\n });\n const page = await resp.json();\n await expect(page.cis.length).toBeGreaterThan(0);\n }).toPass();\n }\n\n async waitForFirstPoll(triggerId: string): Promise<void> {\n await expect(async () => {\n const resp = await this.doGet(`api/v1/triggers/${triggerId}`);\n const trigger = await resp.json();\n await expect(isNil(trigger.triggerState)).toBe(false);\n }).toPass();\n }\n\n exec(path: string): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n execFile(path, (error) => {\n if (error === null) {\n return resolve();\n } else {\n return reject();\n }\n });\n });\n }\n\n getFakeApiUrl(): string {\n return this.getEnvVariable('ENV_FAKE_API') || 'http://localhost:5517';\n }\n\n getEnvVariable(name: string): string | undefined {\n return process.env[name];\n }\n\n async archiveRelease(releaseId: string): Promise<APIResponse> {\n return this.doGet(`fixtures/archive/${releaseId}`);\n }\n\n async preArchiveRelease(releaseId: string): Promise<APIResponse> {\n return this.doGet(`fixtures/preArchive/${releaseId}`);\n }\n\n async setFeatures(features: Array<FixtureFeature>): Promise<APIResponse> {\n return this.doPut('settings/features', features);\n }\n\n async enableTaskDrawer(enabled: boolean): Promise<APIResponse> {\n return this.setFeatures([\n { id: 'Configuration/features/xlrelease.TaskDrawer', type: 'xlrelease.TaskDrawer', enabled: enabled },\n ]);\n }\n\n async createReleaseGroup(releaseGroup: ReleaseGroup): Promise<APIResponse> {\n return this.doPost('fixtures/release-groups', releaseGroup);\n }\n\n private doPost(url: string, body: unknown): Promise<APIResponse> {\n return this.request.post(url, { data: body, headers: adminHeaders });\n }\n\n private doPut(url: string, body: unknown): Promise<APIResponse> {\n return this.request.put(url, { data: body, headers: adminHeaders });\n }\n\n private doGet(url: string): Promise<APIResponse> {\n return this.request.get(url, { headers: adminHeaders });\n }\n\n private doDelete(url: string, body?: unknown): Promise<APIResponse> {\n return this.request.delete(url, { data: body, headers: adminHeaders });\n }\n\n private initDefaults(ci: FixtureRelease): void {\n initReleaseDefaults(ci as Release);\n }\n}\n","export { test } from './fixtures';\n"],"names":[],"version":3,"file":"types.d.ts.map"}
|
|
1
|
+
{"mappings":"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","sources":["apps/release/pages/WithPage.ts","apps/release/pages/releases/releaseCreatePage.ts","apps/release/pages/ReleaseHeaderPage.ts","apps/release/pages/ReleasesListPage.ts","apps/release/pages/TriggersPage.ts","apps/release/pages/helper/index.ts","apps/release/pages/common/dateUtil.ts","apps/release/pages/variablePage.ts","apps/release/pages/task-drawer/taskActivity.ts","apps/release/pages/task-drawer/taskAttachments.ts","apps/release/pages/task-drawer/taskAttribute.ts","apps/release/pages/task-drawer/taskCondition.ts","apps/release/pages/task-drawer/taskConfig.ts","apps/release/pages/task-drawer/taskOverview.ts","apps/release/pages/task-drawer/taskScheduling.ts","apps/release/pages/task-drawer/taskHistory.ts","apps/release/pages/task-drawer/taskDrawer.ts","apps/release/pages/releases/releaseGanttPage.ts","apps/release/pages/releases/releasePropertiesPage.ts","apps/release/pages/releases/releaseTeamsAndPermissionsPage.ts","apps/release/pages/releases/releaseTableViewPage.ts","apps/release/pages/common/util.ts","apps/release/pages/releases/ReleasePage.ts","apps/release/pages/ApplicationsPage.ts","apps/release/pages/common/dataRandomGenerator.ts","apps/release/pages/folder/folderDeliveryPage.ts","apps/release/pages/folder/folderGroupPage.ts","apps/release/types/index.ts","apps/release/pages/folder/folderPatternPage.ts","apps/release/pages/folder/folderNotificationPage.ts","apps/release/pages/FolderPage.ts","apps/release/pages/globalVariablePage.ts","apps/release/pages/homePage.ts","apps/release/pages/headerPage.ts","apps/release/pages/managePluginsPage.ts","apps/release/pages/PersonalAccessTokenPage.ts","apps/release/pages/personalSettingsPage.ts","apps/release/pages/users/userModal.ts","apps/release/pages/users/usersPage.ts","apps/release/pages/workflowCatalogPage.ts","apps/release/pages/settingsMenu.ts","apps/release/pages/taskDetails.ts","apps/release/pages/ReleaseCalendarPage.ts","apps/release/pages/ReleaseGroupPage.ts","apps/release/pages/ReleaseGroupTimelinePage.ts","apps/release/pages/releases/ReleaseVariablesPage.ts","apps/release/pages/tasks/taskListPage.ts","apps/release/pages/templates/templatePropertiesPage.ts","apps/release/pages/templates/templateCreatePage.ts","apps/release/pages/templates/templateTriggerPage.ts","apps/release/pages/templates/templateVaraiablePage.ts","apps/release/pages/templates/templatePage.ts","apps/release/pages/templateListPage.ts","apps/release/pages/users/rolesModal.ts","apps/release/pages/users/rolesPage.ts","apps/release/pages/systemSettings/risksProfilePage.ts","apps/release/pages/systemSettings/advancedSettingsPage.ts","apps/release/pages/systemSettings/experimentalSettingsPage.ts","apps/release/pages/systemSettings/taskSettingsPage.ts","apps/release/pages/systemSettings/reportsSettingsPage.ts","apps/release/pages/systemSettings/releaseAndTriggersPage.ts","apps/release/pages/notificationPage.ts","apps/release/pages/systemSettings/notificationSettingsPage.ts","apps/release/pages/systemSettingsPage.ts","apps/release/pages/connectionsPage.ts","apps/release/pages/tasks/taskAccessPage.ts","apps/release/pages/index.ts","apps/release/pages/login-page.ts","apps/release/fixtures/helper.ts","apps/release/fixtures/index.ts","apps/release/index.ts"],"sourcesContent":["import { Page } from '@playwright/test';\n\nexport class WithPage {\n protected readonly page: Page;\n\n constructor(page: Page) {\n this.page = page;\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ReleaseCreatePage extends WithPage {\n releaseForm: Locator;\n\n constructor(page: Page) {\n super(page);\n this.releaseForm = this.page.locator('#release-properties .form-group');\n }\n\n async setName(releaseName: string): Promise<void> {\n await this.page.locator('#release-form-title').click();\n await this.page.locator('#release-form-title').fill(releaseName);\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.release-description').hover();\n await this.page.locator('.display').filter({ hasText: 'Set description' }).locator('.edit-icon').click();\n await this.page.locator('textarea').click();\n await this.page.locator('textarea').clear();\n await this.page.locator('textarea').fill(description);\n await this.page.getByText('Save', { exact: true }).click();\n }\n\n async setOwner(ownerName: string): Promise<void> {\n await this.page.locator('.release-owner').click();\n await this.page.locator('input[name=\"owner\"]').fill(ownerName);\n }\n\n async create(): Promise<void> {\n await this.page.getByRole('button', { name: 'Create' }).waitFor({ state: 'visible' });\n await this.page.getByRole('button', { name: 'Create' }).click();\n }\n\n async expectVariablesCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.variable-editor .form-group')).toHaveCount(count);\n }\n\n async expectContainingVariable(variableName: string, value: string): Promise<void> {\n await expect(this.page.locator(`#form-${variableName} .text span`)).toContainText(value);\n }\n\n async selectTemplate(templateName: string): Promise<void> {\n await this.page.getByPlaceholder('No template').click();\n await this.page.getByPlaceholder('No template').clear();\n await this.page.getByPlaceholder('No template').fill(templateName);\n await this.page.getByText(templateName).click();\n }\n\n async removeTemplate(): Promise<void> {\n await this.page.locator('.template-select .close-icon').click();\n }\n\n async setValueForVariables(variableName: string, value: string): Promise<void> {\n await this.page.locator(`#form-${variableName} .display`).click();\n await this.page.locator(`input[name=\"${variableName}\"]`).fill(value);\n await this.page.locator(`input[name=\"${variableName}\"]`).blur();\n }\n\n async setVariable(variable: string, value: string): Promise<void> {\n await this.releaseForm.filter({ hasText: variable }).locator('div[inline-text-editor]').click();\n await this.releaseForm.filter({ hasText: variable }).locator('div[inline-text-editor] input').fill(value);\n await this.releaseForm.filter({ hasText: variable }).locator('div[inline-text-editor] input').blur();\n }\n\n async resetVariableValues(): Promise<void> {\n await this.page.locator('button', { hasText: 'Reset to defaults' }).click();\n await this.page.locator('button', { hasText: 'Reset variables' }).click();\n await expect(this.page.locator('button', { hasText: 'Reset to defaults' })).toBeDisabled();\n }\n\n async clickOnPrefillVariables(): Promise<void> {\n await this.page.getByText('Pre-fill variable values from previous releases').click();\n }\n\n async selectPreviousRelease(releaseName: string): Promise<void> {\n await this.page.locator('button', { hasText: 'Select release' }).click();\n await this.page.locator('a', { hasText: releaseName }).click();\n }\n\n async expectPrefillWarning(message: string): Promise<void> {\n await expect(this.page.getByText(message)).toBeVisible();\n }\n}\n","import { expect, Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleasesHeaderPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n getHeaderSelector(): string {\n return '.release-list-header';\n }\n\n getBaseDrawerSelector(): string {\n return `${this.getHeaderSelector()} .filter-drawer`;\n }\n\n getFilterDrawerSelector(): string {\n return `${this.getBaseDrawerSelector()} div[role=\"dialog\"]`;\n }\n\n getStatusInputSelector(): string {\n return `${this.getBaseDrawerSelector()} input#release-status-filter-autocomplete`;\n }\n\n getBasePopperSelector(): string {\n return '.dot-popper[role=\"presentation\"]';\n }\n\n getSelectAllStatusesButtonSelector(): string {\n return `${this.getBasePopperSelector()} button[data-testid=\"dot-action-item-btn\"]`;\n }\n\n getTitleInputSelector(): string {\n return `${this.getHeaderSelector()} input#title-filter`;\n }\n\n getRiskLevelInputSelector(): string {\n return `${this.getBaseDrawerSelector()} input#risk`;\n }\n\n async setReleaseStatusFilter(statuses: string[]): Promise<this> {\n for (const status of statuses) {\n await this.page.locator(this.getStatusInputSelector()).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li`).filter({ hasText: status }).click();\n }\n return this;\n }\n\n async setReleaseTagsFilter(tags: string[]): Promise<this> {\n for (const tag of tags) {\n await this.page.locator(`${this.getBaseDrawerSelector()} input#release-tags`).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li`).filter({ hasText: tag.toLowerCase() }).click();\n }\n return this;\n }\n\n async setTaskTagsFilter(tags: string[]): Promise<this> {\n for (const tag of tags) {\n await this.page.locator(`${this.getBaseDrawerSelector()} input#task-tags`).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li`).filter({ hasText: tag.toLowerCase() }).click();\n }\n return this;\n }\n\n async setRiskLevelFilter(riskLevel: string): Promise<this> {\n await this.page.locator(this.getRiskLevelInputSelector()).click();\n await this.page.locator(`${this.getBasePopperSelector()} ul li:has-text(\"${riskLevel}\")`).click({ force: true });\n return this;\n }\n\n async filterReleaseByTitle(releaseTitle: string): Promise<void> {\n await this.page.locator(this.getTitleInputSelector()).fill(releaseTitle);\n }\n\n async clearTitleFilter(): Promise<this> {\n await this.page.locator(this.getTitleInputSelector()).fill('');\n return this;\n }\n\n async openFilterDrawer(): Promise<this> {\n await this.page.locator(`${this.getHeaderSelector()} button`, { hasText: 'Filters' }).click();\n await expect(this.page.locator(this.getFilterDrawerSelector())).toBeVisible();\n return this;\n }\n\n async closeFilterDrawer(): Promise<this> {\n await this.page.locator(`${this.getBaseDrawerSelector()} .dot-icon-btn[data-testid=\"close-btn\"]`).click();\n await expect(this.page.locator(this.getFilterDrawerSelector())).not.toBeVisible();\n return this;\n }\n\n async clearAllFilters(): Promise<this> {\n await this.page\n .locator(`${this.getHeaderSelector()} .release-list-filter-row button[data-testid=\"clear-all-btn\"]`)\n .click();\n return this;\n }\n\n async clearAllStatusFilters(): Promise<this> {\n await this.page.locator(this.getStatusInputSelector()).click();\n await this.page\n .locator(`${this.getBaseDrawerSelector()} div.filter-release-status-autocomplete button[title=\"Clear\"]`)\n .click();\n return this;\n }\n\n async selectAllStatusFilters(): Promise<this> {\n await this.page.locator(this.getStatusInputSelector()).click();\n await this.page.locator(this.getSelectAllStatusesButtonSelector()).click();\n return this;\n }\n\n async gotoListView(): Promise<void> {\n await this.clickOnReleasesPageTab('Releases');\n await expect(this.page.locator('.release-list')).toBeVisible();\n }\n\n async gotoCalendarView(): Promise<void> {\n await this.clickOnReleasesPageTab('Calendar');\n await expect(this.page.locator('.tl-viewport')).toBeVisible();\n }\n\n async clickOnReleasesPageTab(tabName: 'Releases' | 'Archive' | 'Calendar'): Promise<this> {\n await this.page.locator('releases-tabs .dot-tab-label').filter({ hasText: tabName }).click();\n return this;\n }\n\n async toggleFilterFlaggedOnly(): Promise<this> {\n await this.page\n .locator(`${this.getBaseDrawerSelector()} .flagged-releases-switch input[aria-label=\"Flagged releases\"]`)\n .click();\n return this;\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { ReleasePage } from './releases/ReleasePage';\nimport { ReleaseCreatePage } from './releases/releaseCreatePage';\nimport { ReleasesHeaderPage } from './ReleaseHeaderPage';\n\nexport class ReleasesListPage extends ReleasesHeaderPage {\n releaseCreatePage: ReleaseCreatePage;\n buttonNewRelease: Locator;\n constructor(page: Page) {\n super(page);\n this.releaseCreatePage = new ReleaseCreatePage(page);\n this.buttonNewRelease = page.locator('.action-toolbar-actions button').filter({ hasText: 'New release' });\n }\n\n async expectNumberOfReleases(releaseTitle: string, amount: number): Promise<void> {\n await this.filterReleaseByTitle(releaseTitle);\n if (amount === 1) {\n await expect(this.page.locator('.release').getByText(releaseTitle)).toBeVisible({ timeout: 5000 });\n } else {\n expect(await this.page.locator('.release').getByText(releaseTitle).count()).toBe(amount);\n }\n }\n\n async expectReleaseStarted(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Planned' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseStatusInProgress(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'In progress' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseAborted(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Aborted' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseFailed(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Failed' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseFailing(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Failing' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectReleaseCompleted(releaseTitle: string): Promise<void> {\n const releaseStatus = this.page\n .locator('.release')\n .filter({ hasText: releaseTitle })\n .locator('.release-status')\n .filter({ hasText: 'Completed' });\n await expect(releaseStatus).toBeVisible();\n }\n\n async expectRedirectToReleasesList(): Promise<void> {\n await expect(this.page.getByLabel('breadcrumb').getByText('Releases')).toBeVisible();\n await expect(this.page.locator('.release-list')).toBeVisible();\n }\n\n async openReleaseByName(releaseTitle: string): Promise<ReleasePage> {\n await this.page.locator('.release-line .row-wrapper .release-title-wrapper a', { hasText: releaseTitle }).click();\n return new ReleasePage(this.page);\n }\n\n async createNewRelease(releaseName: string, description: string): Promise<void> {\n await this.releaseCreatePage.setName(releaseName);\n await this.releaseCreatePage.setDescription(description);\n await this.releaseCreatePage.create();\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n\n async createNewReleaseWithOwner(releaseName: string, description: string, ownerName: string): Promise<void> {\n await this.releaseCreatePage.setName(releaseName);\n await this.releaseCreatePage.setDescription(description);\n await this.releaseCreatePage.setOwner(ownerName);\n await this.releaseCreatePage.create();\n }\n\n async openReleasesList(): Promise<this> {\n await this.page.goto('./#/releases');\n await expect(this.page.locator('.release-list')).toBeVisible();\n return this;\n }\n\n async clickReleaseOptions(releaseTitle: string): Promise<this> {\n await this.page\n .locator('.release-line')\n .filter({ hasText: releaseTitle })\n .locator('.options-icon')\n .click({ force: true });\n return this;\n }\n\n async clickAddToRelease(): Promise<this> {\n const addToGroupLink = this.page.locator('a:has-text(\"Add to group\")');\n await expect(addToGroupLink).toBeVisible();\n await addToGroupLink.click({ force: true });\n return this;\n }\n\n async checkAddDisabled(): Promise<this> {\n await expect(this.page.locator('.modal-footer .primary')).toBeDisabled();\n return this;\n }\n\n async selectReleaseGroup(rgTitle: string): Promise<this> {\n await this.page.locator('.ui-autocomplete-input').click({ force: true });\n await this.page.locator('.ui-autocomplete-input').fill(rgTitle);\n await this.page.locator('.ui-autocomplete-input').press('Backspace');\n await this.page.locator('li').filter({ hasText: rgTitle }).click();\n return this;\n }\n\n async clickAddToReleaseGroup(): Promise<this> {\n await expect(this.page.locator('.modal-footer .primary')).toBeVisible();\n await this.page.locator('.modal-footer .primary').click();\n return this;\n }\n}\n","import { expect } from '@playwright/test';\nimport { ReleasesListPage } from './ReleasesListPage';\nimport { WithPage } from './WithPage';\n\nexport class TriggersPage extends WithPage {\n async openRelatedReleasesOf(title: string): Promise<ReleasesListPage> {\n await this.openContextMenu(title);\n await this.page.locator('.popover-content xlr-context-menu a', { hasText: 'View releases' }).click();\n return new ReleasesListPage(this.page);\n }\n\n private async openContextMenu(title: string): Promise<void> {\n await expect(async () => {\n await this.page.locator('.trigger-row-content', { hasText: title }).locator('.context-menu-button').click();\n await expect(this.page.locator('.popover-content')).toBeVisible();\n }).toPass();\n }\n}\n","import { Locator } from '@playwright/test';\n\ntype WaitForRes = [locatorIndex: number, locator: Locator];\nexport async function waitForOneOf(locators: Locator[]): Promise<WaitForRes> {\n const res = await Promise.all([\n ...locators.map(async (locator, index): Promise<WaitForRes> => {\n let timedOut = false;\n await locator.waitFor({ state: 'visible', timeout: 2000 }).catch(() => (timedOut = true));\n return [timedOut ? -1 : index, locator];\n }),\n ]);\n const resolvedLocator = res.find((r) => r[0] !== -1);\n if (!resolvedLocator) {\n console.warn('waitForOneOf', res);\n throw new Error('no locator visible before timeout');\n }\n return resolvedLocator;\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport moment from 'moment';\n\nexport class DateUtil extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async openDatePicker(selector: string): Promise<void> {\n await this.page.locator(`${selector} .date`).click();\n }\n\n /**\n * Setting date, month and year from calendar picker\n */\n async setDate(date?: string, monthYear?: string): Promise<void> {\n const prev = this.page.locator('.datepicker-days .prev');\n const next = this.page.locator('.datepicker-days .next');\n const monYear = this.page.locator('.datepicker-days .datepicker-switch');\n\n const currentYear = await monYear.textContent();\n const thisMonth = moment(monthYear, 'MMMM YYYY').isBefore(currentYear);\n while ((await monYear.textContent()) != monthYear) {\n if (thisMonth) {\n await prev.click();\n } else {\n await next.click();\n }\n }\n await this.page\n .getByRole('cell', { name: '' + date + '', exact: true })\n .first()\n .click();\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.page.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async setDuration(days?: string, hours?: string, mins?: string): Promise<void> {\n if (typeof days !== 'undefined') {\n await this.page.locator('.days').fill(days);\n }\n if (typeof hours !== 'undefined') {\n await this.page.locator('.hours').fill(hours);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.minutes').fill(mins);\n }\n await this.page.keyboard.press('Enter');\n }\n\n async expectTimeToBe(selector: Locator, format: string, date: Date | string): Promise<void> {\n if (typeof date === 'string') {\n date = new Date(date);\n }\n const formattedDate = moment(date).format(format);\n await expect(selector).toBeVisible();\n const value = await selector.inputValue();\n expect(value).toBe(formattedDate);\n }\n\n /**\n *\n * @returns Getting current month and year in the format \"MonthName YYYY\"\n */\n async getCurrentMonthYear(): Promise<string> {\n const monthNames = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December',\n ];\n const d = new Date();\n const month = monthNames[d.getMonth()];\n const year = d.getFullYear();\n return `${month} ${year}`;\n }\n\n /**\n *\n * @returns Getting current date in the format \"dd MonthName YYYY\"\n */\n async getCurrentDate(): Promise<string> {\n const d = new Date();\n const date = d.getDate();\n const monthYear = await this.getCurrentMonthYear();\n return `${date} ${monthYear}`;\n }\n\n /**\n *\n * @param days Number of days to add to current date within the current month\n * @returns\n */\n async getFutureDate(days: number): Promise<string> {\n const d = new Date();\n d.setDate(d.getDate() + days);\n const date = d.getDate();\n const monthYear = await this.getCurrentMonthYear();\n return `${date} ${monthYear}`;\n }\n\n async removeDate(selector: Locator): Promise<void> {\n return await selector.locator(`.remove`).click();\n }\n async expectDateNotDeletable(selector: Locator): Promise<void> {\n await expect(selector.locator(`.remove`)).not.toBeVisible();\n }\n\n async expectDateToBe(selector: Locator, date: Date | string): Promise<void> {\n return await this.expectInputContainingDate(selector, date);\n }\n\n async expectDateToBeInferred(selector: Locator): Promise<void> {\n await expect(selector.locator(`input.light-text`).first()).toBeVisible();\n }\n\n async expectNoDate(selector: Locator): Promise<void> {\n expect(selector.locator(`.date-placeholder`)).toBeVisible();\n }\n\n async expectInputContainingDate(inputLocator: Locator, date: Date | string): Promise<void> {\n await expect(inputLocator).toBeVisible();\n\n const attribute = await inputLocator.getAttribute('value');\n\n expect(attribute).toContain(date);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { waitForOneOf } from './helper';\nimport { DateUtil } from './common/dateUtil';\n\ntype ExpectWithLocator = (l: Locator) => void;\n\nexport class VariablePage extends WithPage {\n addListValue: Locator;\n addVariableValue: Locator;\n listAddButton: Locator;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.addListValue = this.page.locator('.variable-selector .xl-components-input-full input');\n this.addVariableValue = this.page.locator('.variable-value .xl-components-input-full input');\n this.dateUtil = new DateUtil(page);\n this.listAddButton = this.page.getByRole('button', { name: 'Add' });\n }\n\n async openVariable(variableKey: string): Promise<VariableModal> {\n await this.page.locator(`.variables-list .variable`).getByText(variableKey).click();\n return new VariableModal(this.page);\n }\n\n async addNewVariable(variableName: string, labelname: string, description?: string): Promise<void> {\n await this.page.locator('button', { hasText: 'New variable' }).click();\n await this.page.fill(`[name=\"fieldKey\"]`, variableName);\n await this.page.locator('.variable-label input').fill(labelname);\n if (description) await this.page.locator('.variable-description input').fill(description);\n }\n\n async addNewVariableInFolder(variableName: string, labelname: string, description?: string): Promise<void> {\n await this.page.locator('button', { hasText: 'New folder variable' }).click();\n await this.page.fill(`[name=\"fieldKey\"]`, variableName);\n await this.page.locator('.variable-label input').fill(labelname);\n if (description) await this.page.locator('.variable-description input').fill(description);\n }\n\n async selectVariableTextType(valueName: string, multiline?: boolean): Promise<void> {\n await this.page.getByRole('combobox').selectOption('StringVariable');\n if (multiline) {\n await this.clickMultiline();\n await this.page.locator('.variable-value textarea').fill(valueName);\n } else await this.page.locator('.variable-value input').fill(valueName);\n }\n\n async selectVariableListboxType(\n possiblevalue: Array<string> | string,\n defaultValue: string,\n required?: true,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n await this.addListValue.fill(value);\n await this.listAddButton.click();\n }\n } else {\n await this.addListValue.fill(possiblevalue);\n await this.listAddButton.click();\n }\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n }\n }\n\n async selectVariablePasswordType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('PasswordStringVariable');\n await this.page.locator('input[type=\"password\"]').type(possiblevalue);\n }\n\n async selectVariableCheckboxType(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('BooleanVariable');\n await this.page.getByRole('checkbox').check();\n }\n\n async selectVariableNumberType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('IntegerVariable');\n await this.page.locator('input[ng-model=\"var.value\"]').fill(possiblevalue);\n }\n\n async selectVariableMultiListType(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MultiSelectListBox');\n await this.addListValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addListValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.getByText('Select all', { exact: true }).click();\n }\n\n async selectVariableByDate(date: string, monthYear: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DateVariable');\n await this.page.getByText('Select date').click();\n await this.setDate(date, monthYear);\n }\n\n async setDate(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async addVariableKeyValueMap(keys1: string, values1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MapStringStringVariable');\n await this.page.getByPlaceholder('key').fill(keys1);\n await this.page.getByPlaceholder('Value').fill(values1);\n await this.listAddButton.click();\n await this.page.locator('.xl-map-string-string-div-buttons .search-icon').click();\n await this.page.getByRole('row', { name: 'Search' }).getByRole('textbox').fill(keys1);\n const detail = await this.page.locator('table.table-condensed span').allInnerTexts();\n expect(detail[0]).toEqual(keys1);\n expect(detail[1]).toEqual(values1);\n }\n\n async addVariableSet(possiblevalue1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('SetStringVariable');\n await this.page.locator('.dip-input input').fill(possiblevalue1);\n await this.listAddButton.click();\n }\n\n async submitTheVariable(): Promise<void> {\n const createButton = this.page.locator('.modal-footer .save');\n await expect(createButton).toBeEnabled();\n await createButton.scrollIntoViewIfNeeded();\n await createButton.click();\n // Expect is needed here to avoid flackiness on clicking create button\n await expect(createButton).not.toBeVisible();\n }\n\n async expectVariableWithNameValueAndType(name: string, value: string, type: string): Promise<void> {\n await this.page.locator('.variables-list .row-table').waitFor({ timeout: 10000 });\n const rowLocator = await this.page.locator('.variable .data-row').allTextContents();\n expect(rowLocator.toString()).toContain(name);\n expect(rowLocator.toString()).toContain(value);\n expect(rowLocator.toString()).toContain(type);\n }\n\n async clickEditVariable(variableName: string): Promise<VariableModal> {\n await this.page.locator('.data-row').filter({ hasText: variableName }).getByText('Edit').first().click();\n return new VariableModal(this.page);\n }\n\n async clickDeleteVariable(variableName: string): Promise<DeleteVariableModel> {\n await this.page\n .locator('.data-row')\n .filter({ hasText: variableName })\n .locator('.action .delete-icon')\n .first()\n .click();\n return new DeleteVariableModel(this.page);\n }\n\n async expectVariablesCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.variable .data-row')).toHaveCount(count);\n }\n\n async expectVariableNotPresent(variableName: string): Promise<void> {\n await expect(this.page.locator('.variable').filter({ hasText: variableName })).not.toBeVisible();\n }\n\n async clearReleaseVariableSearch(): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").clear();\n }\n\n async switchPossibleValuesToVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n }\n\n async selectVariableListboxTypeWithVariable(\n variableName: string,\n defaultValue: string,\n required?: boolean,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n } else {\n await this.page.getByRole('checkbox').uncheck();\n }\n }\n\n async clickMultiline(): Promise<void> {\n await this.page.locator('#multiline').click();\n }\n\n async searchFolderVariable(variableName: string): Promise<void> {\n await this.page.locator('.searchFilter').fill(variableName);\n }\n\n async clearFolderVarSearch(): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n }\n\n async clickFolderVariableButton(): Promise<void> {\n await this.page.getByText('Folder variables').click();\n }\n\n async clickReleaseVariableButton(): Promise<void> {\n await this.page.getByText('Release variables').click();\n }\n}\n\nclass VariableModal extends WithPage {\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n }\n private async expectValue(locators: Locator[], expectFn: ExpectWithLocator[]): Promise<void> {\n const [index, locator] = await waitForOneOf(locators);\n expectFn[index](locator);\n }\n\n async expectValueToBe(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode .text-container'),\n ],\n [\n (l) => expect(l).toHaveValue(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n ],\n );\n }\n\n async expectValueToContain(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode'),\n ],\n [\n (l) => expect(l.inputValue()).toContain(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n ],\n );\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async expectPossibleValues(possiblevalue: Array<string> | string): Promise<void> {\n const listLocator = await this.page.locator('.editor .xl-list-row').allInnerTexts();\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n expect(listLocator).toContain(value);\n }\n } else {\n expect(listLocator).toContain(possiblevalue);\n }\n }\n\n async expectPossibleVariableValues(possibleVariableValue: string): Promise<void> {\n await expect(this.page.locator('.variable-dropdown input')).toHaveValue(possibleVariableValue);\n }\n\n async addPossibleValue(value: Array<string> | string): Promise<void> {\n if (value instanceof Array) {\n for (const li of value) {\n await this.page.locator('.xl-components-input-full input').fill(li);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n } else {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n }\n\n async selectVariableValue(defaultValue: string): Promise<void> {\n await this.page.locator('.variable-value select').selectOption(defaultValue);\n }\n\n async save(): Promise<void> {\n const saveButton = this.page.locator('#modal .modal-footer .save');\n await saveButton.scrollIntoViewIfNeeded();\n await saveButton.click({ delay: 2000 });\n // Expect is needed here to avoid flackiness on clicking save button on modal window\n await expect(saveButton).not.toBeVisible();\n }\n\n async createPossibleValuesVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await expect(async () => {\n await this.page.locator('.ui-autocomplete-input').clear();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n const check = await this.page\n .locator('.ui-menu-item-wrapper')\n .getByText('${' + variableName + '}', { exact: true })\n .isVisible({ timeout: 1000 });\n if (check) {\n await this.page\n .locator('.ui-menu-item-wrapper')\n .getByText('${' + variableName + '}', { exact: true })\n .click({ timeout: 1000 });\n } else {\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click({ timeout: 1000 });\n }\n }).toPass();\n }\n\n async expectVariableValueToBe(value: string): Promise<void> {\n expect(await this.page.locator('.variable-value select option[selected=\"selected\"]').textContent()).toBe(value);\n }\n\n async expectNoVariablesInList(): Promise<void> {\n await expect(this.page.getByText('No variables defined.')).toBeVisible();\n }\n\n async expectNameInput(value: string): Promise<void> {\n await expect(this.page.locator(`#modal .variable-name input`)).toHaveValue(value);\n }\n\n async expectLabel(value: string): Promise<void> {\n await expect(this.page.locator('#modal .variable-label input')).toHaveValue(value);\n }\n\n async expectRequired(value: boolean): Promise<void> {\n if (value) await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).toBeChecked();\n else await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).not.toBeChecked();\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.variable-description input').click();\n await this.page.locator('.variable-description input').clear();\n await this.page.locator('.variable-description input').fill(description);\n }\n\n async setLabel(labelValue: string): Promise<void> {\n await this.page.locator('.variable-label input').fill(labelValue);\n }\n\n async setDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setValue(value: string): Promise<void> {\n await this.page.locator('.variable-value input').fill(value);\n }\n\n async clearValue(): Promise<void> {\n await this.page.locator('.variable-value input').clear();\n }\n\n async clickMultiline(): Promise<void> {\n await this.page.locator('#multiline').click();\n }\n\n async setValueForMultilinePassword(value: string): Promise<void> {\n await this.page.locator('.password-textarea').fill(value);\n }\n}\nclass DeleteVariableModel extends WithPage {\n model: VariableModal;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.model = new VariableModal(page);\n this.dateUtil = new DateUtil(page);\n }\n async deleteVariable(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async replaceItWithVariable(variable: string): Promise<void> {\n await this.model.createPossibleValuesVariable(variable);\n }\n\n async replaceItwithValue(value: string): Promise<void> {\n await this.page.locator('.display').click();\n await this.page.getByLabel('*').fill(value);\n }\n\n async clickReplaceAndDelete(): Promise<void> {\n await this.page.getByRole('button', { name: 'Replace and delete' }).click();\n }\n\n async addValue(value: string): Promise<void> {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n\n async remove(value: string): Promise<void> {\n await this.page.locator('li').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async expectReplacementPromptDisplayed(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async removeItemOnSet(value: string): Promise<void> {\n await this.page.locator('tr').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async addValueForSet(key: string, value: string): Promise<void> {\n await this.page.locator('.input-key').fill(key);\n await this.page.locator('.input-value').fill(value);\n }\n\n async replaceWithIntegerValue(value: string): Promise<void> {\n await this.page.locator('.editable').fill(value);\n }\n\n async replaceForBooleanValue(): Promise<void> {\n await this.page.locator('.editor input').click();\n }\n\n async deleteBySettingDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ActivityRail extends WithPage {\n commentFilterInput: Locator;\n filterIconButton: Locator;\n markdownWrapper: Locator;\n sortButton: Locator;\n systemListItem: Locator;\n tooltipPopper: Locator;\n userListItem: Locator;\n viewAllListItem: Locator;\n\n constructor(page: Page) {\n super(page);\n this.sortButton = this.page.locator(\".dot-icon-btn[data-testid='task-comment-sort-btn']\");\n this.viewAllListItem = this.page.locator(\".dot-li[data-id='all']\");\n this.systemListItem = this.page.locator(\".dot-li[data-id='system']\");\n this.userListItem = this.page.locator(\".dot-li[data-id='user']\");\n this.filterIconButton = this.page.locator(\".dot-icon-btn[aria-label='filter icon button']\");\n this.commentFilterInput = this.page.locator('input#task-comment-filter');\n this.markdownWrapper = this.page.locator('.markdown-wrapper');\n this.tooltipPopper = this.page.locator('.MuiTooltip-popper');\n }\n\n async expectCommentToContain(comment: string, shouldContain = true): Promise<void> {\n const commentLocator = this.markdownWrapper.getByText(comment);\n\n if (shouldContain) {\n await expect(commentLocator).toBeVisible();\n } else {\n await expect(commentLocator).toHaveCount(0);\n }\n }\n\n async expectCommentToContainAtPosition(comment: string, positionIndex: number): Promise<this> {\n await expect(this.markdownWrapper.nth(positionIndex).getByText(comment)).toBeVisible();\n return this;\n }\n\n async expectCommentToContainLink(hrefLink: RegExp): Promise<void> {\n await expect(this.page.locator('.markdown-wrapper a')).toHaveAttribute('href', hrefLink);\n }\n\n async expectTaskIsCommentable(isCommentable: boolean): Promise<void> {\n return expect(await this.page.locator('#task-comment').count()).toBe(isCommentable ? 1 : 0);\n }\n\n async addComment(comment: string): Promise<this> {\n await this.page.locator('#task-comment').fill(comment);\n await this.page.locator('.icon-send-airplane').click();\n return this;\n }\n\n async searchComments(filter: string): Promise<this> {\n await this.commentFilterInput.fill(filter);\n await this.commentFilterInput.press('Enter');\n return this;\n }\n\n async clickOnFilterIconButton(): Promise<this> {\n await this.filterIconButton.click();\n return this;\n }\n\n async clickOnUserListItemFilter(): Promise<this> {\n await this.userListItem.click();\n return this;\n }\n\n async clickOnSystemListItemFilter(): Promise<this> {\n await this.systemListItem.click();\n return this;\n }\n\n async clickOnViewAllListItemFilter(): Promise<this> {\n await this.viewAllListItem.click();\n return this;\n }\n\n async clickOnSortIconButton(): Promise<this> {\n await this.sortButton.click();\n return this;\n }\n\n async expectAuthorCommentsToBe(author: string): Promise<this> {\n await expect(this.page.locator('.task-comment-user h6')).toHaveText(author);\n return this;\n }\n\n async expectSortIconButtonToHaveTooltipText(tooltipText: string): Promise<this> {\n await this.sortButton.hover();\n await expect(this.tooltipPopper.getByText(tooltipText)).toBeVisible();\n return this;\n }\n\n async expectCommentsDateTimeToBe(comment: string, date: string): Promise<this> {\n const commentLocator = this.page\n .locator('.task-comment-body')\n .filter({ has: this.page.locator('.markdown-switcher').getByText(comment) })\n .locator('.task-comment-user span')\n .getByRole('tooltip', { name: 'Edited' });\n await expect(commentLocator).toHaveAttribute('aria-label', date);\n return this;\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class AttachmentRail extends WithPage {\n async expectWithAttachment(filename: string): Promise<void> {\n const test = this.page.locator('.task-attachments-grid .file-item-text');\n await expect(test).toContainText(filename);\n }\n\n async getAttachmentsListCount(): Promise<number> {\n return await this.page.locator('.file-upload-list div').count();\n }\n\n async uploadFile(filePath: string): Promise<void> {\n const fileChooserPromise = this.page.waitForEvent('filechooser');\n await this.page.getByRole('button', { name: 'Select file(s)' }).click();\n const fileChooser = await fileChooserPromise;\n await fileChooser.setFiles(filePath);\n }\n\n async downloadFile(filename: string): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n const downloadPromise = this.page.waitForEvent('download');\n await this.page\n .locator('li')\n .filter({ hasText: '' + filename + '' })\n .click();\n await downloadPromise;\n }\n\n async deleteAttachment(fileName: string): Promise<void> {\n await this.page.locator('li').filter({ hasText: fileName }).click();\n await this.page.getByLabel('delete file').click();\n await this.page.getByRole('button', { name: 'Delete' }).waitFor({ state: 'visible' });\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async expectWithNoAttachment(tempFile: string): Promise<void> {\n const test = await this.page.locator('.task-attachments-grid .file-item-text').count();\n if (test > 0) {\n await expect(this.page.locator('.task-attachments-grid .file-item-text')).not.toContainText(tempFile);\n } else {\n await expect(this.page.locator('.task-attachments-grid .file-item-text')).not.toBeVisible();\n }\n }\n}\n","import { WithPage } from '../WithPage';\nimport { Page, expect } from '@playwright/test';\n\nexport class AttributeRail extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async clickAddAttribute(): Promise<void> {\n await this.page.getByTestId('add-btn').click();\n }\n\n async expectAttributeEditable(): Promise<void> {\n await expect(this.page.locator('#facet-type')).not.toHaveAttribute('readonly', '');\n }\n\n async addTag(tagName: string): Promise<void> {\n await this.page.locator('#task-tags').click();\n await this.page.locator('#task-tags').fill(tagName);\n await this.page.locator('#task-tags').press('Enter');\n }\n\n async expectContainsTag(tagName: Array<string> | string): Promise<void> {\n if (Array.isArray(tagName)) {\n for (const tag of tagName) {\n await expect(this.page.locator('.task-tags-wrapper .dot-chip').filter({ hasText: tag })).toBeVisible();\n }\n } else {\n await expect(this.page.locator('.task-tags-wrapper .dot-chip').filter({ hasText: tagName })).toBeVisible();\n }\n }\n\n async selectAttributeType(type: string): Promise<void> {\n await this.page.getByRole('combobox', { name: 'Type of attribute' }).click();\n await this.page.getByRole('combobox', { name: 'Type of attribute' }).fill(type);\n await this.page.getByRole('option', { name: type }).click();\n }\n\n async fillInputValue(labelName: string, value: string): Promise<void> {\n await this.page.getByRole('combobox', { name: labelName }).click();\n await this.page.getByRole('combobox', { name: labelName }).clear();\n await this.page.getByRole('combobox', { name: labelName }).fill(value);\n await this.page.getByRole('option', { name: value, exact: true }).click();\n }\n\n async saveAttributes(): Promise<void> {\n await this.page.locator('.task-attribute-edit-buttons').click();\n await this.page.getByTestId('save-btn').click();\n }\n\n async cancelAttribute(): Promise<void> {\n await this.page.getByTestId('cancel-btn').click();\n }\n\n async setInputTextField(fieldId: string, value: string): Promise<void> {\n await this.page.locator(`input[id=\"${fieldId}\"]`).focus();\n await this.page.locator(`input[id=\"${fieldId}\"]`).fill(value);\n }\n\n async expectFacetCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.task-attribute-item')).toHaveCount(count);\n }\n\n async expectFieldValueToBe(fieldId: string, value: string): Promise<void> {\n await expect(this.page.locator('input[id=\"' + fieldId + '\"]')).toHaveValue(value);\n }\n\n async clickEditExistingFacet(facetName: string): Promise<void> {\n await this.page.locator('.task-attribute-item').filter({ hasText: facetName }).getByTestId('edit-btn').click();\n }\n\n async deleteFacet(faceName: string): Promise<void> {\n await this.page.locator('.task-attribute-item').filter({ hasText: faceName }).getByTestId('delete-btn').click();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ConditionRail extends WithPage {\n railLocator: Locator;\n preconditionToggle: Locator;\n textEditor: Locator;\n saveButton: Locator;\n\n constructor(page: Page) {\n super(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-conditions');\n this.preconditionToggle = page.getByLabel('Enable precondition');\n this.textEditor = page.locator('textarea');\n this.saveButton = page.getByTestId('save-btn');\n }\n\n async enablePrecondition(): Promise<void> {\n expect(await this.preconditionToggle.isChecked()).toBe(false);\n await this.preconditionToggle.check();\n }\n\n async disablePrecondition(): Promise<void> {\n expect(await this.preconditionToggle.isChecked()).toBe(true);\n await this.preconditionToggle.uncheck();\n }\n\n async setPrecondition(script: string): Promise<void> {\n await this.enablePrecondition();\n await this.textEditor.fill(script);\n await this.saveButton.dblclick();\n await this.page.waitForTimeout(1000);\n }\n\n async expectPreconditionEditable(editable: boolean): Promise<void> {\n if (editable) {\n await expect(this.textEditor).toBeEditable();\n } else {\n await expect(this.textEditor).not.toBeEditable();\n }\n }\n\n async enableFailureHandler(): Promise<void> {\n await this.page.getByLabel('Enable failure handler').check();\n }\n\n async expectEnabledFailureHandlerToggle(): Promise<void> {\n await expect(this.page.getByLabel('Enable failure handler')).toBeEnabled();\n }\n\n async expectDisabledFailureHandlerToggle(): Promise<void> {\n await expect(this.page.getByLabel('Enable failure handler')).toBeDisabled();\n }\n\n async clickFailureHandler(): Promise<this> {\n await this.page.getByRole('button', { name: 'failure' }).click();\n return this;\n }\n\n async clickPrecondition(): Promise<this> {\n await this.page.getByRole('button', { name: 'precondition' }).click();\n return this;\n }\n\n async expectFailureHandlerHasDefaults(): Promise<this> {\n await expect(this.page.locator('.task-conditions .dot-label-wrapper')).toContainText('If the task fails');\n await expect(this.page.locator('#select-action')).toContainText('Skip task');\n return this;\n }\n\n async selectPostAction(action: string): Promise<this> {\n await this.page\n .getByRole('textbox', { name: 'If the task fails' })\n .getByLabel('If the task fails')\n .selectOption(action);\n return this;\n }\n\n async enterFailureHandlerScript(script: string): Promise<this> {\n await this.page.locator('.ace_content').click();\n await this.page.locator('textarea').fill(script);\n await this.saveButton.click();\n return this;\n }\n\n async expectScriptToContain(script: string): Promise<void> {\n await expect(this.page.locator('.code-editor .ace_content')).toContainText(script);\n }\n\n async expectFailureHandlerEditable(): Promise<this> {\n await expect(this.page.locator('#select-action')).toBeVisible();\n return this;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ConfigRail extends WithPage {\n railLocator: Locator;\n\n constructor(page: Page) {\n super(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-config');\n }\n\n async openInputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Input properties').click();\n }\n\n async openOutputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Output properties').click();\n }\n\n async getValueFromCi(propertyName: string): Promise<string> {\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async getAllOptionsFromCi(propertyName: string): Promise<string[]> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n return this.railLocator.locator(`.dot-popper ul li`).allInnerTexts();\n }\n\n async setValueFromCi(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.locator(`.dot-popper ul li`, { hasText: value }).click();\n }\n\n async getValueFromString(propertyName: string): Promise<string | null> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async setValueFromString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueFromLargeString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`textarea[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueFromPassword(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setAndCreateVariable(propertyName: string, variableName: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(variableName);\n await this.railLocator.locator(`.dot-popper button`, { hasText: variableName }).click();\n }\n\n async setVariable(propertyName: string, variableName: string): Promise<void> {\n return this.setValueFromCi(propertyName, variableName);\n }\n\n async expectValueFromString(propertyName: string, propertyValue: string): Promise<void> {\n return await expect(this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`)).toHaveText(\n propertyValue,\n );\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class OverviewRail extends WithPage {\n dependency: Dependency;\n modal: ModalWindow;\n railLocator: Locator;\n scriptTextArea: Locator;\n constructor(page: Page) {\n super(page);\n this.dependency = new Dependency(page);\n this.modal = new ModalWindow(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-drawer-content');\n this.scriptTextArea = this.page.locator('.code-editor textarea.ace_text-input');\n }\n\n async openInputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Input properties').click();\n }\n\n async openOutputProperties(): Promise<void> {\n await this.railLocator.locator('.task-config-header').getByText('Output properties').click();\n }\n\n async getValueFromCi(propertyName: string): Promise<string> {\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async getAllOptionsFromCi(propertyName: string): Promise<string[]> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n return this.railLocator.locator(`.dot-popper ul li`).allInnerTexts();\n }\n\n async setValueFromCi(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.locator(`.dot-popper ul li`, { hasText: value }).click();\n }\n\n async clickCreateNewCiInVariable(propertyName: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).clear();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).click();\n await this.railLocator.getByTestId('dot-action-item-btn').click();\n }\n\n async getValueFromString(propertyName: string): Promise<string | null> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n return this.railLocator.locator(`input[id=\"${propertyName}\"]`).inputValue();\n }\n\n async getStringListField(propertyName: string): Promise<StringList> {\n return new StringList(propertyName, this.page);\n }\n\n async getStringSetField(propertyName: string): Promise<StringSet> {\n return new StringSet(propertyName, this.page);\n }\n\n async getStringMapField(propertyName: string): Promise<StringMap> {\n return new StringMap(propertyName, this.page);\n }\n\n async setValueFromString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueFromLargeString(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.railLocator.locator(`textarea[id=\"${propertyName}\"]`).fill(value);\n }\n\n async setValueForBody(value: string): Promise<void> {\n await this.railLocator.locator('.notification-body-field .markdown-viewer').focus();\n await this.railLocator.locator('.notification-body-field .markdown-viewer').dblclick();\n await this.railLocator.locator('#notification-body').fill(value);\n await this.railLocator.locator('#notification-body').press('Enter');\n await this.railLocator.getByTestId('save-button').click();\n }\n\n async setValueFromPassword(propertyName: string, value: string): Promise<void> {\n await this.railLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async selectVariableFromOption(objectID: string, variable: string): Promise<void> {\n await this.page.locator(`div[data-testid=\"${objectID}\"] .icon-variable`).click();\n await this.page.locator(`#${objectID}`).fill(variable);\n await this.page.getByRole('option', { name: variable }).click();\n }\n\n async setValueForDateVariable(variable: string, date: string): Promise<this> {\n await this.page.getByRole('textbox', { name: variable }).fill(date);\n return this;\n }\n\n async createNewVariableForField(objectID: string, variable: string): Promise<void> {\n const variable_icon = this.page.locator(`div[data-testid=\"${objectID}\"] .icon-variable`);\n if (await variable_icon.isVisible()) {\n await variable_icon.click({ timeout: 1000 });\n }\n await this.page.locator(`#${objectID}`).fill(variable);\n await this.railLocator.locator(`.dot-popper button`, { hasText: variable }).click();\n }\n\n async createReleaseIdInOutputProperties(propertyName: string, variableName: string): Promise<void> {\n await this.railLocator.locator(`#${propertyName}`).fill(variableName);\n await this.page.getByTestId('dot-action-item-btn').click();\n }\n\n async expectValueInOutputProperties(variableId: string, value: string, expected = true): Promise<void> {\n if (expected) {\n await expect(this.railLocator.locator(`#${variableId}`)).toBeVisible();\n await expect(this.railLocator.locator(`#${variableId}`)).toHaveValue(value);\n } else {\n await expect(this.railLocator.locator(`#${variableId}`)).not.toBeVisible();\n }\n }\n\n async expectValueInInputProperties(propertyName: string, value: string, expected = true): Promise<void> {\n if (expected) {\n await expect(this.railLocator.locator(`[name='${propertyName}']`)).toHaveValue(value);\n }\n }\n\n async selectReleaseIdInOutputProperties(objectID: string, variableName: string): Promise<void> {\n await this.railLocator.locator(`#${objectID}`).fill(variableName);\n await this.page.getByRole('option', { name: variableName }).click();\n }\n\n async expectVariable(propertyName: string, expected = true): Promise<void> {\n if (expected)\n await expect(\n this.railLocator\n .locator(`input[id=\"${propertyName}\"]`)\n .or(this.railLocator.locator(`textarea[id=\"${propertyName}\"]`)),\n ).toBeVisible();\n else\n await expect(\n this.railLocator\n .locator(`input[id=\"${propertyName}\"]`)\n .or(this.railLocator.locator(`textarea[id=\"${propertyName}\"]`)),\n ).not.toBeVisible();\n }\n\n async expectAlertMessage(alertMessage: string): Promise<void> {\n await expect(this.railLocator.locator('.warning .MuiAlert-message')).toHaveText(alertMessage);\n }\n\n async expectValueFromString(propertyName: string, propertyValue: string): Promise<void> {\n return await expect(this.railLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`)).toHaveText(\n propertyValue,\n );\n }\n\n async expectValueFromResultString(propertyName: string, value: string): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${propertyName}\"]`).getByText(value)).toBeVisible();\n return this;\n }\n\n async expectDisabledInputField(propertyName: string): Promise<this> {\n const inputField = this.railLocator.locator(`.task-input-property input[id=\"${propertyName}\"]`);\n if (await inputField.isVisible()) await expect(inputField).toHaveAttribute('readonly' || 'disabled', '');\n return this;\n }\n\n async expectRiskProfileValue(value: string): Promise<void> {\n await expect(this.railLocator.locator('#riskProfileId')).toHaveValue(value);\n }\n\n async expectTo(value: string): Promise<void> {\n return await expect(this.railLocator.getByTestId(`dot-autocomplete-chip`)).toHaveText(value);\n }\n\n async expectAutoCompleteFieldValue(label: string, value: string[] | string): Promise<void> {\n await expect(\n this.railLocator.locator('.task-input-property').filter({ hasText: label }).getByTestId('dot-autocomplete-chip'),\n ).toContainText(value);\n }\n\n async expectFieldValue(fieldName: string, value: string): Promise<void> {\n await expect(this.railLocator.locator(`input[name=\"${fieldName}\"]`)).toHaveValue(value);\n }\n\n async expectSubjectToBe(value: string): Promise<void> {\n return await expect(this.page.locator('#notification-subject')).toHaveValue(value);\n }\n\n async expectBodyToBe(value: string): Promise<void> {\n return await expect(this.page.locator('.notification-body-field p')).toHaveText(value);\n }\n\n async expectReleaseTitleToBe(value: string): Promise<void> {\n return await expect(this.page.locator('input[name=newReleaseTitle]')).toHaveValue(value);\n }\n\n async setBody(value: string): Promise<void> {\n await this.page.locator('.notification-body-field p').dblclick();\n await this.page.locator('.notification-body-field #notification-body').fill(value);\n await this.page.getByTestId(`save-button`).click();\n }\n\n async setReleaseTags(tags: Array<string> | string): Promise<void> {\n if (typeof tags !== 'string') {\n for (const tag of tags) {\n await this.page.locator('#release-tags').fill(tag);\n await this.page.locator('#release-tags').press('Enter');\n }\n } else {\n await this.page.locator('#release-tags').fill(tags);\n await this.page.locator('#release-tags').press('Enter');\n }\n }\n\n async setScript(script: string): Promise<void> {\n await this.scriptTextArea.clear();\n await this.scriptTextArea.fill(script);\n await this.page.locator('.code-editor .header button:has-text(\"Save\")').click();\n }\n\n async expectScriptToContain(script: string): Promise<void> {\n await expect(this.page.locator('.code-editor .ace_content')).toContainText(script);\n }\n\n async enterScriptForAutoComplete(script: string): Promise<void> {\n await this.scriptTextArea.clear();\n await this.scriptTextArea.fill(script);\n await this.scriptTextArea.press('.');\n }\n\n async openScriptEditorInSeparateWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-enter-btn').click();\n await expect(this.page.locator('#dialogTitle')).toBeVisible();\n }\n\n async closeFullscreenScriptWindowWithESC(): Promise<void> {\n await this.page.locator('#dialogTitle').press('Escape');\n await expect(this.page.locator('#dialogTitle')).not.toBeVisible();\n }\n\n async closeFullscreenScriptWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-exit-btn').click();\n await expect(this.page.locator('#dialogTitle')).not.toBeVisible();\n }\n\n async abort(comment: string): Promise<void> {\n await this.page.getByTestId('single-action-button').click();\n await this.page.getByTestId('task-action-comment').click();\n await this.page.getByTestId('task-action-comment').fill(comment);\n await this.page.locator('button', { hasText: 'Abort' }).click();\n }\n\n async expectDependenciesDisplayed(dependencies: any[]): Promise<void> {\n await this.railLocator.locator('.gate-task-dependencies').waitFor();\n for (let i = 0; i < dependencies.length; i++) {\n await expect(this.page.locator('.dependency').filter({ hasText: dependencies[i] })).toBeVisible();\n }\n }\n\n async expectDependencyStatus(option = true): Promise<void> {\n if (option) {\n await expect(this.page.locator('.with-status .task-status')).toBeVisible();\n } else {\n await expect(this.page.locator('.with-status .task-status')).not.toBeVisible();\n }\n }\n\n async expectResolvedDependency(): Promise<void> {\n await expect(this.page.locator('span[aria-label=\"check-line icon\"]')).toBeVisible();\n }\n\n async expectUnresolvedDependency(): Promise<void> {\n await expect(this.page.locator('span[aria-label=\"close-line icon\"]')).not.toBeVisible();\n }\n\n async expectCanDeleteDependency(title: string, canDelete = true): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options');\n if (canDelete) {\n await depOptionsIcon.click();\n await expect(this.railLocator.getByRole('menuitem', { name: 'Remove' })).toBeVisible();\n } else {\n await expect(depOptionsIcon).not.toBeVisible();\n }\n }\n\n async expectDependencyContextualMenu(option = true): Promise<void> {\n const depOptionsIcon = this.page.locator('.dependency .icon-options');\n if (option) {\n await expect(depOptionsIcon).toBeVisible();\n } else {\n await expect(depOptionsIcon).not.toBeVisible();\n }\n }\n\n async expectDependencyContextualMenuFor(title: string, option = true): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options');\n if (option) {\n await expect(depOptionsIcon).toBeVisible();\n } else {\n await expect(depOptionsIcon).not.toBeVisible();\n }\n }\n\n async removeDependency(title: string): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByLabel(title, { exact: true }) })\n .locator('.icon-options');\n await depOptionsIcon.click();\n await this.railLocator.getByRole('menuitem', { name: 'Remove' }).click();\n }\n\n async expectDependencyNotToBeVisible(): Promise<void> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).not.toBeVisible();\n }\n\n async getDependencyCount(): Promise<number> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n return await this.railLocator.locator('.gate-task-dependencies .dependency').count();\n }\n\n async addDependency(): Promise<void> {\n await expect(this.railLocator.locator('.add-dependency-btn')).toBeVisible();\n await this.railLocator.locator('.add-dependency-btn').click();\n }\n\n async addCondition(): Promise<void> {\n await expect(this.railLocator.getByTestId('add-condition')).toBeVisible();\n await this.railLocator.getByTestId('add-condition').click();\n }\n\n async expectDependencyText(dependencies: string, isVisible = true): Promise<void> {\n if (isVisible) {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n await expect(this.page.locator(`.gate-task-dependencies`).getByLabel(dependencies).first()).toBeVisible();\n } else await expect(this.page.locator(`.gate-task-dependencies`).getByLabel(dependencies)).not.toBeVisible();\n }\n\n async clickEditDependency(dependencies: string): Promise<void> {\n const depOptionsIcon = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByLabel(dependencies) })\n .first()\n .locator('.actions');\n await depOptionsIcon.click();\n const frame = this.page.getByTestId('undefined-menu');\n if (await frame.isVisible()) {\n await this.railLocator.getByRole('menuitem', { name: 'Edit' }).click();\n } else {\n await depOptionsIcon.click();\n await this.railLocator.getByRole('menuitem', { name: 'Edit' }).click();\n }\n }\n async validateAutoCompleteOptionsInDescription(\n descriptionName: string,\n expectedVariableCount: number,\n variableToSelection?: string,\n ): Promise<void> {\n await this.page.getByLabel('Double-click to edit').waitFor({ timeout: 10000 });\n await this.page.getByLabel('Double-click to edit').hover();\n await this.page.locator('.markdown-viewer-actions').getByTestId('edit-button').click();\n await this.page.locator('#task-description-input').fill(descriptionName);\n await expect(this.page.locator('.dot-popper-content-wrapper .option-name')).toHaveCount(expectedVariableCount);\n if (variableToSelection)\n await this.page\n .locator('.dot-popper-content-wrapper .option-name')\n .filter({ hasText: variableToSelection })\n .click();\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n\n // eslint-disable-next-line max-params\n async validateAutoCompleteOptions(\n fieldLabel: string,\n value: string,\n expectedVariableCount: number,\n variableToSelect?: string,\n ): Promise<void> {\n await this.page.getByLabel(fieldLabel).click();\n await this.page.getByLabel(fieldLabel).fill(value);\n await expect(this.page.getByRole('option')).toHaveCount(expectedVariableCount);\n if (variableToSelect) await this.page.getByRole('option', { name: variableToSelect }).click();\n }\n\n async setReleaseTitle(releaseName: string): Promise<void> {\n await this.page.getByLabel('Release title *').fill(releaseName);\n }\n\n async setFolder(folderName: string): Promise<void> {\n await this.page.getByPlaceholder('Select a folder').click();\n await this.page.getByPlaceholder('Search folder...').fill(folderName);\n await this.page.getByRole('button', { name: folderName }).click();\n }\n\n async setTemplate(templateName: string): Promise<void> {\n await this.page.locator('#templateId').click();\n await this.page.locator('#templateId').fill(templateName);\n await this.page.getByRole('option', { name: templateName }).click();\n }\n\n async clearTemplate(): Promise<void> {\n await this.page.locator('#templateId').click();\n await this.page.locator('#templateId').clear();\n }\n\n async errorMsgVisible(errorMessage: string): Promise<void> {\n await expect(this.page.locator('#dialogTitle')).toContainText(errorMessage);\n }\n\n async isButtonVisible(buttonName: string, visible = true): Promise<void> {\n const locator = this.page.getByRole('button', { name: buttonName });\n if (visible) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async cancelDialogWindow(): Promise<void> {\n await this.page.getByRole('button', { name: 'cancel' }).click();\n }\n\n async acceptDialogWindow(): Promise<void> {\n await this.page.getByRole('button', { name: 'change template' }).click();\n }\n\n async setRiskProfile(RiskProfile: string): Promise<void> {\n await this.page.getByLabel('Risk profile').click();\n await this.page.getByLabel('Risk profile').fill(RiskProfile);\n await this.page.getByRole('option', { name: RiskProfile }).click();\n }\n\n async expectTemplate(template: string): Promise<void> {\n await expect(this.railLocator.locator('#templateId')).toBeVisible({ timeout: 10000 });\n await expect(this.railLocator.locator('#templateId')).toHaveValue(template);\n }\n\n async setAutoCompletePassword(passwordValue: string): Promise<void> {\n await this.page.getByTestId('password').getByLabel('Click to switch between').click();\n await this.page.locator('#password').fill(passwordValue);\n await this.page.getByRole('option', { name: passwordValue }).click();\n }\n\n async setAutoCompleteField(fieldLabel: string, value: string): Promise<void> {\n await this.page.getByLabel(fieldLabel).click();\n await this.page.getByLabel(fieldLabel).fill(value);\n await this.page.getByRole('option', { name: value }).click();\n }\n\n async setNewAutoCompleteField(fieldLabel: string, value: string): Promise<void> {\n await this.page.getByLabel(fieldLabel).click();\n await this.page.getByLabel(fieldLabel).fill(value);\n await this.page.getByTestId('dot-action-item-btn').click();\n }\n\n async setTextField(fieldID: string, value: string): Promise<void> {\n await this.page.locator(`[data-test-id=\"${fieldID}\"]`).nth(1).click();\n await this.page.locator(`input[name='${fieldID}']`).fill(value);\n }\n\n async setEmailField(fieldName: string, value: string): Promise<void> {\n await this.page.getByLabel(`${fieldName}`, { exact: true }).click();\n await this.page.getByLabel(`${fieldName}`, { exact: true }).clear();\n await this.page.getByLabel(`${fieldName}`, { exact: true }).fill(value);\n await this.page.getByLabel(`${fieldName}`, { exact: true }).press('Enter');\n }\n\n async selectValueFromOption(fieldId: string, value: string): Promise<void> {\n await this.page.locator(`#${fieldId}`).selectOption(value);\n }\n\n async abortButtonVisibility(visible = true): Promise<void> {\n const locator = this.page.getByRole('button', { name: 'Abort' });\n if (visible) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async setPattern(patternName: string): Promise<void> {\n await this.page.locator('#patternId').click();\n await this.page.locator('#patternId').fill(patternName);\n await this.page.getByRole('option', { name: patternName }).click();\n }\n\n async setStartDate(date: string): Promise<void> {\n await this.page.locator('#startDate').click();\n await this.page.locator('#startDate').fill(date);\n }\n\n async setEndDate(date: string): Promise<void> {\n await this.page.locator('#endDate').click();\n await this.page.locator('#endDate').fill(date);\n }\n\n async enableFallback(): Promise<void> {\n await this.page.getByLabel('Fallback').check();\n }\n\n async expectDescription(description: string): Promise<void> {\n await expect(this.page.getByTestId('dot-accordion-details')).toHaveText(description);\n }\n\n async editDescription(description: string): Promise<void> {\n await this.page.getByLabel('Double-click to edit').waitFor({ timeout: 10000 });\n await this.page.getByLabel('Double-click to edit').hover();\n await this.page.locator('.markdown-viewer-actions').getByTestId('edit-button').click();\n await this.page.locator('#task-description-input').clear();\n await this.page.locator('#task-description-input').fill(description);\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n\n async expectedGateConditionDisplayed(title: string, isVisible = true): Promise<void> {\n if (isVisible)\n await expect(this.page.locator('.gate-task-condition-input').filter({ hasText: title })).toBeVisible();\n else await expect(this.page.locator('.gate-task-condition-input').filter({ hasText: title })).not.toBeVisible();\n }\n\n async expectedGateConditionChecked(title: string, expected = true): Promise<void> {\n if (expected)\n await expect(\n this.page.locator('.gate-task-condition').filter({ hasText: title }).getByTestId('CheckBoxIcon'),\n ).toBeVisible();\n else\n await expect(\n this.page.locator('.gate-task-condition').filter({ hasText: title }).getByTestId('CheckBoxOutlineBlankIcon'),\n ).toBeVisible();\n }\n\n async removeCondition(title: string): Promise<void> {\n await this.page.locator('.gate-task-condition').filter({ hasText: title }).locator('.icon-delete').click();\n }\n\n async checkGateCondition(title: string): Promise<void> {\n await this.page\n .locator('.gate-task-condition')\n .filter({ hasText: title })\n .getByTestId('CheckBoxOutlineBlankIcon')\n .click();\n }\n\n async expectScriptEditable(): Promise<void> {\n await this.page.locator('div.ace_content').click();\n await expect(this.scriptTextArea).not.toHaveAttribute('disabled', '');\n await expect(this.scriptTextArea).not.toHaveAttribute('readonly', '');\n }\n\n async expectInputPropertiesEditable(propertyName: Array<string> | string): Promise<void> {\n if (typeof propertyName !== 'string') {\n for (const pName of propertyName) {\n await expect(this.railLocator.locator(`input[id=\"${pName}\"]`)).not.toHaveAttribute('disabled', '');\n await expect(this.railLocator.locator(`input[id=\"${pName}\"]`)).not.toHaveAttribute('readonly', '');\n }\n } else {\n await expect(this.railLocator.locator(`input[id=\"${propertyName}\"]`)).not.toHaveAttribute('disabled', '');\n await expect(this.railLocator.locator(`input[id=\"${propertyName}\"]`)).not.toHaveAttribute('readonly', '');\n }\n }\n\n async setSelectField(fieldName: string, fieldValue: string): Promise<void> {\n await this.page.getByTestId(`${fieldName}-input`).click();\n const closeIcon = this.page.getByTestId(`CloseIcon`);\n if (await closeIcon.isVisible()) {\n await closeIcon.click();\n }\n await this.page.getByTestId(`${fieldName}-input`).fill(fieldValue);\n await this.page.getByText(fieldValue).click();\n }\n\n async expectStartReleaseToBe(value: string): Promise<void> {\n return await expect(this.railLocator.locator('#startRelease')).toHaveValue(value);\n }\n\n async setStartReleaseVariable(value: string): Promise<void> {\n await this.railLocator.locator('#startRelease').click();\n await this.railLocator.locator('#startRelease').fill(value);\n }\n\n async close(): Promise<void> {\n await this.page.locator('task-drawer .dot-drawer .task-drawer-header').getByTestId('close-btn').click();\n }\n\n async deselectValue(ObjectID: string): Promise<this> {\n await this.page.locator(`#${ObjectID}`).hover();\n await this.page.getByRole('button', { name: 'Clear' }).click();\n await expect(this.page.locator(`#${ObjectID}`)).toHaveValue('');\n return this;\n }\n\n async expectEditVariableList(isVisible = true): Promise<this> {\n if (isVisible) {\n await expect(this.page.getByTestId('edit-btn')).toBeVisible();\n } else {\n await expect(this.page.getByTestId('edit-btn')).toBeDisabled();\n }\n return this;\n }\n\n async clickEditVariableList(): Promise<this> {\n await this.page.getByTestId('edit-btn').click();\n return this;\n }\n\n async removeVariable(variableName: string): Promise<this> {\n await this.page.locator('.draggable-list').filter({ hasText: variableName }).locator('.icon-close').click();\n return this;\n }\n\n async saveVariable(): Promise<this> {\n await this.page.getByTestId('save-btn').click();\n return this;\n }\n\n async selectVariable(variable: Array<string> | string): Promise<this> {\n if (variable instanceof Array) {\n for (const value of variable) {\n await this.railLocator.getByRole('combobox', { name: 'Variables in this task' }).click();\n await this.railLocator.getByText(value).click();\n }\n } else {\n await this.railLocator.getByRole('combobox', { name: 'Variables in this task' }).click();\n await this.railLocator.getByText(variable).click();\n }\n return this;\n }\n\n async setValueForUserInputField(propertyName: string, value: string): Promise<void> {\n await this.page.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.page.locator(`input[id=\"${propertyName}\"]`).fill(value);\n }\n\n async toggleIgnoreVariableInterpolation(): Promise<void> {\n await this.page.getByLabel('Ignore variable interpolation').click();\n }\n}\n\nexport class ModalWindow extends WithPage {\n saveLocator: Locator;\n modalLocator: Locator;\n constructor(page: Page) {\n super(page);\n this.modalLocator = this.page.locator('.dot-dialog-content');\n this.saveLocator = this.page.getByRole('button', { name: 'Save' });\n }\n\n async setInputTextField(propertyName: string, value: string): Promise<void> {\n await this.modalLocator.locator(`.input-scalar-fake-input[id=\"${propertyName}\"]`).focus();\n await this.modalLocator.locator(`input[id=\"${propertyName}\"]`).fill(value);\n await this.modalLocator.press('Tab');\n }\n\n async save(): Promise<void> {\n await this.saveLocator.click();\n }\n}\n\nexport class Dependency extends WithPage {\n private readonly dependencyLocator: Locator;\n private release: Locator;\n private phase: Locator;\n private task: Locator;\n\n constructor(page: Page) {\n super(page);\n this.dependencyLocator = page.locator('.gate-task-dependencies .dependency-selector-component');\n this.release = this.dependencyLocator.locator('#release-dependency');\n this.phase = this.dependencyLocator.locator('#phase-dependency');\n this.task = this.dependencyLocator.locator('#task-dependency');\n }\n\n async getRelease(): Promise<string | null> {\n return await this.release.getAttribute('value');\n }\n\n async getPhase(): Promise<string | null> {\n return await this.phase.getAttribute('value');\n }\n\n async getTask(): Promise<string | null> {\n return await this.task.getAttribute('value');\n }\n\n async setRelease(releaseTitle: string): Promise<void> {\n await this.release.click();\n await this.release.fill(releaseTitle);\n await this.page.getByRole('option', { name: releaseTitle }).waitFor();\n await this.page.getByRole('option', { name: releaseTitle }).click();\n }\n\n async save(): Promise<void> {\n await expect(this.dependencyLocator.getByTestId('save-button')).toBeVisible();\n await this.dependencyLocator.getByTestId('save-button').click();\n }\n\n async setPhase(phaseTitle: string): Promise<void> {\n await this.phase.click();\n await this.phase.fill('');\n const count = await this.page.getByRole('option', { name: phaseTitle }).count();\n if (count > 0) {\n await this.page.getByRole('option', { name: phaseTitle }).click();\n } else {\n await this.page.locator('.phase-dependency').getByLabel('Open').click();\n await this.page.getByRole('option', { name: phaseTitle }).click();\n }\n }\n\n async setTask(taskTitle: string): Promise<void> {\n await this.task.click();\n await this.task.fill(' ');\n await this.page.getByRole('option', { name: taskTitle }).click();\n }\n\n async clearPhase(): Promise<void> {\n await this.phase.clear();\n }\n\n async expectVariableModeEnabled(mode: boolean): Promise<void> {\n await expect(this.dependencyLocator.getByLabel('input-variable')).toBeVisible();\n const variableMode = await this.dependencyLocator.getByLabel('input-variable').getAttribute('aria-pressed');\n expect(variableMode).toBe('' + mode + '');\n }\n\n async clickVariable(): Promise<void> {\n await this.dependencyLocator.getByLabel('input-variable').waitFor();\n await this.dependencyLocator.getByLabel('input-variable').click();\n }\n\n //TODO: getAttribute('value') is not working as expected. Need to be fixed with better alternative.\n async expectMinimumOptions(options: any[]): Promise<void> {\n await this.dependencyLocator.getByPlaceholder('Please select a variable of').click();\n for (let i = 0; i < options.length; i++) {\n const option = await this.dependencyLocator.locator('#mui-30-option-' + i).getAttribute('value');\n expect(options[i]).toContain(option);\n }\n }\n\n async enterNewVariable(variableName: string): Promise<void> {\n await this.page.getByLabel('Please select a variable of').click();\n await this.page.getByLabel('Please select a variable of').fill(variableName);\n await this.page.getByTestId('dot-action-item-btn').click();\n }\n\n async selectVariable(variableName: string): Promise<void> {\n await this.page.getByLabel('Please select a variable of').click();\n await this.page.getByRole('option', { name: variableName }).click();\n }\n}\n\nexport class StringList extends WithPage {\n propertyName: string;\n constructor(propertyName: string, page: Page) {\n super(page);\n this.propertyName = propertyName;\n }\n\n async setValueFromStringList(value: string): Promise<this> {\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).focus();\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).fill(value);\n await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .icon-add`).click();\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).getByText(value)).toBeVisible();\n return this;\n }\n\n async expectStringListCount(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).count()).toBe(count);\n return this;\n }\n\n async removeValueFromStringList(value: string): Promise<this> {\n await this.page\n .locator(`[data-test-id=\"${this.propertyName}\"] .list`)\n .filter({ hasText: value })\n .locator('.icon-close')\n .click();\n return this;\n }\n\n async expectInputFieldDisabled(): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] input`)).not.toBeEditable();\n return this;\n }\n\n async expectValueFromStringList(value: string): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).getByText(value)).toBeVisible();\n return this;\n }\n}\n\nexport class StringSet extends WithPage {\n propertyName: string;\n\n constructor(propertyName: string, page: Page) {\n super(page);\n this.propertyName = propertyName;\n }\n\n async setValueFromStringSet(value: string): Promise<this> {\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).focus();\n await this.page.locator(`input[id=\"${this.propertyName}\"]`).fill(value);\n await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .icon-add`).click();\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).getByText(value)).toBeVisible();\n return this;\n }\n\n async expectInputFieldDisabled(): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] input`)).not.toBeEditable();\n return this;\n }\n\n async expectAddButtonDisabled(): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${this.propertyName}\"] .icon-add`)).toBeDisabled();\n return this;\n }\n\n async expectStringSetCount(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"${this.propertyName}\"] .list`).count()).toBe(count);\n return this;\n }\n\n async removeValueFromStringSet(key: string): Promise<this> {\n await this.page\n .locator(`[data-test-id=\"${this.propertyName}\"] .list`)\n .filter({ hasText: key })\n .locator('.icon-close')\n .click();\n return this;\n }\n}\n\nexport class StringMap extends WithPage {\n propertyName: string;\n\n constructor(propertyName: string, page: Page) {\n super(page);\n this.propertyName = propertyName;\n }\n\n async setValueFromMap(key: string, value: string): Promise<void> {\n await this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`).click();\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-key-input\"]`)\n .fill(key);\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-value-input\"]`)\n .fill(value);\n await this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.map-row-save-button`).click();\n await expect(this.page.locator(`.map-data-row .map-key`).getByText(key)).toBeVisible();\n }\n\n async removeValueFromMap(key: string): Promise<this> {\n await this.page\n .locator(`.map-data-row`)\n .filter({ has: this.page.locator(`.map-key`).getByText(key) })\n .locator(`.icon-delete`)\n .click();\n await expect(this.page.locator(`.map-data-row .map-key`).getByText(key)).not.toBeVisible();\n return this;\n }\n\n async expectStringMapCount(count: number): Promise<this> {\n expect(await this.page.locator('.map-data-row').count()).toBe(count);\n return this;\n }\n\n async expectAddButtonDisabledForMap(key: string, value: string): Promise<this> {\n await this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`).click();\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-key-input\"]`)\n .fill(key);\n await expect(\n this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`),\n ).toBeDisabled();\n await this.page\n .locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-value-input\"]`)\n .fill(value);\n await expect(\n this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] button.add-new-button`),\n ).toBeDisabled();\n return this;\n }\n\n async expectInputFieldDisabledForMap(): Promise<this> {\n await expect(\n this.page.locator(`.input-with-map[data-test-id=\"${this.propertyName}\"] input[id=\"new-row-value-input\"]`),\n ).not.toBeVisible();\n return this;\n }\n}\n","import { expect, Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\nimport moment from 'moment';\n\nexport class SchedulingRail extends WithPage {\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n }\n\n async expectStartDateToBeDisplayed(): Promise<void> {\n await expect(\n this.page.locator('.flex-section.column').filter({ hasText: 'Start Date' }).locator('.task-date-view-content'),\n ).toBeVisible();\n }\n\n async expectStartDateToBe(date: string): Promise<void> {\n expect(\n await this.page\n .locator('.flex-section.column')\n .filter({ hasText: 'Start Date' })\n .locator('.task-date-view-content .dot-avatar')\n .getAttribute('aria-label'),\n ).toContain(date);\n }\n\n async expectStartDateWarningBannerToNotBePresent(): Promise<void> {\n const alertBanner = this.page.locator('.dot-alert-banner');\n await expect(alertBanner).not.toBeVisible();\n }\n\n async expectStartDateWarningBanner(text: string, originalScheduledStartDate?: string): Promise<void> {\n const alertBanner = this.page.locator('.dot-alert-banner');\n await expect(alertBanner).toBeVisible();\n await expect(alertBanner).toContainText(text);\n if (originalScheduledStartDate) {\n const originalScheduledStartDateText = await this.page\n .locator('.dot-alert-banner p[data-testid=\"original-scheduled-start-date\"] span')\n .textContent();\n if (originalScheduledStartDateText) {\n expect(moment(new Date(originalScheduledStartDateText)).format('YYYY-MM-DDTHH:mm')).toBe(\n moment(new Date(originalScheduledStartDate)).format('YYYY-MM-DDTHH:mm'),\n );\n }\n }\n }\n\n async expectEndDateToBeDisplayed(): Promise<void> {\n await expect(\n this.page.locator('.flex-section.column').filter({ hasText: 'End Date' }).locator('.task-date-view-content'),\n ).toBeVisible();\n }\n\n async switchWaitForScheduledDate(): Promise<void> {\n await this.page.locator('.wait-for-start input').click();\n }\n\n async expectWaitForScheduledDateToBeChecked(): Promise<void> {\n await expect(this.page.locator('.wait-for-start input')).toBeChecked();\n }\n\n async expectWaitForScheduledDateToBeUnchecked(): Promise<void> {\n await expect(this.page.locator('.wait-for-start input')).not.toBeChecked();\n }\n\n async setDueTime(day?: string, hour?: string, minute?: string): Promise<void> {\n await this.page.locator('.duration-view-content').click();\n if (day) {\n await this.page.locator('#days').clear();\n await this.page.locator('#days').fill(day);\n }\n if (hour) {\n await this.page.locator('#hours').clear();\n await this.page.locator('#hours').fill(hour);\n }\n if (minute) {\n await this.page.locator('#minutes').clear();\n await this.page.locator('#minutes').fill(minute);\n }\n await this.page.getByTestId('save-button').click();\n }\n\n async setStartDate(date: string, monthYear: string): Promise<void> {\n await this.page\n .locator('.flex-section.column')\n .filter({ hasText: 'Start date' })\n .locator('.task-date')\n .waitFor({ timeout: 10000 });\n // reclick if the date picker is not visible\n await expect(async () => {\n await this.page.locator('.flex-section.column').filter({ hasText: 'Start date' }).locator('.task-date').click();\n // sometimes the date picker closes itself\n await this.page.waitForTimeout(1000);\n await expect(this.page.locator('.MuiPickersCalendarHeader-label')).toBeVisible({ timeout: 100 });\n }).toPass();\n await this.setDate(date, monthYear);\n }\n\n async setEndDate(date: string, monthYear: string): Promise<void> {\n await this.page\n .locator('.flex-section.column')\n .filter({ hasText: 'End date' })\n .locator('.task-date')\n .waitFor({ timeout: 10000 });\n // reclick if the date picker is not visible\n await expect(async () => {\n await this.page.locator('.flex-section.column').filter({ hasText: 'End date' }).locator('.task-date').click();\n // sometimes the date picker closes itself\n await this.page.waitForTimeout(1000);\n await expect(this.page.locator('.MuiPickersCalendarHeader-label')).toBeVisible({ timeout: 100 });\n }).toPass();\n await this.setDate(date, monthYear);\n }\n\n async setDate(date: string, monthYear: string): Promise<void> {\n const prev = this.page.getByTestId('ArrowLeftIcon');\n const next = this.page.getByTestId('ArrowRightIcon');\n const monYear = this.page.locator('.MuiPickersCalendarHeader-label');\n const currentDate = await monYear.textContent();\n const thisMonth = moment(monthYear, 'MMMM YYYY').isBefore(currentDate);\n while ((await monYear.textContent()) != monthYear) {\n if (thisMonth) {\n await prev.click();\n } else {\n await next.click();\n }\n }\n await this.page\n .getByRole('gridcell', { name: '' + date + '', exact: true })\n .first()\n .click();\n }\n\n async checkDelayDuringBlackoutPeriod(): Promise<void> {\n await this.page\n .locator('.task-wait-switch')\n .filter({ hasText: 'blackout' })\n .locator('.PrivateSwitchBase-input')\n .check();\n }\n\n async unCheckDelayDuringBlackoutPeriod(): Promise<void> {\n await this.page.getByTestId('blackout').locator('.PrivateSwitchBase-input').uncheck();\n }\n\n async checkEnvironmentAvailability(): Promise<void> {\n await this.page\n .locator('.task-wait-switch')\n .filter({ hasText: 'environment' })\n .locator('.PrivateSwitchBase-input')\n .check();\n }\n\n async unCheckEnvironmentAvailability(): Promise<void> {\n await this.page.getByTestId('environment').locator('.PrivateSwitchBase-input').uncheck();\n }\n}\n","import { WithPage } from '../WithPage';\nimport { expect, Locator, Page } from '@playwright/test';\n\nexport class HistoryRail extends WithPage {\n logsFilterInput: Locator;\n logContentWrapper: Locator;\n sortButton: Locator;\n\n constructor(page: Page) {\n super(page);\n this.logsFilterInput = this.page.locator('input#drawer-history-filter');\n this.sortButton = this.page.locator(\".dot-icon-btn[data-testid='drawer-history-sort-btn']\");\n this.logContentWrapper = this.page.locator('.content-right-message');\n }\n\n async expectLogToContain(log: string, shouldContain = true): Promise<void> {\n const logLocator = this.logContentWrapper.getByText(log);\n\n if (shouldContain) {\n await expect(logLocator).toBeVisible();\n } else {\n await expect(logLocator).toHaveCount(0);\n }\n }\n\n async expectLogToContainAtPosition(log: string, positionIndex: number): Promise<this> {\n await expect(this.logContentWrapper.nth(positionIndex).getByText(log)).toBeVisible();\n return this;\n }\n\n async searchLogs(filter: string): Promise<this> {\n await this.logsFilterInput.fill(filter);\n return this;\n }\n\n async clickOnSortIconButton(): Promise<this> {\n await this.sortButton.click();\n return this;\n }\n}\n","import { ActivityRail } from './taskActivity';\nimport { AttachmentRail } from './taskAttachments';\nimport { AttributeRail } from './taskAttribute';\nimport { ConditionRail } from './taskCondition';\nimport { ConfigRail } from './taskConfig';\nimport { OverviewRail } from './taskOverview';\nimport { Locator, Page, expect } from '@playwright/test';\nimport { SchedulingRail } from './taskScheduling';\nimport { WithPage } from '../WithPage';\nimport { HistoryRail } from './taskHistory';\n\ntype Rail =\n | 'Overview'\n | 'Activity'\n | 'Config'\n | 'Scheduling'\n | 'Conditions'\n | 'Attributes'\n | 'Attach'\n | 'Tags'\n | 'History';\n\nexport class TaskDrawer extends WithPage {\n activity: ActivityRail;\n attachment: AttachmentRail;\n attribute: AttributeRail;\n cancelButton: Locator;\n commentBox: Locator;\n completeButton: Locator;\n confirm: Locator;\n config: ConfigRail;\n condition: ConditionRail;\n failMenu: Locator;\n history: HistoryRail;\n retryButton: Locator;\n openMenu: Locator;\n overview: OverviewRail;\n scheduling: SchedulingRail;\n skipMenu: Locator;\n startButton: Locator;\n taskDrawerLocator: Locator;\n\n constructor(page: Page) {\n super(page);\n this.activity = new ActivityRail(page);\n this.attachment = new AttachmentRail(page);\n this.attribute = new AttributeRail(page);\n this.cancelButton = this.page.getByTestId('task-action-cancel');\n this.commentBox = this.page.getByTestId('task-action-comment');\n this.confirm = this.page.locator('.popper-action-buttons').getByTestId('dot-button');\n this.config = new ConfigRail(page);\n this.condition = new ConditionRail(page);\n this.completeButton = this.page.getByRole('button', { name: 'Complete', exact: true });\n this.failMenu = this.page.getByRole('menuitem', { name: 'Fail' });\n this.history = new HistoryRail(page);\n this.openMenu = this.page.getByRole('button', { name: 'arrow-down icon', exact: true });\n this.overview = new OverviewRail(page);\n this.retryButton = this.page.getByRole('button', { name: 'Retry' });\n this.scheduling = new SchedulingRail(page);\n this.startButton = this.page.getByTestId('single-action-button');\n this.skipMenu = this.page.getByRole('menuitem', { name: 'Skip' });\n this.taskDrawerLocator = this.page.locator('task-drawer .dot-drawer');\n }\n\n async waitForTaskDrawer(): Promise<void> {\n const handle = await this.page.locator('.dot-drawer-paper').elementHandle();\n await handle?.waitForElementState('stable');\n }\n\n async openOverviewRail(): Promise<void> {\n await this.openRail('Overview');\n }\n\n async openActivityRail(): Promise<void> {\n await this.openRail('Activity');\n }\n\n async openSchedulingRail(): Promise<SchedulingRail> {\n await this.openRail('Scheduling');\n return new SchedulingRail(this.page);\n }\n\n async openConditionRail(): Promise<void> {\n await this.openRail('Conditions');\n }\n\n async openAttributesRail(): Promise<void> {\n await this.openRail('Attributes');\n }\n\n async openAttachRail(): Promise<void> {\n await this.openRail('Attach');\n }\n\n async openTagsRail(): Promise<void> {\n await this.openRail('Tags');\n }\n\n async openHistoryRail(): Promise<void> {\n await this.openRail('History');\n }\n\n async openRail(rail: Rail): Promise<void> {\n await this.taskDrawerLocator.locator('.task-navigation-rail').getByText(rail).click();\n }\n\n async close(): Promise<void> {\n await this.taskDrawerLocator.locator('.task-drawer-header').getByTestId('close-btn').click();\n }\n\n async retryTask(comment: string): Promise<void> {\n await this.page.waitForTimeout(1000);\n await this.retryButton.click();\n await this.commentBox.fill(comment);\n await this.page.getByTestId('popper-test-id-content-wrapper').getByTestId('dot-button').click();\n }\n\n async skipTask(comment: string): Promise<void> {\n await this.openMenu.click();\n await this.skipMenu.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async failTask(comment: string): Promise<void> {\n await this.openMenu.click();\n await this.failMenu.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async completeTask(comment: string): Promise<void> {\n await this.completeButton.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async startNow(comment: string): Promise<void> {\n await this.startButton.click();\n await this.commentBox.fill(comment);\n await this.page.locator('button', { hasText: 'Start now' }).click();\n await expect(this.startButton).not.toBeVisible();\n }\n\n async startNowWithBlackout(comment: string): Promise<void> {\n await this.startButton.click();\n await this.commentBox.fill(comment);\n await expect(\n this.page.getByText('Are you sure you want to run this task during the blackout period?'),\n ).toBeVisible();\n await this.page.locator('button', { hasText: 'Start now' }).click();\n await expect(this.startButton).not.toBeVisible();\n }\n\n async expectTaskTitle(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task-drawer .task-title-input .dot-view-mode-typography')).toContainText(\n taskTitle,\n );\n }\n\n async expectCompleteButtonEnabled(): Promise<void> {\n await expect(this.completeButton).toBeEnabled();\n }\n\n async expectCompleteButtonNotEnabled(): Promise<void> {\n await expect(this.completeButton).not.toBeEnabled();\n }\n\n async expectButtonNotVisible(buttonName: string): Promise<this> {\n await expect(this.page.getByRole('button', { name: buttonName, exact: true })).not.toBeVisible();\n return this;\n }\n\n async expectSkipMenuNotEnabled(): Promise<void> {\n await this.openMenu.click();\n await expect(this.skipMenu).not.toBeEnabled();\n }\n\n async setTitle(title: string): Promise<void> {\n await this.page.getByTestId('task-title-input-view-mode-typography').click();\n await this.page.getByTestId('task-title-input-input').clear();\n await this.page.getByTestId('task-title-input-input').fill(title);\n await this.page.getByTestId('task-title-input-input').press('Enter');\n }\n\n async expectTaskTitleEditable(): Promise<this> {\n await this.page.getByTestId('task-title-input-view-mode-typography').click();\n await expect(this.page.getByTestId('task-title-input-input')).toBeEditable();\n return this;\n }\n\n async expectTypeToContain(taskType: string): Promise<void> {\n await expect(this.page.locator('.task-drawer .task-type')).toContainText(taskType);\n }\n\n async clickExpand(): Promise<void> {\n await this.page.getByRole('tooltip', { name: 'Expand' }).getByTestId('expand-btn').click();\n await expect(this.page.getByRole('tooltip', { name: 'Shrink' }).getByTestId('expand-btn')).toBeVisible();\n }\n\n async clickShrink(): Promise<void> {\n await this.page.getByRole('tooltip', { name: 'Shrink' }).getByTestId('expand-btn').click();\n await expect(this.page.getByRole('tooltip', { name: 'Expand' }).getByTestId('expand-btn')).toBeVisible();\n }\n\n async expectAssignedTo(username: string): Promise<void> {\n await expect(this.taskDrawerLocator.getByRole('button', { name: username })).toBeVisible();\n }\n\n async expectStartButtonToBeEnabled(isEnabled = true): Promise<void> {\n if (isEnabled) {\n await expect(this.startButton).toBeEnabled();\n } else await expect(this.startButton).not.toBeEnabled();\n }\n\n async startTask(comment: string): Promise<void> {\n await this.startButton.click();\n await this.completeButton.click();\n await this.commentBox.fill(comment);\n await this.completeButton.click();\n await expect(this.startButton).not.toBeVisible();\n }\n\n // Other locators are flaky and it can be replaced if we get locator change in the frontend\n async clickOnStartDate(): Promise<void> {\n await this.page.getByTestId('month-and-year').first().click();\n }\n\n async removeStartDate(): Promise<void> {\n await this.page.getByRole('button', { name: 'Set by user' }).locator('.MuiChip-deleteIcon').click();\n }\n\n async setStartDate(date: string): Promise<void> {\n await this.clickOnStartDate();\n await this.page.locator('.MuiPickersDay-root', { hasText: date }).click();\n }\n\n async assignToMe(userName: string, existingUsername: string): Promise<void> {\n await expect(async () => {\n await this.page\n .locator('.user-task-assigned-wrapper .editable')\n .getByText(existingUsername)\n .click({ timeout: 1000 });\n await this.page.getByTestId(`render-option-${userName}`).click({ timeout: 1000 });\n }).toPass();\n }\n\n async expectAssigneeToBeEnabled(): Promise<void> {\n await expect(this.page.locator('.user-task-assigned-wrapper .clickable-avatar')).toBeVisible();\n }\n\n async removeAssignToUser(userName: string): Promise<this> {\n await this.page.getByRole('button', { name: userName }).click();\n await this.page.getByRole('button', { name: 'Clear' }).click();\n return this;\n }\n\n async assignToTeam(existingTeamName: string, teamName: string): Promise<this> {\n await this.page.locator('.team-task-assigned-wrapper .editable').getByText(existingTeamName).click();\n await this.page.getByTestId(`render-option-${teamName}`).click();\n return this;\n }\n\n async expectAssignedToTeam(teamName: string): Promise<void> {\n await expect(this.page.getByRole('button', { name: teamName })).toBeVisible();\n }\n\n async removeAssignedTeam(teamName: string): Promise<this> {\n await this.page.locator('.team-task-assigned-wrapper .editable').getByText(teamName).click();\n await this.page.getByRole('button', { name: 'Clear' }).click();\n return this;\n }\n\n async setFlag(flagName: string, flagComment: string): Promise<void> {\n await this.page.getByTestId('flag-btn').click();\n await this.page.getByLabel(flagName).click();\n await this.page.getByPlaceholder('Set message').click();\n await this.page.getByPlaceholder('Set message').fill(flagComment);\n await this.page.getByPlaceholder('Set message').press('Enter');\n await expect(this.page.getByRole('button', { name: `flag icon ${flagComment}` })).toBeVisible();\n }\n\n async expectFlaggedWith(flagName: string, flagComment: string): Promise<void> {\n await this.page.getByRole('button', { name: 'flag icon' }).click();\n const regexPattern = new RegExp(`${flagComment}.*${flagName}`, 'i');\n await expect(this.page.getByText(regexPattern)).toBeVisible();\n }\n\n async expectStartDateToBeDisplayed(): Promise<void> {\n await expect(this.page.getByTestId('start-date-title')).toHaveCount(1);\n }\n\n async expectStartDayToBeInAvatar(expectedDay: string): Promise<void> {\n const startDayAvatar = this.page.locator(`.task-date-content .MuiAvatar-root[aria-label] `).nth(0);\n const startDay = await startDayAvatar.locator('..').locator('h3').textContent();\n expect(startDay?.trim()).toBe(expectedDay);\n }\n\n async expectEndDayToBeInAvatar(expectedDay: string): Promise<void> {\n const endDayAvatar = this.page.locator(`.task-date-content .MuiAvatar-root[aria-label] `).nth(1);\n const endDay = await endDayAvatar.locator('..').locator('h3').textContent();\n expect(endDay?.trim()).toBe(expectedDay);\n }\n\n async expectEndDateToBeDisplayed(): Promise<void> {\n await expect(this.page.getByTestId('end-date-title')).toHaveCount(1);\n }\n\n async expectStartDateAndEndDateToBeDisplayed(): Promise<void> {\n await expect(this.page.getByTestId('month-and-year')).toHaveCount(2);\n }\n\n async expectPhaseAndTaskTitleToContain(phaseName: string, taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task-header-top-path')).toContainText(phaseName);\n await this.expectTaskTitle(taskTitle);\n }\n\n async expectTaskStatusLine(statusLine: string): Promise<void> {\n await expect(this.taskDrawerLocator.locator(`.task-status-line`)).toHaveText(statusLine);\n }\n\n async expectTaskStatusLineHref(link: RegExp): Promise<void> {\n await expect(this.taskDrawerLocator.locator(`.task-status-line a`)).toHaveAttribute('href', link);\n }\n\n async expectNoTaskActionButton(): Promise<void> {\n await expect(this.page.locator('.task-action-buttons')).not.toBeVisible();\n }\n\n async clickTaskOptionIcon(): Promise<void> {\n await this.page.getByTestId('task-options-button').click();\n }\n\n async deleteTaskFromOption(): Promise<void> {\n await this.clickTaskOptionIcon();\n await this.page.getByText('Delete task').click();\n await expect(this.page.getByRole('heading', { name: 'Delete task' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async duplicateTaskFromOption(): Promise<void> {\n await this.clickTaskOptionIcon();\n await this.page.getByText('Duplicate').click();\n }\n\n async expectOptionNotVisible(option: string): Promise<void> {\n await this.clickTaskOptionIcon();\n await expect(this.page.getByText(option)).not.toBeVisible();\n }\n\n async refresh(): Promise<void> {\n await this.page.getByTestId('refresh-btn').click();\n }\n\n async expectRefreshButtonNotVisible(): Promise<void> {\n await expect(this.page.getByTestId('refresh-btn')).not.toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class ReleaseGanttPage extends WithPage {\n releaseHeader: Locator;\n taskDrawer: TaskDrawer;\n constructor(page: Page) {\n super(page);\n this.releaseHeader = this.page.locator('.release-header');\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async enableShowDates(): Promise<void> {\n await this.page.locator('#toggleIsDatesColumnsShown').check();\n }\n\n async disableShowDates(): Promise<void> {\n await this.page.locator('#toggleIsDatesColumnsShown').uncheck();\n }\n\n async expectPlanningDataColumnsHidden(): Promise<void> {\n expect(\n await this.page.locator(`#gantt .gantt_grid_data .gantt_row`).first().locator(`.gantt_cell`).count(),\n ).toEqual(1);\n }\n\n async expectPlanningDateColumnsShown(): Promise<void> {\n expect(\n await this.page.locator(`#gantt .gantt_grid_data .gantt_row`).first().locator(`.gantt_cell`).count(),\n ).toEqual(4);\n }\n\n async expectReleaseOnBreadcrumb(title: string): Promise<void> {\n await expect(this.page.getByRole('link', { name: title })).toBeVisible();\n }\n\n async expectPhaseDisplayed(phaseName: string): Promise<void> {\n await expect(this.page.getByTitle(phaseName, { exact: true })).toBeVisible();\n }\n\n async expectTaskDisplayed(taskName: string, isDisplayed = true): Promise<void> {\n if (isDisplayed) await expect(this.page.getByTitle(taskName)).toBeVisible();\n else await expect(this.page.getByTitle(taskName)).not.toBeVisible();\n }\n\n async expandGanttTree(title: string): Promise<void> {\n return await this.page.locator('.gantt_cell').filter({ hasText: title }).locator('.gantt_open').click();\n }\n\n async expectDifferentWidth(title1: string, title2: string): Promise<void> {\n const releaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title1, { exact: true })\n .getAttribute('style');\n const PhaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title2, { exact: true })\n .getAttribute('style');\n return expect(releaseWidth).not.toEqual(PhaseWidth);\n }\n\n async expectSameWidth(title1: string, title2: string): Promise<void> {\n const releaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title1, { exact: true })\n .getAttribute('style');\n const PhaseWidth = await this.page\n .locator(`.gantt_task_content`)\n .getByText(title2, { exact: true })\n .getAttribute('style');\n return expect(releaseWidth).toEqual(PhaseWidth);\n }\n\n async expectElementWithClasses(title: string, classes: Array<string>): Promise<void> {\n const eleNumber = await this.page\n .locator(`.${classes.join('.')}`)\n .locator(`.gantt_task_content`)\n .getByText(title, { exact: true })\n .count();\n return expect(eleNumber).toBe(1);\n }\n\n async resizeToDayIndex(title: string, index: number): Promise<void> {\n await this.page.locator(`#gantt .gantt_container .gantt_task_line`).filter({ hasText: title }).click();\n await this.page\n .locator(`.gantt_task_line`)\n .filter({ hasText: title })\n .locator(`.gantt_task_drag.task_right`)\n .hover();\n const objId = await this.page.locator(`.gantt_task_line`).filter({ hasText: title }).getAttribute('task_id');\n await this.page.mouse.down();\n await this.page.locator(`div[task_id='${objId}']`).locator('.gantt_task_cell').nth(index).hover();\n await this.page.mouse.up();\n }\n\n async expectLinksToBeDisplayed(countOfLinks: number): Promise<void> {\n expect(await this.page.locator('.gantt_task_link').count()).toEqual(countOfLinks);\n }\n\n async expectLeftHandleVisibility(title: string, visible: boolean): Promise<void> {\n const objId = await this.page.locator(`.gantt_task_line`).filter({ hasText: title }).getAttribute('task_id');\n if (visible) {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container ').locator(`div[task_id=\"${objId}\"].gantt-no-left-handle`),\n ).not.toBeVisible();\n } else {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container ').locator(`div[task_id=\"${objId}\"].gantt-no-left-handle`),\n ).toBeVisible();\n }\n }\n\n async expectRightHandleVisibility(title: string, visible: boolean): Promise<void> {\n const objId = await this.page.locator(`.gantt_task_line`).filter({ hasText: title }).getAttribute('task_id');\n if (visible) {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container').locator(`div[task_id='${objId}'].gantt-no-right-handle`),\n ).not.toBeVisible();\n } else {\n await this.page.locator('#gantt .gantt_container .gantt_task_line').filter({ hasText: title }).hover();\n await expect(\n this.page.locator('#gantt .gantt_container').locator(`div[task_id='${objId}'].gantt-no-right-handle`),\n ).toBeVisible();\n }\n }\n\n async openTaskDrawer(title: string): Promise<TaskDrawer> {\n await this.page.getByTitle(title).dblclick();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openPhaseDetails(phaseName: string): Promise<void> {\n await this.page.getByTitle(phaseName).dblclick();\n }\n\n getRow(phaseName: string): GanttRow {\n return new GanttRow(this.page, phaseName);\n }\n}\nclass GanttRow extends WithPage {\n private readonly phaseName: Locator;\n dateUtil: DateUtil;\n constructor(page: Page, phaseName: string) {\n super(page);\n this.phaseName = page.locator('.gantt_row').filter({ hasText: phaseName });\n this.dateUtil = new DateUtil(page);\n }\n\n private async getFirstDate(): Promise<Locator> {\n return this.phaseName.locator('.date-editor .date input').first();\n }\n\n private async getLastDate(): Promise<Locator> {\n return this.phaseName.locator('.date-editor .date input').last();\n }\n\n private async getFirstDateEditor(): Promise<Locator> {\n return this.phaseName.locator('.date-editor').first();\n }\n\n private async getLastDateEditor(): Promise<Locator> {\n return this.phaseName.locator('.date-editor').last();\n }\n\n async setStartDate(date?: string, monthYear?: string): Promise<void> {\n await (await this.getFirstDate()).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setEndDate(date?: string, monthYear?: string): Promise<void> {\n await (await this.getLastDate()).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async expectStartDateToBe(date: Date | string): Promise<void> {\n const dateTimePicker = this.getFirstDate();\n await this.dateUtil.expectDateToBe(await dateTimePicker, date);\n }\n\n async expectEndDateToBe(date: Date | string): Promise<void> {\n const dateTimePicker = this.getLastDate();\n await this.dateUtil.expectDateToBe(await dateTimePicker, date);\n }\n\n async removeStartDate(): Promise<void> {\n const dateTimePicker = await this.getFirstDateEditor();\n await this.dateUtil.removeDate(dateTimePicker);\n }\n\n async removeEndDate(): Promise<void> {\n const dateTimePicker = this.getLastDateEditor();\n await this.dateUtil.removeDate(await dateTimePicker);\n }\n\n async expectStartDateToBeInferred(): Promise<void> {\n const dateTimePicker = await this.getFirstDateEditor();\n await this.dateUtil.expectDateToBeInferred(dateTimePicker);\n }\n\n async expectEndDateToBeInferred(): Promise<void> {\n const dateTimePicker = await this.getLastDateEditor();\n await this.dateUtil.expectDateToBeInferred(dateTimePicker);\n }\n\n async expectStartDateNotDeletable(): Promise<void> {\n const dateTimePicker = await this.getFirstDate();\n await this.dateUtil.expectDateNotDeletable(dateTimePicker);\n }\n\n async expectEndDateNotDeletable(): Promise<void> {\n const dateTimePicker = await this.getLastDate();\n await this.dateUtil.expectDateNotDeletable(dateTimePicker);\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.phaseName.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async clickDuration(): Promise<void> {\n await this.phaseName.locator('.duration-editor').first().click();\n }\n\n async removeDuration(): Promise<void> {\n await this.phaseName.click();\n return await this.phaseName.locator(`.remove-duration`).click();\n }\n\n async expectNoDuration(): Promise<void> {\n expect(await this.phaseName.locator('.duration-editor').textContent()).toContain('');\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport moment from 'moment';\n\nexport class ReleasePropertiesPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async editReleaseName(name: string): Promise<void> {\n await this.page.locator('#release-form-title').clear();\n await this.page.locator('#release-form-title').fill(name);\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.task-description').hover();\n await this.page.locator('.display > .xl-icon').first().click();\n await this.page.locator('textarea').click();\n await this.page.locator('textarea').clear();\n await this.page.locator('textarea').fill(description);\n await this.page.getByText('Save').first().click();\n }\n\n async setScriptUsername(username: string): Promise<void> {\n await this.page.getByPlaceholder('Set user...').waitFor();\n await this.page.getByPlaceholder('Set user...').click();\n await this.page.locator('input[name=\"\"]').fill(username, { timeout: 2000 });\n }\n\n async setScriptUserPassword(password: string): Promise<void> {\n await this.page.locator('span[name=\"scriptUserPassword\"]').waitFor();\n await this.page.locator('span[name=\"scriptUserPassword\"]').click();\n await this.page.locator('input[name=\"scriptUserPassword\"]').fill(password, { timeout: 2000 });\n }\n\n async save(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).waitFor();\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.locator('.form-footer .last-saved')).toBeVisible();\n }\n\n async reset(): Promise<void> {\n await this.page.getByRole('button', { name: 'Reset' }).waitFor();\n await this.page.getByRole('button', { name: 'Reset' }).click();\n }\n\n async expectWithAttachment(filename: string): Promise<void> {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).toBeVisible();\n }\n\n async getAttachmentsListCount(): Promise<number> {\n return await this.page.locator('.attachments tr').count();\n }\n\n async uploadFile(filePath: string): Promise<void> {\n const fileChooserPromise = this.page.waitForEvent('filechooser');\n await this.page.locator('input[type=\"file\"]').click();\n const fileChooser = await fileChooserPromise;\n await fileChooser.setFiles(filePath);\n }\n\n async expectWithNoAttachment(filename: string): Promise<void> {\n const test = await this.page.locator('.attachments').isVisible();\n if (test) {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).not.toBeVisible();\n }\n }\n\n async downloadFile(filename: string): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n const downloadPromise1 = this.page.waitForEvent('download');\n await this.page.getByText(filename).click();\n const download = await downloadPromise1;\n // Wait for the download process to complete and save the downloaded file in given path.\n await download.saveAs('./core/xlr-ui/build/playwright/' + download.suggestedFilename());\n expect(download.suggestedFilename()).toBe(filename);\n }\n\n async deleteAttachment(fileName: string): Promise<void> {\n await this.page.getByRole('row', { name: fileName }).locator('span').click();\n await this.page.getByText('Remove').click();\n }\n\n async expectVariableDisplayed(variable: string, present: boolean): Promise<void> {\n if (present)\n await expect(this.page.locator(`#release-properties .form-group`, { hasText: variable })).toHaveCount(1);\n else await expect(this.page.locator(`#release-properties .form-group`, { hasText: variable })).toHaveCount(0);\n }\n\n async setScheduledStartDate(date?: string, monthYear?: string): Promise<void> {\n await this.page.locator(`.scheduled-start-date .date`).click();\n const prev = this.page.locator('.datepicker-days .prev');\n const next = this.page.locator('.datepicker-days .next');\n const monYear = this.page.locator('.datepicker-days .datepicker-switch');\n\n const thisMonth = moment(monthYear, 'MMMM YYYY').isBefore();\n\n while ((await monYear.textContent()) != monthYear) {\n if (thisMonth) {\n await prev.click();\n } else {\n await next.click();\n }\n }\n await this.page\n .getByRole('cell', { name: '' + date + '', exact: true })\n .first()\n .click();\n }\n\n async setScheduledStartTime(hrs?: string, mins?: string, meridian?: string): Promise<void> {\n await this.page.locator('.scheduled-start-date .time-picker-holder').click();\n if (typeof hrs !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-hour').click();\n await this.page.locator('.bootstrap-timepicker-hour').clear();\n await this.page.locator('.bootstrap-timepicker-hour').fill(hrs);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-minute').click();\n await this.page.locator('.bootstrap-timepicker-minute').clear();\n await this.page.locator('.bootstrap-timepicker-minute').fill(mins);\n }\n if (typeof meridian !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-meridian').click();\n await this.page.locator('.bootstrap-timepicker-meridian').clear();\n await this.page.locator('.bootstrap-timepicker-meridian').fill(meridian);\n }\n await this.page.keyboard.press('Escape');\n }\n\n async setDuration(days?: string, hours?: string, mins?: string): Promise<void> {\n await this.page.locator('.duration-editor').click();\n if (typeof days !== 'undefined') {\n await this.page.locator('.days').click();\n await this.page.locator('.days').clear();\n await this.page.locator('.days').fill(days);\n }\n if (typeof hours !== 'undefined') {\n await this.page.locator('.hours').click();\n await this.page.locator('.hours').clear();\n await this.page.locator('.hours').fill(hours);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.minutes').click();\n await this.page.locator('.minutes').clear();\n await this.page.locator('.minutes').fill(mins);\n }\n await this.page.keyboard.press('Escape');\n }\n\n async expectScheduledStartDateToBe(date: string): Promise<void> {\n expect(await this.page.locator(`.scheduled-start-date .date input`).getAttribute('value')).toContain(date);\n }\n\n async expectScheduledStartTimeToBe(date: string): Promise<void> {\n expect(await this.page.locator(`.scheduled-start-date .time input`).getAttribute('value')).toContain(date);\n }\n\n async expectDueDateToBe(date: string): Promise<void> {\n expect(await this.page.locator('.due-date .date input').getAttribute('value')).toContain(date);\n }\n\n async expectedDueDateTime(time: string): Promise<void> {\n expect(await this.page.locator('.due-date .time input').getAttribute('value')).toContain(time);\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.page.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async setDueDate(hrs?: string, min?: string, meridian?: string): Promise<void> {\n await this.page.locator('.due-date .time-picker-holder').click();\n if (typeof hrs !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-hour').click();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-hour').clear();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-hour').fill(hrs);\n }\n if (typeof min !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-minute').click();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-minute').clear();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-minute').fill(min);\n }\n if (typeof meridian !== 'undefined') {\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-meridian').click();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-meridian').clear();\n await this.page.locator('.bootstrap-timepicker-widget .bootstrap-timepicker-meridian').fill(meridian);\n }\n await this.page.keyboard.press('Escape');\n }\n\n async checkAbortOnFailure(): Promise<void> {\n await this.page.locator('#release-form-abort-on-failure').check();\n await expect(this.page.locator('#release-form-abort-on-failure')).toBeChecked();\n }\n\n async expectDescriptionToBe(description: string): Promise<void> {\n expect(await this.page.locator('.release-description p').textContent()).toContain(description);\n }\n\n async expectReleaseNameToBe(name: string): Promise<void> {\n await expect(this.page.locator('form[name=\"releasePropertiesForm\"]')).toContainText('Properties for ' + name);\n }\n\n async expectStartDateReadonly(): Promise<void> {\n await expect(\n this.page\n .locator('#release-properties .form-group')\n .filter({ hasText: 'Start date' })\n .locator('.date-editor.readonly'),\n ).toBeVisible();\n }\n\n async expectEndDateReadonly(): Promise<void> {\n await expect(\n this.page\n .locator('#release-properties .form-group')\n .filter({ hasText: 'End date' })\n .locator('.date-editor.readonly'),\n ).toBeVisible();\n }\n\n async setOwner(user: string): Promise<void> {\n await this.page.locator('.release-owner').click();\n await this.page.locator('.release-owner input').clear();\n await this.page.locator('.release-owner input').fill(user);\n }\n\n async expectPageTitleToBeInBreadcrumbLink(releaseName: string): Promise<void> {\n expect(await this.page.locator('.dot-breadcrumbs a').allTextContents()).toContain(releaseName);\n }\n\n async reloadPage(): Promise<void> {\n await this.page.reload({ timeout: 3000 });\n }\n\n async expectOwnerToBe(user: string): Promise<void> {\n await expect(this.page.locator('.release-owner')).toContainText(user);\n }\n\n async expectReleaseTaggedWith(tagName: string): Promise<void> {\n await expect(this.page.locator('#tags')).toContainText(tagName);\n }\n\n async expectTemplateTitleToBe(templateTitle: string): Promise<void> {\n await expect(this.page.locator('[data-test=\"created-from-template\"]')).toContainText(templateTitle);\n }\n\n async expectRiskProfileTitleToBe(riskProfile: string): Promise<void> {\n await expect(this.page.locator('[data-test=\"release-risk-profile\"]')).toContainText(riskProfile);\n }\n\n async expectStartFromReleaseToBe(parentRelease: string): Promise<void> {\n await expect(this.page.locator('.started-from-release')).toHaveText(parentRelease);\n }\n\n async expectTemplateURLToBe(templateURL: string): Promise<void> {\n expect(await this.page.locator('[data-test=\"created-from-template\"]').getAttribute('href')).toContain(templateURL);\n }\n\n async expectStartFromReleaseURLToBe(parentReleaseURL: string): Promise<void> {\n expect(await this.page.locator('.started-from-release').getAttribute('href')).toContain(parentReleaseURL);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ReleaseTeamsAndPermissionsPage extends WithPage {\n saveButton: Locator;\n resetButton: Locator;\n constructor(page: Page) {\n super(page);\n this.resetButton = this.page.getByRole('button', { name: 'Reset' });\n this.saveButton = this.page.getByRole('button', { name: 'Save' });\n }\n\n async expectSaveButtonDisabled(): Promise<void> {\n expect(this.saveButton).toBeDisabled();\n }\n\n async expectUserIsAssignedToTeam(teamName: string, userName: string): Promise<void> {\n const releaseAdminRow = this.page.locator('#teams-permissions-table tr', { hasText: teamName });\n await expect(releaseAdminRow.locator('span.tag-wrapper.tag-label', { hasText: userName })).toBeVisible();\n }\n}\n","import { WithPage } from '../WithPage';\nimport { Locator, Page, expect } from '@playwright/test';\nimport { DateUtil } from '../common/dateUtil';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class ReleaseTableViewPage extends WithPage {\n commentBox: Locator;\n contextMenuButton: Locator;\n completeButton: Locator;\n dateUtil: DateUtil;\n refreshButton: Locator;\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.commentBox = this.page.locator(`.input-block-level`);\n this.contextMenuButton = this.page.locator('#context-menu-container li');\n this.completeButton = this.page.getByTestId('release-grid-complete-btn');\n this.dateUtil = new DateUtil(page);\n this.refreshButton = this.page.getByTestId('refresh-btn');\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async openContextMenuForTask(taskTitle: string): Promise<void> {\n await this.page\n .locator('.name-cell-wrapper')\n .filter({ hasText: taskTitle })\n .locator('.context-menu-button')\n .click();\n }\n\n // eslint-disable-next-line max-params\n async callMenuOptionsForTask(\n taskTitle: string,\n option: string,\n taskGroup?: string,\n taskType?: string,\n ): Promise<void> {\n await expect(async () => {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText(option).click({ timeout: 1000 });\n }).toPass();\n if (await this.commentBox.isVisible()) {\n await this.commentBox.fill(' Automation Test Comment');\n } else if (await this.page.getByRole('heading', { name: 'Change task type' }).isVisible()) {\n await this.page.getByPlaceholder('Start typing to filter task').click();\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n await this.page.locator('#task-selector').fill(taskGroup);\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n await this.page.getByTestId(taskType).click();\n }\n if (await this.page.getByRole('button', { name: option, exact: true }).isVisible())\n await this.page.getByRole('button', { name: option, exact: true }).click();\n }\n\n async expectAssignToUser(taskTitle: string, username: string): Promise<void> {\n await this.refreshButton.click();\n expect(\n await this.page\n .locator('.ui-grid-row')\n .filter({ hasText: taskTitle })\n .locator(`span[display-user=\"row.entity.planItem.owner\"] span`)\n .textContent(),\n ).toContain(username);\n }\n\n async expectToHasGateIcon(taskTitle: string): Promise<void> {\n await expect(\n this.page.locator('.ui-grid-row').filter({ hasText: taskTitle }).locator('.marker-check-icon'),\n ).toBeVisible();\n }\n\n async expectTaskRowCountToBe(title: string, expectedCount: number): Promise<void> {\n await this.refreshButton.click();\n await expect(this.page.locator('.name-cell-title').filter({ hasText: title })).toHaveCount(expectedCount);\n }\n\n async setHeaderFilter(columnTitle: string, valueToFilter: string): Promise<void> {\n const filter = this.page.locator(`.ui-grid-header-cell`).filter({ hasText: columnTitle }).locator(`input`);\n await filter.clear();\n await filter.fill(valueToFilter);\n }\n\n async expectRowCountToBe(cellCount: number): Promise<void> {\n await expect(this.page.locator('.ui-grid-canvas .name-cell')).toHaveCount(cellCount);\n }\n\n async filterStartDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator(`.ui-grid-header-cell`).filter({ hasText: 'Start Date' }).locator(`input`).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async filterEndDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator(`.ui-grid-header-cell`).filter({ hasText: 'End Date' }).locator(`input`).click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async openTaskDrawer(taskTitle: string): Promise<TaskDrawer> {\n await this.page.locator('.name-cell-title').filter({ hasText: taskTitle }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async collapseNthRowByIndex(Indexnumber: number): Promise<void> {\n await this.page.locator('.task-group-toggle .xl-icon.arrow-down-icon').nth(Indexnumber).click();\n }\n\n async closePhaseModal(): Promise<void> {\n await this.page.locator(\"button[type='button'] i[class='xl-icon close-icon']\").click();\n }\n\n async expectTaskToHaveStatus(taskTitle: string, status: string): Promise<void> {\n await this.refreshButton.click();\n await expect(this.page.locator('.ui-grid-row').filter({ hasText: taskTitle }).locator('.label')).toContainText(\n status,\n );\n }\n\n async expectOverdueOnEndDate(taskTitle: string): Promise<void> {\n await expect(\n this.page.locator(`.ui-grid-row`).filter({ hasText: taskTitle }).locator(`i.xl-icon.delay-icon.overdue-icon`),\n ).toBeVisible();\n }\n\n async selectTask(taskTitle: string): Promise<void> {\n const checkboxLocator = this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: taskTitle })\n .locator(`input.item-selector`);\n await expect(async () => {\n await checkboxLocator.click({ force: true });\n await expect(checkboxLocator).toBeChecked({ timeout: 1000 });\n }).toPass();\n }\n\n async expectSelectedTasksCounter(text: string): Promise<void> {\n await expect(this.page.getByTestId('release-grid-selected-tasks')).toBeVisible();\n await expect(this.page.getByTestId('release-grid-selected-tasks')).toContainText(text);\n }\n\n async clearSelection(): Promise<this> {\n await this.page.getByTestId('release-grid-unselect-btn').click();\n return this;\n }\n\n async assignSelectedTasks(owner?: string, team?: string): Promise<this> {\n await this.page.getByText('Assign to').click();\n if (owner) {\n const ownerSelector = this.page.locator('.task-owner');\n await ownerSelector.focus();\n await ownerSelector.click();\n await this.page.getByLabel('*').fill(owner);\n await this.page.locator('a').filter({ hasText: owner }).click();\n }\n if (team) {\n const teamSelector = this.page.locator('.task-team > .display');\n await teamSelector.focus();\n await teamSelector.click();\n await this.page.getByLabel(team, { exact: true }).selectOption(team);\n }\n await this.page.getByRole('button', { name: 'Assign' }).click();\n return this;\n }\n\n async expectSuccessMessage(successMessage: string): Promise<this> {\n await expect(this.page.getByLabel('success')).toContainText(successMessage);\n return this;\n }\n\n async completeSelectedTasks(comment: string): Promise<this> {\n await this.completeButton.click();\n await this.page.getByPlaceholder('Give feedback or place a').fill(comment);\n await this.page.locator('.modal-footer').getByRole('button', { name: 'Complete' }).click();\n return this;\n }\n\n async selectFromMoreActions(menuItem: string): Promise<this> {\n await this.page.getByTestId('release-grid-dropdown-btn').click();\n await this.page.getByRole('menuitem', { name: menuItem }).click();\n\n if (['Skip', 'Reopen', 'Retry', 'Fail'].includes(menuItem)) {\n await this.commentBox.fill('Automation Test Comment');\n }\n await this.page.getByRole('button', { name: menuItem, exact: true }).click();\n return this;\n }\n\n async addCommentToSelectedTask(comment: string): Promise<this> {\n await this.page.getByTestId('release-grid-comment-btn').click();\n await this.page.getByPlaceholder('Give feedback or place a').click();\n await this.page.getByPlaceholder('Give feedback or place a').fill(comment);\n await this.page.getByRole('button', { name: 'Comment' }).click();\n await expect(this.page.getByLabel('success')).toBeVisible();\n return this;\n }\n\n async selectSubtasks(item: string): Promise<this> {\n await this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: item })\n .locator(`.tasks-group-select`)\n .click({ force: true });\n return this;\n }\n\n async shiftSelectFromTo(taskFrom: string, taskTo: string): Promise<this> {\n await this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: taskFrom })\n .locator(`.item-selector`)\n .click({ force: true });\n await this.page.keyboard.down('Shift');\n await this.page\n .locator(`.ui-grid-cell-contents`)\n .filter({ hasText: taskTo })\n .locator(`.item-selector`)\n .click({ force: true });\n await this.page.keyboard.up('Shift');\n return this;\n }\n\n async isContextualMenuItemEnabled(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await expect(this.contextMenuButton.filter({ hasText: menuName })).not.toHaveClass(/disabled/);\n await expect(this.contextMenuButton.filter({ hasText: menuName }).locator('a')).not.toBeDisabled();\n await this.closeContextMenu();\n }\n\n async isContextualMenuItemDisabled(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n const menuItem = this.contextMenuButton.filter({ hasText: menuName });\n await expect(menuItem).toHaveClass(/disabled/);\n const anchorTag = menuItem.locator('a');\n const disabledAttribute = await anchorTag.getAttribute('disabled');\n expect(disabledAttribute).not.toBeNull();\n await this.closeContextMenu();\n }\n\n async closeContextMenu(): Promise<void> {\n await this.page.locator('#release-header').click();\n }\n\n async expectDisabledActions(actionName: string): Promise<this> {\n await expect(this.page.getByTestId(`release-grid-${actionName}-btn`)).toBeDisabled();\n return this;\n }\n\n async expectDisabledActionsOnMoreActionsMenu(menuItem: Array<string> | string): Promise<this> {\n await this.page.getByTestId('release-grid-dropdown-btn').click();\n if (menuItem instanceof Array) {\n for (const val of menuItem) {\n await expect(this.page.getByRole('button', { name: val, exact: true })).toBeDisabled();\n }\n } else {\n await expect(this.page.getByRole('button', { name: menuItem, exact: true })).toBeDisabled();\n }\n await this.closeContextMenu();\n return this;\n }\n}\n","import * as fs from 'fs';\nimport path from 'path';\nimport { WithPage } from '../WithPage';\nimport { Locator, Page, expect } from '@playwright/test';\n\nexport class Util extends WithPage {\n tempDir: string;\n content: string;\n closeIcon: Locator;\n\n constructor(page: Page) {\n super(page);\n this.tempDir = '';\n this.content = '';\n this.closeIcon = this.page.locator('.xl-icon.close-icon');\n }\n\n async createTempFile(fileName: path.ParsedPath | string, testInfo: any): Promise<void> {\n const content = fileName.toString();\n const tempDir = testInfo.outputPath(fileName.toString());\n fs.promises.writeFile(tempDir, content, 'utf8');\n }\n\n async expandAllFolders(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('.rstm-toggle-icon.xl-icon.arrow-right-icon');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandAllFolders();\n }\n }\n await expect(icExpandTreeview1).not.toBeVisible();\n }\n\n async openSideNavMenu(menuItem: string): Promise<void> {\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).scrollIntoViewIfNeeded();\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).click();\n }\n\n async openNestedMenuItem(nestedMenuItem: string): Promise<void> {\n await this.page.locator('.MuiList-root li').getByText(nestedMenuItem, { exact: true }).scrollIntoViewIfNeeded();\n await this.page.locator('.MuiList-root li').getByText(nestedMenuItem, { exact: true }).click();\n }\n\n async clickCloseIcon(): Promise<void> {\n await this.closeIcon.click();\n }\n\n async clickOnStatusField(): Promise<void> {\n await this.page.locator('.ci-filter-status.ng-isolate-scope').click();\n }\n\n async clickOnStatus(statusNames: string[]): Promise<void> {\n await this.clickOnStatusClearAll();\n await this.clickOnStatusField();\n for (let i = 0; i < statusNames.length; i++) {\n await this.page.locator(`i.xl-icon.icon-s.checkbox[data='${statusNames[i]}']`).click();\n }\n // Clicking outside to close the grid dropdown\n await this.page.getByText('Status').click();\n }\n\n async clickOnStatusClearAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Clear all' }).click();\n await this.page.getByText('Status').click();\n }\n\n async clickOnStatusSelectAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Select all' }).click();\n await this.page.getByText('Status').click();\n }\n\n async setOrderBy(orderBy: string): Promise<void> {\n await this.page.locator('.order-by-filter .btn:first-child').click();\n await this.page.locator(`.order-by-filter .bootstrap-link:has-text('${orderBy}')`).click();\n }\n\n async setSearchFilter(filterText: string): Promise<void> {\n await this.page.locator('.searchFilter').fill(filterText);\n }\n\n async clearSearchFilter(): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n }\n\n async leaveWithoutSaving(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Confirm leave' })).toBeVisible();\n await expect(this.page.getByRole('paragraph')).toContainText('You have unsaved changes that will be lost.');\n await this.page.getByRole('button', { name: 'Leave without saving' }).click();\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { TriggersPage } from '../TriggersPage';\nimport { WithPage } from '../WithPage';\nimport { VariablePage } from '../variablePage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\nimport { ReleaseCreatePage } from './releaseCreatePage';\nimport { ReleaseGanttPage } from './releaseGanttPage';\nimport { ReleasePropertiesPage } from './releasePropertiesPage';\nimport { ReleaseTeamsAndPermissionsPage } from './releaseTeamsAndPermissionsPage';\nimport { ReleaseTableViewPage } from './releaseTableViewPage';\nimport { DateUtil } from '../common/dateUtil';\nimport { Util } from '../common/util';\n\nexport class ReleasePage extends WithPage {\n private defaultTimeout = 10_000;\n addPhaseBtn: Locator;\n createPage: ReleaseCreatePage;\n ganttPage: ReleaseGanttPage;\n tableView: ReleaseTableViewPage;\n taskDrawer: TaskDrawer;\n teamsPermissions: ReleaseTeamsAndPermissionsPage;\n phaseTitle: Locator;\n properties: ReleasePropertiesPage;\n variables: VariablePage;\n util: Util;\n\n constructor(page: Page) {\n super(page);\n this.addPhaseBtn = this.page.getByTestId('add-phase-btn');\n this.createPage = new ReleaseCreatePage(page);\n this.ganttPage = new ReleaseGanttPage(page);\n this.tableView = new ReleaseTableViewPage(page);\n this.taskDrawer = new TaskDrawer(page);\n this.teamsPermissions = new ReleaseTeamsAndPermissionsPage(page);\n this.phaseTitle = this.page.locator('.phase .phase-title');\n this.properties = new ReleasePropertiesPage(page);\n this.variables = new VariablePage(page);\n this.util = new Util(page);\n }\n\n async openTriggers(): Promise<TriggersPage> {\n await this.openSubPage('Triggers');\n return new TriggersPage(this.page);\n }\n\n async abort(comment = 'Abort for testing'): Promise<void> {\n await this.page.getByTestId('abort-btn').waitFor();\n await this.page.getByTestId('abort-btn').click();\n await this.page.getByPlaceholder('Provide a reason').fill(comment);\n await this.page.getByRole('button', { name: 'Abort' }).click();\n await this.page.locator('.progress-status-and-percentage').waitFor();\n await expect(this.page.locator('.progress-status-and-percentage')).toContainText('Aborted');\n }\n\n getPhase(phaseName: string): Phase {\n return new Phase(this.page, phaseName);\n }\n\n async expectPhaseCountToBe(expectedPhaseCount: number): Promise<void> {\n const phaseCount = await this.page.locator('.phase').count();\n expect(phaseCount).toBe(expectedPhaseCount);\n }\n\n async expectVariableToBeFound(variableName: string): Promise<void> {\n await expect(this.page.locator(`span.variable:has-text(\"${variableName}\")`)).toHaveCount(1);\n }\n\n async expectNotFlagged(): Promise<void> {\n await expect(this.page.locator('.flag-none-icon')).toBeHidden();\n }\n\n async expectRiskFlagOnTaskCard(): Promise<void> {\n await expect(this.page.locator('.risk-flag-icon')).toBeVisible();\n }\n\n async expectBlackoutIconOnTaskCard(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task').filter({ hasText: taskTitle }).locator('.circle-minus-icon')).toBeVisible();\n }\n\n async expectFlagOnCompletedTaskCard(): Promise<void> {\n await expect(this.page.locator('.flag-count')).toBeVisible();\n }\n\n async refresh(): Promise<void> {\n await this.page.reload();\n }\n\n async start(): Promise<void> {\n await this.page.getByTestId('start-btn').click();\n await this.page.getByRole('button', { name: 'Start' }).click();\n await expect(this.page.locator('.dot-dialog')).not.toBeVisible();\n await this.page.waitForSelector('#release');\n }\n\n async waitForCompletion(timeout = this.defaultTimeout): Promise<void> {\n await this.page.locator('#release.completed').waitFor({ timeout });\n }\n\n async waitForTaskCompleted(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.completed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskNeedsInput(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.waiting_for_input').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async waitForTaskCompletedInAdvance(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.completed_in_advance').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskInProgress(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskFailed(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.failed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskFailing(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.failing').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async waitForTaskSkipped(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.skipped').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskSkippedInAdvance(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.skipped_in_advance').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskAborted(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.aborted').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForStatusLine(statusLine: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task .status-line').getByText(statusLine, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async expectTaskStatusLineToContain(taskTitle: string, info: string): Promise<void> {\n await expect(this.page.locator('.task').filter({ hasText: taskTitle }).locator('.status-line')).toContainText(info);\n }\n\n async expectTaskStatusLineToContainHref(taskTitle: string, link: RegExp): Promise<void> {\n const taskInfo = this.page.locator('.task').filter({ hasText: taskTitle }).locator('.status-line a');\n await expect(taskInfo).toHaveAttribute('href', link);\n }\n\n async waitForTaskStarted(taskTitle: string, timeout = this.defaultTimeout): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByTitle(taskTitle, { exact: true })).toBeVisible({\n timeout,\n });\n }\n\n async waitForTaskPlanned(title: string): Promise<void> {\n await expect(this.page.locator('.task.planned').getByText(title, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async clickOnStatusLine(statusLine: string): Promise<void> {\n await this.page.locator('.task .status-line a').getByText(statusLine, { exact: true }).click();\n }\n\n async expectTaskCompletedInAdvance(taskTitle: string): Promise<void> {\n await expect(\n this.page.locator('#release-content .completed_in_advance .task-title').filter({ hasText: taskTitle }),\n ).toBeVisible();\n }\n\n async expectTaskPending(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.pending').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n\n async expectCurrentTaskToContain(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.active .task-title').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n\n async openManualTaskDetails(title: string): Promise<void> {\n await this.page.locator(`text=${title}`).click({ force: true });\n await expect(this.page.locator('div').filter({ hasText: title }).first()).toBeVisible();\n }\n\n async reopenTask(comment: string): Promise<void> {\n await this.page\n .locator('div')\n .filter({ hasText: /^Reopen$/ })\n .click();\n await this.page.getByTestId('task-action-comment').click();\n await this.page.getByTestId('task-action-comment').fill(comment);\n await this.page.locator('button', { hasText: 'Reopen' }).click();\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.task-header').getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromTableView(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.name-cell-title').getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromGrantt(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.gantt_tree_content').getByText(taskName, { exact: true }).dblclick();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openVariables(): Promise<void> {\n await this.util.openSideNavMenu('Variables');\n await expect(this.page.getByLabel('breadcrumb').getByText('Variables', { exact: true })).toBeVisible();\n }\n\n async openProperties(): Promise<void> {\n await this.util.openSideNavMenu('Properties');\n await expect(this.page.getByLabel('breadcrumb').getByText('Properties')).toBeVisible();\n }\n\n async openReleaseFlow(): Promise<void> {\n await this.util.openSideNavMenu('Flow');\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n\n async openRelationships(): Promise<void> {\n await this.util.openSideNavMenu('Relationships');\n await expect(this.page.getByLabel('breadcrumb').getByText('Relationships')).toBeVisible();\n }\n\n async openTeamsPermissions(): Promise<void> {\n await this.util.openSideNavMenu('Teams & Permissions');\n await expect(this.page.getByLabel('breadcrumb').getByText('Teams & Permissions')).toBeVisible();\n }\n\n async expectMembersToHavePermission(permission: string, ...roles: string[]): Promise<void> {\n const row = this.page.locator('tr', { has: this.page.locator('td', { hasText: permission }) });\n for (const roleName of roles) {\n const roleLocator = row.locator('li.tag', { hasText: roleName });\n await expect(roleLocator.first(), `Expected role \"${roleName}\" for permission \"${permission}\"`).toBeVisible();\n }\n }\n\n async expectMembersNotToHavePermission(permission: string, ...roles: string[]): Promise<void> {\n const row = this.page.locator('tr', { has: this.page.locator('td', { hasText: permission }) });\n for (const roleName of roles) {\n const roleLocator = row.locator('li.tag', { hasText: roleName });\n await expect(roleLocator.first(), `Expected role \"${roleName}\" for permission \"${permission}\"`).not.toBeVisible();\n }\n }\n\n async save(): Promise<void> {\n const saveButton = this.page.getByRole('button', { name: 'Save', exact: true });\n await saveButton.click();\n }\n\n async grantPermissionToRoles(permission: string, ...roles: string[]): Promise<void> {\n const row = this.page.locator('tr', { has: this.page.locator('td', { hasText: permission }) });\n for (const roleName of roles) {\n const roleLocator = row.locator('input[placeholder=\"Add...\"]');\n await roleLocator.first().click();\n await roleLocator.fill(roleName);\n await roleLocator.press('Enter');\n await expect(roleLocator.first(), `Expected role \"${roleName}\" for permission \"${permission}\"`).toBeVisible();\n }\n }\n\n async revokeMembersPermission(permission: string, ...roles: string[]): Promise<void> {\n const row = this.page.locator('tr', { has: this.page.locator('td', { hasText: permission }) });\n for (const roleName of roles) {\n const roleLocator = row.locator('li.tag', { hasText: roleName });\n const closeBtn = roleLocator\n .locator('a.tag-close, .tag-close, a > .xl-icon.close-icon, i.xl-icon.close-icon')\n .first();\n await expect(closeBtn, `Expected close button for role \"${roleName}\" to be visible`).toBeVisible();\n await closeBtn.click();\n await expect(roleLocator.first(), `Expected role \"${roleName}\" for permission \"${permission}\"`).not.toBeVisible();\n }\n }\n\n async expectResetIsEnabled(expected: boolean): Promise<void> {\n const resetButton = this.page.getByRole('button', { name: 'Reset' });\n if (expected) {\n await expect(resetButton).toBeEnabled();\n } else {\n await expect(resetButton).toBeDisabled();\n }\n }\n\n async expectPermissionsTableCount(locatorName: string): Promise<void> {\n const table = this.page.locator(locatorName);\n await expect(table).toHaveCount(1);\n }\n\n async openEditor(): Promise<this> {\n await this.openSubPage('Flow');\n return this;\n }\n\n async reset(): Promise<this> {\n const resetButton = this.page.getByRole('button', { name: 'Reset', exact: true });\n await resetButton.click();\n return this;\n }\n\n async openDashboard(): Promise<void> {\n await this.util.openSideNavMenu('Dashboard');\n await expect(this.page.getByLabel('breadcrumb').getByText('Dashboard')).toBeVisible();\n }\n\n async openHistory(): Promise<void> {\n await this.util.openSideNavMenu('History');\n await expect(this.page.getByLabel('breadcrumb').getByText('History')).toBeVisible();\n }\n\n private async openReleaseMenu(menuItem: string): Promise<void> {\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).click();\n }\n\n private async openSubPage(subpage: string): Promise<void> {\n await this.page.locator('ul.side-nav li', { hasText: subpage }).click();\n }\n\n async openTask(taskName: string): Promise<void> {\n await this.page.getByTitle(taskName, { exact: true }).click();\n }\n\n async collapseAllTaskView(): Promise<void> {\n const icCollapseTreeview1 = this.page.locator('div.pull-left.expander.ng-scope i.xl-icon.arrow-down-icon');\n for (const element of await icCollapseTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.collapseAllTaskView();\n }\n }\n }\n\n async expandAllTaskView(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('div.pull-left.expander.ng-scope i.xl-icon.arrow-right-icon');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandAllTaskView();\n }\n }\n }\n\n async expectTemplateLabelNotToBePresent(): Promise<void> {\n await expect(this.page.locator('.dot-chip').filter({ hasText: 'TEMPLATE' })).not.toBeVisible();\n }\n\n async expectAbortedStatusToBePresent(): Promise<void> {\n await this.page.locator('.progress-status-and-percentage').waitFor({ timeout: 10000 });\n await expect(this.page.locator('.progress-status-and-percentage')).toHaveText('Aborted');\n }\n\n async expectInProgressStatusToBePresent(): Promise<void> {\n await this.page.locator('.release-status').waitFor({ timeout: 10000 });\n await expect(this.page.locator('.release-status')).toHaveText('In progress');\n }\n\n async expectFailedStatusToBePresent(): Promise<void> {\n await this.page.locator('.progress-status-and-percentage').waitFor({ timeout: 10000 });\n await expect(this.page.locator('.progress-status-and-percentage')).toHaveText('Failed0%');\n }\n\n async openTableView(): Promise<void> {\n await this.util.openSideNavMenu('Table');\n await expect(this.page.locator('.release-grid-container')).toBeVisible();\n }\n\n async openPlannerView(): Promise<void> {\n await this.util.openSideNavMenu('Planner');\n await expect(this.page.locator('.gantt-container')).toBeVisible();\n }\n\n async expandGanttFolder(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('.gantt_tree_icon.gantt_open');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandGanttFolder();\n }\n }\n }\n\n async backToRelease(): Promise<void> {\n await this.page.locator('.icon-back').click();\n }\n\n async expectTitleToBeInBreadcrumbLink(title: string): Promise<void> {\n await expect(this.page.locator('.dot-breadcrumbs a', { hasText: title })).toBeVisible();\n }\n\n async expectHasPhase(title: string): Promise<void> {\n await expect(this.page.locator(`#release-content .phase-title`, { hasText: title })).toBeVisible();\n }\n\n async addNewPhase(phaseName?: string): Promise<void> {\n await this.addPhaseBtn.click();\n if (phaseName) {\n await this.phaseTitle.getByText('New Phase').click();\n await this.phaseTitle.getByRole('textbox').clear();\n await this.phaseTitle.getByRole('textbox').fill(phaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: phaseName })).toBeVisible();\n }\n }\n\n async renamePhase(oldPhaseName: string, newPhaseName: string): Promise<void> {\n await this.phaseTitle.getByText(oldPhaseName).click();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').clear();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').fill(newPhaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: newPhaseName })).toBeVisible();\n }\n\n async exportRelease(exportAs = 'Audit report (Excel)'): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n await this.page.getByTestId('template-export-btn').click();\n const downloadPromise = this.page.waitForEvent('download');\n await this.page.getByRole('link', { name: exportAs }).click();\n await downloadPromise;\n }\n\n async expectTaskToBePresent(taskName: string): Promise<void> {\n await expect(this.page.locator('.task .task-title').filter({ hasText: taskName })).toBeVisible();\n }\n\n async expectTaskNotToBePresent(taskName: string): Promise<void> {\n await expect(this.page.locator('.task .task-title').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async toggleTaskFilter(filterOption: string): Promise<void> {\n await this.clickFilterOptions();\n await this.page.locator(`#filter-container #${filterOption}`).click();\n await this.clickFilterOptions();\n }\n\n async clickFilterOptions(): Promise<void> {\n await this.page.locator('#release-header .dropdown-button').click();\n }\n\n async expectTaskToHaveFailed(title: string, failCount: number): Promise<void> {\n await expect(\n this.page.locator(`.task`).filter({ hasText: title }).locator(`.task-infos .failure-count.count-warning`),\n ).toBeVisible();\n await expect(\n this.page.locator(`.task`).filter({ hasText: title }).locator(`.task-infos .failure-count.count-warning`),\n ).toContainText(failCount.toString());\n }\n\n async expectTaskToHaveBeenDelayed(title: string): Promise<void> {\n await expect(\n this.page.locator(`.task`).filter({ hasText: title }).locator(`.task-infos .delay-count`),\n ).toBeVisible();\n }\n\n async expectOnePhaseDisplayed(): Promise<void> {\n expect(await this.page.locator('.phase-content').count()).toBe(1);\n }\n\n async restartPhases(): Promise<RestartPhaseModel> {\n await this.page.getByTestId('restart-btn').click();\n return new RestartPhaseModel(this.page);\n }\n\n async expectAddPhaseNotVisible(): Promise<void> {\n await expect(this.addPhaseBtn).not.toBeVisible();\n }\n\n async expectAddTaskNotVisible(): Promise<void> {\n await expect(this.page.locator('.add-task.link')).not.toBeVisible();\n }\n\n async expectTaskCount(count: number): Promise<void> {\n expect(await this.page.locator('.task-container').count()).toBe(count);\n }\n\n async expectCurrentTaskCount(count: number): Promise<void> {\n expect(await this.page.locator('.task.active').count()).toBe(count);\n }\n}\n\nclass Phase extends WithPage {\n private readonly phaseLocator: Locator;\n commentBox: Locator;\n contextMenuButton: Locator;\n dateUtil: DateUtil;\n\n constructor(page: Page, phaseName: string) {\n super(page);\n this.phaseLocator = page.locator('.phase', { hasText: phaseName });\n this.commentBox = this.page.locator(`.input-block-level`);\n this.contextMenuButton = this.page.locator('#context-menu-container li');\n this.dateUtil = new DateUtil(page);\n }\n\n async setTitle(title: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header .display').click();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').clear();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').fill(title);\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').blur();\n }\n\n async isMenuItemEnabled(menuName: string, taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n const menuItem = this.contextMenuButton.filter({\n has: this.page.locator('a').getByText(menuName, { exact: true }),\n });\n await expect(menuItem).not.toHaveClass(/disabled/);\n await this.closeContextMenu();\n }\n\n async isMenuItemDisabled(menuName: string, taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n const menuItem = this.contextMenuButton.filter({\n has: this.page.locator('a').getByText(menuName, { exact: true }),\n });\n await expect(menuItem).toHaveClass(/disabled/);\n await this.closeContextMenu();\n }\n\n async expectMenuItemIsNotVisible(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await expect(this.contextMenuButton.getByText(menuName, { exact: true })).not.toBeVisible();\n await this.closeContextMenu();\n }\n\n async expectMenuItemIsVisible(menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await expect(this.contextMenuButton.getByText(menuName, { exact: true })).toBeVisible();\n await this.closeContextMenu();\n }\n\n async expectSubmenuItemIsVisible(parentMenuItem: string, menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.contextMenuButton.getByText(parentMenuItem, { exact: true }).hover();\n await expect(\n this.page\n .locator(`#context-menu-container ul[data-id=\"${parentMenuItem}\"] li`)\n .getByText(menuName, { exact: true }),\n ).toBeVisible();\n await this.closeContextMenu();\n }\n\n async clickSubmenuItemForTask(parentMenuItem: string, menuName: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.contextMenuButton.getByText(parentMenuItem, { exact: true }).hover();\n await this.page\n .locator(`#context-menu-container ul[data-id=\"${parentMenuItem}\"] li a`)\n .getByText(menuName, { exact: true })\n .click();\n }\n\n async expectSnackbarSuccessMessage(message: string): Promise<void> {\n const snackbar = this.page.locator('.dot-snackbar[severity=\"success\"]');\n await expect(snackbar.locator('[aria-label=\"success\"]')).toHaveText(message);\n await snackbar.getByRole('button').click();\n }\n\n async closeContextMenu(): Promise<void> {\n await this.page.locator('#release-header').click();\n }\n\n async expectTaskBorderWithColor(taskName: string, color: string): Promise<void> {\n await expect(this.page.locator(`.task-box:has-text('${taskName}')`)).toHaveCSS('border-top-color', color);\n }\n\n async pasteTaskFromTaskGenerator(): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n const pasteButton = this.page.locator('button[data-testid=\"paste-copied-task-btn\"]');\n await expect(pasteButton).toBeEnabled();\n await pasteButton.click();\n }\n\n async addTaskInPhase(taskTitle: string, taskGroup: string, taskType: string): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.page.locator('#task-selector').hover();\n await this.page.locator('button[aria-label=\"Clear\"]').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.locator('.icon-close').click();\n await this.page.locator('#task-title').fill(taskTitle);\n await this.page.getByTestId('save-select-task-btn').click();\n await this.page.locator('#release-header').click();\n await expect(this.phaseLocator.locator('.task-title').filter({ hasText: taskTitle })).toBeVisible();\n }\n\n async getNumberOfTasks(): Promise<number> {\n return await this.phaseLocator.locator('.task').count();\n }\n\n async expectToHaveNoneditableTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title > span')).toContainText(phaseTitle);\n }\n\n async expectToHaveTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title')).toContainText(phaseTitle);\n }\n\n async openContextMenuForTask(taskTitle: string, group = false): Promise<void> {\n if (!group)\n await this.phaseLocator.locator('.task').filter({ hasText: taskTitle }).locator('.context-menu-button').click();\n else\n await this.phaseLocator\n .locator('.task-group .task')\n .filter({ hasText: taskTitle })\n .locator('.context-menu-button')\n .click();\n }\n\n async skipFromContextMenu(comment: string, taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Skip').click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Skip', exact: true }).click();\n }\n\n async completeFromContextMenu(taskTitle: string, comment: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Complete').click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Complete', exact: true }).click();\n }\n\n async changeTypeFromContextMenu(taskTitle: string, taskGroup: string, taskType: string): Promise<this> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Change type').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.getByRole('button', { name: 'Change type' }).click();\n return this;\n }\n\n async unlockFromContextMenu(taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n await this.page.locator('.dropdown-menu li').getByText('Unlock').click();\n await this.expectLockCheckMark(taskTitle, false);\n }\n\n async lockFromContextMenu(taskTitle: string, group = false): Promise<void> {\n await this.openContextMenuForTask(taskTitle, group);\n await this.page.locator('.dropdown-menu li').getByText('Lock').click();\n await this.expectLockCheckMark(taskTitle, true);\n }\n\n async expectChangeTypeContextMenuDisabled(taskTitle: string, taskGroup: string, taskType: string): Promise<this> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Change type').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await expect(this.page.getByRole('button', { name: 'Change type' })).toBeDisabled();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async expectGateCheckMark(): Promise<this> {\n await expect(this.page.locator('.task-type-gatetask .marker-check-icon')).toBeVisible();\n return this;\n }\n\n async expectLockCheckMark(taskTitle: string, isVisible = true): Promise<this> {\n if (isVisible) {\n await expect(\n this.page.locator('.task-header').filter({ hasText: taskTitle }).locator('.lock-icon'),\n ).toBeVisible();\n } else {\n await expect(\n this.page.locator('.task-header').filter({ hasText: taskTitle }).locator('.lock-icon'),\n ).not.toBeVisible();\n }\n return this;\n }\n\n async expectFailureHandlerCheckMar(taskTitle: string, isVisible = true): Promise<this> {\n if (isVisible) {\n await expect(\n this.page.locator('.task').filter({ hasText: taskTitle }).locator('.failure-handler-icon'),\n ).toBeVisible();\n } else {\n await expect(\n this.page.locator('.task').filter({ hasText: taskTitle }).locator('.failure-handler-icon'),\n ).not.toBeVisible();\n }\n return this;\n }\n\n async expectNoOptionInChangeType(taskTitle: string, taskGroup: string): Promise<this> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Change type').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await expect(this.page.getByText('No options')).toBeVisible();\n await this.page.getByTestId('ArrowDropDownIcon').click();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async assignToMeFromContextMenu(taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Assign to me').click();\n }\n\n async duplicateFromContextMenu(taskTitle: string): Promise<void> {\n await this.openContextMenuForTask(taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Duplicate').click();\n await expect(this.page.locator('.task .task-title').getByText(`${taskTitle} copy`)).toBeVisible();\n }\n\n async expectTemplateLabelNotToBePresent(): Promise<void> {\n await expect(this.page.locator('.dot-chip').filter({ hasText: 'TEMPLATE' })).not.toBeVisible();\n }\n\n async openPhaseDetails(): Promise<void> {\n await this.phaseLocator.locator('.phase-details').click();\n }\n\n async close(): Promise<void> {\n await this.page.locator(\"button[type='button'] i[class='xl-icon close-icon']\").click();\n }\n\n async expectStartDateToBeDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal .start-date')).toBeVisible();\n }\n\n async expectDueDateToBeDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal .due-date')).toBeVisible();\n }\n\n async expectEndDateToBeDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal .end-date')).toBeVisible();\n }\n\n async setTitleFromPhaseDetails(title: string): Promise<void> {\n await this.page.locator('h4.phase-title').click();\n await this.page.locator('h4.phase-title input').fill(title);\n await this.page.locator('h4.phase-title input').press('Enter');\n await expect(this.page.locator('h4.phase-title')).toContainText(title);\n }\n\n async setDueDateFromPhaseDetails(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.openDatePicker('.modal .due-date .date-editor');\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setScheduledStartDateFromPhaseDetails(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.openDatePicker('.modal .scheduled-start-date .date-editor');\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n await this.dateUtil.expectDurationToBe(duration);\n }\n\n async setDurationFromPhaseDetails(days?: string, hours?: string, mins?: string): Promise<void> {\n await this.page.locator('.duration-editor').click();\n await this.dateUtil.setDuration(days, hours, mins);\n }\n\n async expectDueTimeToBe(format: string, date: Date | string): Promise<void> {\n const selector = this.page.locator('.modal .due-date .time-picker-holder input');\n await this.dateUtil.expectTimeToBe(selector, format, date);\n }\n\n async deleteTaskInPhase(taskName: string): Promise<void> {\n await this.page.locator('.task').filter({ hasText: taskName }).locator('.xl-icon.options-icon').click();\n await this.page.locator('.remove-task-button').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Task' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.phaseLocator.locator('li').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async deletePhase(phaseName: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header').filter({ hasText: phaseName }).locator('.actions').hover();\n await this.phaseLocator.locator('.phase-header').filter({ hasText: phaseName }).locator('.delete-icon').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Phase' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.phaseLocator.locator('.phase-header').filter({ hasText: phaseName })).not.toBeVisible();\n }\n\n async expectCompletedPhase(): Promise<void> {\n await expect(this.page.getByText('View all completed phases')).toBeVisible();\n }\n\n async clickViewAllCompletedPhase(): Promise<void> {\n await this.page.getByText('View all completed phases').click();\n }\n\n async expectTaskToBePresent(taskName: string, visible = true): Promise<void> {\n if (visible)\n await expect(this.phaseLocator.locator('.task .task-title').filter({ hasText: taskName })).toBeVisible();\n else await expect(this.phaseLocator.locator('.task .task-title').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async expectContainingTask(taskName: string, exist = true): Promise<void> {\n const taskHeaderLocator = this.phaseLocator.locator('.task-header').filter({ hasText: taskName });\n if (exist) {\n await expect(taskHeaderLocator).toContainText(taskName);\n } else {\n await expect(taskHeaderLocator).not.toContainText(taskName);\n }\n }\n\n // eslint-disable-next-line max-params\n async addTaskInGroup(\n currentGroupType: string,\n taskTitle: string,\n taskGroup: string,\n taskType: string,\n ): Promise<void> {\n const groupTaskLocator = this.phaseLocator\n .locator('li')\n .filter({ hasText: currentGroupType })\n .locator('a.add-task.link');\n\n await groupTaskLocator.click();\n await this.page.locator('#task-selector').hover();\n await this.page.locator('button[aria-label=\"Clear\"]').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.locator('.icon-close').click();\n await this.page.locator('#task-title').fill(taskTitle);\n await this.page.getByTestId('save-select-task-btn').click();\n await this.page.locator('#release-header').click();\n await expect(this.phaseLocator.filter({ hasText: currentGroupType }).getByText(taskTitle)).toBeVisible();\n }\n\n async openContextMenuForTaskInGroup(groupName: string, taskTitle: string): Promise<void> {\n const taskLocator = this.phaseLocator\n .filter({ hasText: groupName })\n .locator('.task')\n .filter({ hasText: taskTitle });\n await taskLocator.locator('.task .context-menu-button').click();\n }\n\n async duplicateFromContextualMenuInGroup(groupName: string, taskTitle: string): Promise<this> {\n await this.openContextMenuForTaskInGroup(groupName, taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Duplicate').click();\n return this;\n }\n\n async deleteFromContextualMenuInGroup(groupName: string, taskTitle: string): Promise<this> {\n await this.openContextMenuForTaskInGroup(groupName, taskTitle);\n await this.page.locator('.dropdown-menu li').getByText('Delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n return this;\n }\n async duplicatePhase(): Promise<void> {\n await this.phaseLocator.locator('.duplicate-phase').click();\n }\n\n async expectActionsDisabled(): Promise<void> {\n await expect(this.phaseLocator.locator('.duplicate-phase')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.delete-phase')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.task .duplicate-task')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.task .delete-task')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.task-generator .add-task')).toHaveCount(0);\n await expect(this.phaseLocator.locator('.display')).toHaveCount(0);\n }\n\n async expectTaskFailureManualPermission(): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n const checkboxElement = await this.page.getByTestId('save-select-task-btn').isEnabled();\n if (!checkboxElement) {\n await this.page.getByTestId('cancel-select-task-btn').click();\n await this.phaseLocator.getByText('Add task').click();\n }\n await this.page.getByTestId('save-select-task-btn').click();\n await expect(\n this.page.locator('p').filter({ hasText: 'You don’t have permission to view this page.' }),\n ).toBeVisible();\n }\n\n async expectCurrentTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.active').count()).toBe(count);\n }\n\n async expectCompletedTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.completed').count()).toBe(count);\n }\n\n async expectFailedTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.failed').count()).toBe(count);\n }\n\n async expectFailingTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.failing').count()).toBe(count);\n }\n\n async expectSkippedTaskCount(count: number): Promise<void> {\n expect(await this.phaseLocator.locator('.task.skipped').count()).toBe(count);\n }\n}\n\nclass RestartPhaseModel extends WithPage {\n continueBtn: Locator;\n\n constructor(page: Page) {\n super(page);\n this.continueBtn = this.page.getByRole('button', { name: 'Continue' });\n }\n\n async fromPhase(phase: string): Promise<void> {\n await this.page.locator('.modal select[data-test=\"fromPhase\"]').selectOption(phase);\n }\n\n async fromTask(task: string): Promise<void> {\n await this.page.locator('.modal select[data-test=\"fromTask\"]').selectOption(task);\n }\n\n async expectNoTaskSelectorVisible(): Promise<void> {\n await expect(this.page.locator('.modal select[data-test=\"fromTask\"]')).not.toBeVisible();\n }\n\n async continue(): Promise<void> {\n await this.page.locator('.modal .continue').click();\n }\n\n async resumeNow(): Promise<void> {\n await this.page.locator('.modal .resume-now').click();\n }\n\n async resumeLater(): Promise<void> {\n await this.page.locator('.modal .resume-later').click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ApplicationsPage extends WithPage {\n async goToApplicationsPage(): Promise<this> {\n await this.page.goto('./#/applications');\n await expect(this.page).toHaveTitle('Applications - Digital.ai Release');\n return this;\n }\n\n async addNewApplication(applicationName: string): Promise<this> {\n await this.page.locator(`//button[normalize-space()='New application']`).click();\n await this.page.locator(`input[placeholder='Add name...']`).type(applicationName);\n await this.page.locator(`//button[normalize-space()='Save']`).click();\n return this;\n }\n\n async verifyApplicationisCreated(applicationName: string): Promise<this> {\n await this.page.waitForSelector(`div[title='${applicationName}'] strong`);\n return this;\n }\n\n async createApplicationAndLinkEnvironment(environmentName: string, applicationName: string): Promise<this> {\n await this.page.locator(`//button[normalize-space()='New application']`).click();\n await this.page.locator(`input[placeholder='Add name...']`).type(applicationName);\n await this.page.locator(\"input[placeholder='Filter environment name...']\").type(environmentName);\n await this.page.locator(`div[title='${environmentName}']`).click();\n await this.page.locator(`//button[normalize-space()='Save']`).click();\n await this.page.locator('i.xl-icon.close-icon').click();\n return this;\n }\n}\n","export class DataRandomGenerator {\n static codePointA = 65;\n static codePointZ = 90;\n\n static getString(): string {\n return Math.random().toString(36).substring(2);\n }\n\n static getNumber(min: number, max: number): number {\n return Math.floor(Math.random() * (max - min + 1) + min);\n }\n\n static getAlphabetsString(length: number): string {\n let alphabets = '';\n for (let i = 0; i < length; i++) {\n alphabets += String.fromCharCode(\n DataRandomGenerator.getNumber(DataRandomGenerator.codePointA, DataRandomGenerator.codePointZ),\n );\n }\n return alphabets;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { Util } from '../common/util';\n\nexport class DeliveryActivityLogsPage {\n constructor(private page: Page) {}\n rowSelector = '.activity-logs-table .dot-tbody .dot-tr:not(.loading-row)';\n\n async expectActivityLogEntry({ msg, user }: { msg?: string; user?: string }): Promise<this> {\n if (user) {\n await expect(this.page.locator(`${this.rowSelector}:has-text(\"${user}\")`).first()).toBeVisible();\n }\n if (msg) {\n await expect(this.page.locator(`${this.rowSelector}:has-text(\"${msg}\")`).first()).toBeVisible();\n }\n return this;\n }\n\n async expectCountToBe(count: number): Promise<this> {\n await expect(this.page.locator(this.rowSelector)).toHaveCount(count, { timeout: 1000 });\n return this;\n }\n\n async setSearchFilter(filterText: string): Promise<this> {\n const input = this.page.locator('input#activity-logs-filter');\n await input.fill('');\n const responsePromise = this.page.waitForResponse((resp) => resp.url().includes('/activity/'));\n await input.type(filterText);\n await responsePromise;\n return this;\n }\n}\n\nexport class FolderDeliveryPage extends WithPage {\n util: Util;\n addName: Locator;\n addDescription: Locator;\n searchForDelivery: Locator;\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n this.addName = page.locator('.xl-react-components input[placeholder=\"Add...\"]');\n this.addDescription = page.getByPlaceholder('Set description...');\n this.searchForDelivery = page.getByPlaceholder('Search for deliveries...', { exact: true });\n }\n\n async filterDeliveryByName(deliveryName: string): Promise<void> {\n await this.searchForDelivery.click();\n await this.searchForDelivery.clear();\n await this.searchForDelivery.fill(deliveryName);\n await this.searchForDelivery.press('Enter');\n await expect(\n this.page.locator('xlr-delivery-row').filter({ hasText: deliveryName }).getByRole('link').first(),\n ).toBeVisible();\n }\n\n async editDelivery(deliveryName: string, newDeliveryName: string): Promise<void> {\n await this.page\n .locator('xlr-delivery-row')\n .filter({ hasText: deliveryName })\n .locator('.fc-list-item-actions .edit-icon')\n .click();\n await this.util.openSideNavMenu('Properties');\n await this.addName.click();\n await this.addName.clear();\n await this.addName.fill(newDeliveryName);\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.locator('.saved-text')).toContainText('Last saved on ');\n }\n\n async deleteDelivery(deliveryName: string): Promise<void> {\n await this.page\n .locator('xlr-delivery-row')\n .filter({ hasText: deliveryName })\n .locator('.fc-list-item-actions .delete-icon')\n .click();\n await expect(this.page.getByText('Delete release delivery', { exact: true })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(\n this.page.locator('.success').filter({ hasText: 'Deleted release delivery successfully' }),\n ).toBeVisible();\n }\n\n async expectDeliveryDisplayed(deliveryName: string): Promise<void> {\n await expect(this.page.locator('.fc-list-item-title')).toContainText(deliveryName);\n }\n\n async openDeliveryLogs(deliveryId: string, filter?: Record<string, unknown>): Promise<DeliveryActivityLogsPage> {\n const deliveryLogs = await this.appendFilterQueryString(`#/deliveries/${deliveryId}/logs`, filter);\n await this.page.goto(deliveryLogs);\n return new DeliveryActivityLogsPage(this.page);\n }\n\n async appendFilterQueryString(url: string, filter?: Record<string, unknown>): Promise<string> {\n if (filter) {\n const queryString = (() => {\n const result = [];\n for (const key in filter) {\n const value = filter[key];\n if (value) {\n if (value === true) {\n result.push(`${key}`);\n } else {\n result.push(`${key}=${encodeURIComponent(String(value))}`);\n }\n }\n }\n\n return result;\n })().join('&');\n\n if (queryString) {\n url += `?${queryString}`;\n }\n }\n return url;\n }\n\n async openDeliveryTimeline(deliveryId: string, filter?: any): Promise<this> {\n const timelinePath = await this.appendFilterQueryString(`#/deliveries/${deliveryId}/timeline`, filter);\n await this.page.goto(timelinePath);\n return this;\n }\n\n async openDeliveryPatternActivityLogs(\n folderId: string,\n deliveryId: string,\n filter?: any,\n ): Promise<DeliveryActivityLogsPage> {\n const patternActivityLogs = await this.appendFilterQueryString(\n `#/folders/${folderId}/delivery-patterns/${deliveryId}/logs`,\n filter,\n );\n await this.page.goto(patternActivityLogs);\n await this.page.getByTestId('activity-logs-title-typography').waitFor({ state: 'visible' });\n return new DeliveryActivityLogsPage(this.page);\n }\n\n async openDeliveries(): Promise<void> {\n await this.page.goto('./#/deliveries');\n }\n\n async resetFilter(): Promise<void> {\n await Promise.all([\n this.page.waitForResponse((r) => r.url().includes('/api/v1/deliveries/search')),\n this.page.locator('navigation-sidebar, .navigation-sidebar').locator('li', { hasText: 'Deliveries' }).click(),\n ]);\n\n const clearAllLink = this.page.locator('a.xl-react-link:has-text(\"Clear all\")');\n if ((await clearAllLink.isVisible()) && !(await clearAllLink.isDisabled())) {\n await Promise.all([\n this.page.waitForResponse((r) => r.url().includes('/api/v1/deliveries/search')),\n clearAllLink.click(),\n ]);\n }\n\n await this.page.locator('.xl-react-components-input-full:visible').first().click();\n const input = this.page.locator('.react-tagsinput-input');\n await input.fill('In progress');\n\n const inputCheckbox = this.page.locator('[title=\"In progress\"] input[type=\"checkbox\"]');\n if (!(await inputCheckbox.isChecked())) {\n await Promise.all([\n this.page.waitForResponse((r) => r.url().includes('/api/v1/deliveries/search')),\n this.page.locator('[title=\"In progress\"] .checkbox').click(),\n ]);\n }\n\n await this.setOrderBy('Start date');\n await this.page.waitForSelector('.fc-list-loaded', { state: 'visible' });\n }\n\n async setOrderBy(orderBy: string): Promise<void> {\n await this.page.locator('.order-by-filter .btn:first-child').click();\n await this.page.locator(`.order-by-filter .bootstrap-link`, { hasText: orderBy }).click();\n await this.page.locator('.order-by-filter .btn:first-child').click();\n await this.page.waitForSelector('.fc-list-loaded', { state: 'visible' });\n }\n\n async openDeliveryFlow(title: string): Promise<void> {\n await this.filterDeliveryByName(title);\n await this.page\n .locator('xlr-delivery-row, .delivery-row')\n .filter({ hasText: title })\n .getByRole('link')\n .first()\n .click();\n }\n\n async completeStage(stageTitle: string, trackedItems: string[] = []): Promise<this> {\n const popup = this.page.locator(`[data-cy='popup-${stageTitle}']`);\n await popup.click();\n const popover = this.page.locator('.ant-popover:not(.ant-popover-hidden)');\n const completeOption = popover.locator('a:text(\"Complete\")');\n await completeOption.click();\n\n if (trackedItems.length > 0) {\n const trackedRows = this.page.locator('.tracked-item-row');\n await expect(trackedRows).toHaveCount(trackedItems.length);\n for (const item of trackedItems) {\n await expect(this.page.locator(`.tracked-item-row:has-text(\"${item}\")`)).toBeVisible();\n }\n }\n\n const confirmButton = this.page.locator('.confirmation-dialog button:text(\"Complete\")');\n await confirmButton.click();\n await expect(this.page.locator(`.label-completed:has-text(\"Completed\")`)).toBeVisible();\n return this;\n }\n\n async reopenStage(stageTitle: string): Promise<this> {\n const popup = this.page.locator(`[data-cy='popup-${stageTitle}']`);\n await popup.click();\n const popover = this.page.locator('.ant-popover:not(.ant-popover-hidden)');\n await popover.locator('a:text(\"Reopen\")').click();\n await this.page.locator('.confirmation-dialog button:text(\"Reopen\")').click();\n await expect(this.page.locator('.label-completed:has-text(\"Completed\")')).not.toBeVisible();\n return this;\n }\n\n async verifyStageContextMenuIsPresent(titles: string[]): Promise<void> {\n for (const title of titles) {\n const locator = this.page.locator(`[data-cy='popup-${title}']`);\n await expect(locator).toHaveCount(1);\n }\n }\n\n async openFolderPath(folderPath: string): Promise<void> {\n await this.page.goto(`./#/folders/${encodeURIComponent(folderPath)}/releases`);\n await this.page.waitForSelector('.folder-content, .folder-view', { state: 'visible' });\n }\n\n async openDeliveryFromFolder(title: string): Promise<void> {\n await this.page\n .locator('xlr-delivery-row, .release-row')\n .filter({ hasText: title })\n .getByRole('link')\n .first()\n .click();\n\n await this.page.waitForSelector('.delivery-flow, .flow-container', { state: 'visible' });\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { Util } from '../common/util';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\n\nexport class FolderGroupsPage extends WithPage {\n util: Util;\n newReleaseGroupButton: Locator;\n dateUtil: DateUtil;\n dateMonth: Date;\n\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n this.util = new Util(page);\n this.newReleaseGroupButton = page.getByText('New release group');\n this.dateMonth = new Date();\n }\n\n async createGroup(groupName: string, startDate?: string, endDate?: string): Promise<void> {\n await this.newReleaseGroupButton.click();\n await expect(this.page.getByText('Create new release group')).toBeVisible();\n await this.enterGroupName(groupName);\n const monthYear = await this.dateUtil.getCurrentMonthYear();\n if (startDate) await this.enterStartDate(startDate, monthYear);\n if (endDate) await this.enterEndDate(endDate, monthYear);\n await this.clickCreate();\n await this.expectSuccessMessageOnReleaseGroupCreation();\n }\n\n async addReleaseToGroup(releaseName: string): Promise<void> {\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Add release' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Add release' }).click({ force: true });\n await this.page.getByPlaceholder('Search for a release...').click();\n await this.page.getByPlaceholder('Search for a release...').fill(releaseName);\n await this.page.keyboard.press('Enter');\n await this.page\n .locator('release-list-modal-release-row')\n .filter({ hasText: releaseName })\n .getByRole('checkbox')\n .check();\n await this.page.getByRole('button', { name: 'Add' }).click();\n await this.expectSuccessMessageOnAddingReleaseToGroup();\n await expect(this.page.getByRole('link', { name: releaseName })).toBeVisible();\n }\n\n async editReleaseGroupName(newGroupName: string): Promise<void> {\n await this.page.locator('#title').click();\n await this.page.locator('#title').clear();\n await this.page.locator('#title').fill(newGroupName);\n await this.page.locator('.modal-footer .button.save').click();\n await this.expectSuccessMessageOnUpdatingGroup();\n }\n\n async enterGroupName(groupName: string): Promise<void> {\n await this.page.locator('#title').click();\n await this.page.locator('#title').fill(groupName);\n }\n\n async enterStartDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('.form-group').filter({ hasText: 'start date' }).locator('.date input').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async enterEndDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('.form-group').filter({ hasText: 'end date' }).locator('.date input').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async clickCreate(): Promise<void> {\n await this.page.getByRole('button', { name: 'Create' }).click();\n }\n\n async expectSuccessMessageOnReleaseGroupCreation(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Created release group successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async expectSuccessMessageOnAddingReleaseToGroup(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(\n this.page.locator('.success').filter({ hasText: 'Added release to release group successfully' }),\n ).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async expectSuccessMessageOnUpdatingGroup(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Updated release group successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async closeNotificationBanner(): Promise<void> {\n const closeIcon = this.page.locator('.dot-alert-banner').getByTestId(`CloseIcon`);\n if (await closeIcon.isVisible()) {\n await closeIcon.click();\n }\n }\n\n async searchReleaseGroupByTitle(title: string): Promise<void> {\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).click();\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).fill(title);\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).press('Enter');\n await expect(this.page.locator('.fc-list-item-title')).toContainText(title);\n }\n\n async deleteReleaseGroup(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.success').filter({ hasText: 'Deleted release group successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async clickReleaseGroupEdit(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-update').click();\n }\n\n async clickSave(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n\n async clickCancel(): Promise<void> {\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n }\n\n async clickOnStatusField(): Promise<void> {\n await this.page.locator('.ci-filter-status.ng-isolate-scope').click();\n }\n\n async statusFilter(statusNames: string[]): Promise<void> {\n await this.clickOnStatusClearAll();\n await this.clickOnStatusField();\n for (let i = 0; i < statusNames.length; i++) {\n await this.page.locator(`i.xl-icon.icon-s.checkbox[data='${statusNames[i]}']`).click();\n }\n }\n\n async clickOnStatusClearAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Clear all' }).click();\n }\n\n async clickOnStatusSelectAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Select all' }).click();\n }\n}\n","interface BaseConfigurationItem {\n id: string;\n type: string;\n}\n\ninterface PlanItem extends BaseConfigurationItem {\n title?: string;\n}\n\nexport interface Release extends PlanItem {\n allowConcurrentReleasesFromTrigger: boolean;\n attachments: Array<Attachment>;\n autoStart: boolean;\n description: string;\n dueDate?: Date;\n endDate?: Date;\n extensions: Array<ReleaseExtension>;\n flagStatus?: string;\n owner?: string;\n passwordVariableValues?: VariableValues;\n phases: Array<Phase>;\n plannedDuration: number;\n queryableEndDate?: Date;\n queryableStartDate?: Date;\n realFlagStatus?: string;\n scheduledStartDate?: Date;\n scriptUserPassword?: string;\n scriptUsername?: string;\n startDate?: Date;\n status: ReleaseStatus;\n summary?: Dashboard;\n tags?: Array<string>;\n teams: Array<Team>;\n variableValues?: VariableValues;\n variables: Array<Variable>;\n}\n\ntype VariableValues = Record<string, any>;\n\nexport interface Variable extends BaseConfigurationItem {\n description?: string;\n folderId?: any;\n key: string;\n label?: string;\n multiline?: boolean;\n referencedType?: string;\n requiresValue?: boolean;\n showOnReleaseStart?: boolean;\n value?: unknown;\n valueProvider?: VariableValueProvider;\n}\n\nexport interface VariableValueProvider {\n id: string;\n type?: string;\n values?: unknown;\n variable: string;\n}\n\nexport interface Duration {\n days: number;\n hours: number;\n month: number;\n}\n\nexport interface Container extends PlanItem {\n tasks: Array<Task>;\n}\n\nexport interface Phase extends Container {\n color: string;\n description: string;\n dueDate?: Date;\n endDate?: Date;\n plannedDuration: number;\n scheduledStartDate?: Date;\n startDate: Date;\n status: PhaseStatus;\n}\n\nexport interface Dependency extends PlanItem {\n archivedAsResolved: boolean;\n archivedTargetId: string;\n archivedTargetTitle: string;\n target: {\n id: string;\n type: string;\n };\n targetId: string;\n}\nexport interface Folder extends PlanItem {\n children?: Array<Folder>;\n teams?: Array<FixtureTeam>;\n variables?: Array<Variable>;\n}\n\nexport interface Task extends PlanItem {\n addresses: Array<string>;\n attachments: Array<Attachment>;\n body?: string;\n comments: Array<Comment>;\n conditions: Array<Condition>;\n delayDuringBlackout: boolean;\n dependencies: Array<Dependency>;\n description?: string;\n dueDate?: Date;\n endDate?: Date;\n failuresCount: number;\n flagStatus?: string;\n folderId?: string;\n links: Array<Link>;\n locked: boolean;\n newReleaseTitle?: string;\n originalScheduledStartDate: string;\n owner?: string;\n plannedDuration: number;\n precondition: string;\n pythonScript?: PythonScript;\n scheduledStartDate?: Date;\n script: string;\n startDate?: Date;\n status: TaskStatus;\n subject?: string;\n tags?: Array<string>;\n tasks: Array<Task>;\n team: string;\n templateId?: string;\n templateVariables?: Array<Variable>;\n variableMapping: VariableValues;\n variables?: Array<Variable>;\n waitForScheduledStartDate?: boolean;\n}\n\ninterface Condition extends PlanItem {\n checked?: boolean;\n}\n\ntype Link = PlanItem;\n//type Comment = PlanItem;\ntype Attachment = PlanItem;\n\ninterface Comment extends PlanItem {\n author?: string;\n date?: Date;\n text?: string;\n}\n\nexport interface Dashboard extends BaseConfigurationItem {\n owner?: string;\n parentId?: string;\n tiles: Array<Tile>;\n title?: string;\n}\n\ntype ReleaseExtension = BaseConfigurationItem;\n\nexport interface Tile extends BaseConfigurationItem {\n col: number;\n password?: string;\n row: number;\n title: string;\n username?: string;\n variableMapping: Record<string, any>;\n width: number;\n}\n\ninterface PythonScript extends BaseConfigurationItem {\n customScriptTask: string;\n password?: string;\n result: string;\n stringList: Array<string>;\n stringMap: Map<string, string>;\n stringSet: Set<string>;\n}\n\ntype ReleaseStatus = 'TEMPLATE' | 'PLANNED' | 'IN_PROGRESS' | 'PAUSED' | 'FAILING' | 'FAILED' | 'COMPLETED' | 'ABORTED';\ntype PhaseStatus = 'PLANNED' | 'IN_PROGRESS' | 'COMPLETED' | 'FAILING' | 'FAILED' | 'SKIPPED' | 'ABORTED';\ntype TaskStatus =\n | 'IN_PROGRESS'\n | 'PLANNED'\n | 'SKIPPED_IN_ADVANCE'\n | 'COMPLETED_IN_ADVANCE'\n | 'COMPLETED'\n | 'SKIPPED'\n | 'ABORTED'\n | 'PENDING'\n | 'FACET_CHECK_IN_PROGRESS'\n | 'FAILED'\n | 'FAILING'\n | 'FAILURE_HANDLER_IN_PROGRESS'\n | 'ABORT_SCRIPT_IN_PROGRESS'\n | 'PRECONDITION_IN_PROGRESS'\n | 'QUEUED'\n | 'ABORT_SCRIPT_QUEUED'\n | 'WAITING_FOR_INPUT'\n | 'FAILURE_HANDLER_QUEUED';\n\nexport interface Team extends BaseConfigurationItem {\n members: Array<string> | Array<principals>;\n permissions: Array<string>;\n roles?: Array<FixtureRoles>;\n teamName: string;\n}\n\nexport type FixtureTeam = Omit<Team, 'id'>;\n\nexport interface principals {\n name: string;\n type: string;\n}\n\ntype FeatureType = 'xlrelease.TaskDrawer'; // add more as needed\nexport interface FixtureFeature {\n enabled: boolean;\n id: string;\n type: FeatureType;\n}\n\ntype DeepPartial<T> = {\n [P in keyof T]?: DeepPartial<T[P]>;\n};\n\n// for fixtures we allow releases with everything optional expect the `id`\nexport type FixtureRelease = DeepPartial<Release> & Pick<Release, 'id'>;\n\nexport interface FixtureConfiguration extends PlanItem {\n accessTokenUrl?: string;\n address?: string;\n apiToken?: string;\n authenticationMethod?: string;\n clientId?: string;\n folderId?: string;\n password?: string;\n port?: number;\n proxyHost?: string;\n proxyPassword?: string;\n proxyPort?: string;\n proxyUsername?: string;\n scriptLocation?: string;\n url?: string;\n username?: string;\n}\n\nexport interface FixtureCi extends PlanItem {\n apiToken?: string;\n defaultProfile?: boolean;\n documentationPage?: string;\n enabled?: boolean;\n externalIdLabel?: string;\n url?: string;\n username?: string;\n}\n\nexport interface FixtureTrigger extends PlanItem {\n count?: number;\n description?: string;\n enabled?: boolean;\n folderId?: string;\n gitRepository?: string;\n jql?: string;\n password?: string;\n periodicity?: number | string;\n pollType?: string;\n releaseTitle: string;\n server?: string;\n template: string;\n username?: string;\n}\n\nexport interface FixtureActivityLog extends PlanItem {\n activityType: string;\n eventTime: Date;\n id: string;\n message: string;\n targetId?: string;\n type: string;\n username: string;\n}\n\nexport interface FixtureRoles {\n principals?: Array<string>;\n role?: Array<FixtureRole>;\n}\n\nexport interface FixtureRole {\n id: number;\n name: string;\n}\n\nexport interface FixturePermissions {\n permissions?: Array<string>;\n role?: Array<FixtureRole>;\n}\n\nexport interface FixtureGlobalRole {\n id: string | null;\n name: string;\n permissions: Array<string>;\n principals: Array<FixturePrincipal>;\n}\n\nexport interface FixturePrincipal {\n fullname: string;\n username: string;\n}\n\nexport interface ReleaseGroup extends PlanItem {\n endDate: Date;\n folderId: string;\n releaseIds?: Array<string>;\n startDate: Date;\n}\n\nexport interface RiskProfile extends PlanItem {\n riskProfileAssessors?: Array<RiskProfile>;\n}\n\nexport interface Delivery extends PlanItem {\n deliveryPattern?: string;\n endDate?: Date;\n folderId: string;\n patternId?: string;\n patternTitle?: string;\n plannedDuration?: number;\n shouldResetPattern?: boolean;\n stages: Array<Stage>;\n startDate?: Date;\n status?: string;\n trackedItems?: Array<TrackedItem>;\n transitions?: Array<Transition>;\n}\n\nexport interface Stage {\n description?: string;\n endDate?: Date;\n id?: null | string;\n items?: Array<Task>;\n plannedDuration?: number;\n startDate?: Date;\n status?: string;\n title?: string;\n transition?: Transition;\n type: string;\n}\n\nexport interface Transition {\n id?: null | string;\n title?: string;\n type: string;\n}\n\nexport interface TrackedItem extends PlanItem {\n createdDate: Date;\n description?: string;\n endDate?: Date;\n folderId?: string;\n owner?: string;\n startDate?: Date;\n status?: string;\n}\n\nexport interface Reservation {\n applications?: Array<ApplicationFixture> | string;\n endDate: string;\n environment: Array<EnvironmentFixture> | string;\n id?: null | string;\n note?: string;\n startDate: string;\n type?: string;\n}\n\nexport interface ApplicationFixture {\n environments?: Array<EnvironmentFixture>;\n folderId?: string | null;\n id?: string | null;\n title?: string;\n type?: string;\n}\n\nexport interface EnvironmentFixture {\n description?: string;\n folderId?: string | null;\n id: null | string;\n labels?: Array<Label>;\n stage?: Stage;\n title?: string;\n type?: string;\n}\n\nexport interface Label extends PlanItem {\n color: string;\n title: string;\n}\n\nexport interface Facet extends BaseConfigurationItem {\n analysisDate?: string;\n applicationId?: Array<ApplicationFixture> | string;\n build?: string;\n build_url?: string;\n complianceData?: string;\n createdBy?: string;\n creationDate?: string;\n duration?: string;\n endDate?: string;\n environmentId?: Array<EnvironmentFixture> | string;\n outcome?: string;\n priority?: string;\n project?: string;\n project_url?: string;\n record?: string;\n record_url?: string;\n serverUrl?: string;\n serverUser?: string;\n startDate?: string;\n status?: string;\n targetId?: string;\n ticket?: string;\n ticketType?: string;\n ticket_url?: string;\n title?: string;\n updatedDate?: string;\n version?: string;\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { Util } from '../common/util';\nimport { Duration } from '../../types';\n\nexport class FolderPatternPage extends WithPage {\n util: Util;\n addName: Locator;\n addDescription: Locator;\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n this.addName = page.locator('.xl-react-components input[placeholder=\"Add...\"]');\n this.addDescription = page.getByPlaceholder('Set description...');\n }\n\n async clickNewDeliveryPattern(): Promise<void> {\n await this.page.getByRole('button', { name: 'New delivery pattern' }).click();\n await expect(this.page.getByRole('heading', { name: 'Create delivery pattern' })).toBeVisible();\n }\n\n async setPatternName(patternName: string): Promise<void> {\n await this.addName.click();\n await this.addName.clear();\n await this.addName.fill(patternName);\n }\n\n async setPatternDescription(patternDescription: string): Promise<void> {\n await this.page.getByPlaceholder('Set description...').click();\n await this.page.getByPlaceholder('Set description...').clear();\n await this.page.getByPlaceholder('Set description...').fill(patternDescription);\n }\n\n async enableAutoComplete(): Promise<void> {\n await this.page.getByRole('checkbox').check();\n }\n\n async disableAutoComplete(): Promise<void> {\n await this.page.getByRole('checkbox').uncheck();\n }\n\n async setDuration({ month, days, hours }: Duration): Promise<void> {\n await this.page.getByRole('group', { name: 'Pattern details' }).getByRole('textbox').click();\n await this.page.locator('input[name=\"months\"]').click();\n await this.page.locator('input[name=\"months\"]').fill(month.toString());\n await this.page.locator('input[name=\"days\"]').click();\n await this.page.locator('input[name=\"days\"]').fill(days.toString());\n await this.page.locator('input[name=\"hours\"]').click();\n await this.page.locator('input[name=\"hours\"]').fill(hours.toString());\n }\n\n async createNewPattern(patternName: string, patternDescription: string, duration?: Duration): Promise<void> {\n await this.clickNewDeliveryPattern();\n await this.setPatternName(patternName);\n await this.setPatternDescription(patternDescription);\n if (duration) {\n await this.setDuration(duration);\n }\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' }).click({ force: true });\n await expect(this.page.getByLabel('breadcrumb').getByText('Delivery flow')).toBeVisible();\n }\n\n async clickEditPatternIcon(patternName: string): Promise<void> {\n await this.page.locator('.delivery-pattern-row').filter({ hasText: patternName }).locator('.edit').click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Delivery flow')).toBeVisible();\n }\n\n async clickCopyPatternIcon(patternName: string): Promise<void> {\n await this.page.locator('.delivery-pattern-row').filter({ hasText: patternName }).locator('.copy').click();\n await expect(this.page.getByText('Copy delivery pattern')).toBeVisible();\n }\n\n async filterPatternByName(patternName: string): Promise<void> {\n await this.page.getByPlaceholder('Filter by name...').click();\n await this.page.getByPlaceholder('Filter by name...').clear();\n await this.page.getByPlaceholder('Filter by name...').fill(patternName);\n await this.page.getByPlaceholder('Filter by name...').press('Enter');\n }\n\n async openProperties(): Promise<Properties> {\n await this.util.openSideNavMenu('Properties');\n return new Properties(this.page);\n }\n\n async openTrackedItems(): Promise<Properties> {\n await this.util.openSideNavMenu('Tracked items');\n return new Properties(this.page);\n }\n\n async addTrackedItem(trackedItemName: string): Promise<Properties> {\n await this.page.getByRole('button', { name: 'Add tracked item' }).click();\n await this.page.getByPlaceholder('Add...').fill(trackedItemName);\n await this.page.getByRole('button', { name: 'Create' }).click();\n await expect(this.page.getByText(trackedItemName)).toBeVisible();\n return new Properties(this.page);\n }\n\n async editTrackedItemName(oldName: string, newName: string): Promise<void> {\n // Open the edit modal for the given tracked item\n await this.page.locator('.track-panel', { hasText: oldName }).locator('.action-label', { hasText: 'Edit' }).click();\n\n // Wait for modal to be visible\n const modal = this.page.locator('.xl-react-modal .xl-react-modal-content');\n await expect(modal).toBeVisible();\n\n // Clear the input and type new name\n const nameInput = modal.locator('input[type=\"text\"]');\n await nameInput.clear();\n await nameInput.fill(newName);\n\n // Click Save\n await modal.locator('button.xl-react-button.button.primary', { hasText: 'Save' }).click();\n\n // Verify the updated name appears in the tracked items list\n await expect(this.page.locator('.track-panel')).toContainText(newName);\n }\n\n async back(): Promise<void> {\n await this.page.getByTestId('back-button').click();\n }\n\n async copyPattern(existingPatternName: string): Promise<void> {\n await this.clickCopyPatternIcon(existingPatternName);\n await this.page.getByRole('button', { name: 'Continue' }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Delivery flow')).toBeVisible();\n await expect(this.page.getByRole('link', { name: `${existingPatternName} (1)` })).toBeVisible();\n }\n\n async clickDeletePattern(patternName: string): Promise<void> {\n await this.page.locator('.delivery-pattern-row').filter({ hasText: patternName }).locator('.delete').click();\n await expect(this.page.getByText('Delete delivery pattern', { exact: true })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.delivery-pattern-row').filter({ hasText: patternName })).not.toBeVisible();\n }\n\n async expectPatternIsVisible(patternName: string): Promise<void> {\n await expect(this.page.locator('.delivery-pattern-row').filter({ hasText: patternName })).toBeVisible();\n }\n\n async expectPatternIsNotVisible(patternName: string): Promise<void> {\n await expect(this.page.locator('.delivery-pattern-row').filter({ hasText: patternName })).toBeHidden();\n }\n\n noPatternsMessageIsVisible(): Promise<void> {\n return expect(this.page.getByText('No delivery patterns found')).toBeVisible();\n }\n\n async createNewDelivery(deliveryName: string, deliveryDes?: string, setAutoComplete?: true): Promise<void> {\n await this.page.getByRole('button', { name: 'New delivery' }).click();\n await this.addName.fill(deliveryName);\n await this.addDescription.click();\n if (deliveryDes) await this.addDescription.fill(deliveryDes);\n else await this.addDescription.fill('Description');\n if (setAutoComplete) await this.page.getByRole('checkbox').check();\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Create' }).click({ force: true });\n await expect(this.page.locator('.MuiBreadcrumbs-li').getByRole('link', { name: `${deliveryName}` })).toBeVisible();\n }\n}\nclass Properties extends WithPage {\n addName: Locator;\n addDescription: Locator;\n constructor(page: Page) {\n super(page);\n this.addName = page.locator('.xl-react-components input[placeholder=\"Add...\"]');\n this.addDescription = page.getByPlaceholder('Set description...');\n }\n\n async editName(name: string): Promise<void> {\n await this.addName.click();\n await this.addName.clear();\n await this.addName.fill(name);\n }\n\n async editDescription(description: string): Promise<void> {\n await this.page.getByPlaceholder('Set description...').click();\n await this.page.getByPlaceholder('Set description...').clear();\n await this.page.getByPlaceholder('Set description...').fill(description);\n }\n\n async editDuration(month: number, days: number, hours: number): Promise<void> {\n await this.page.getByRole('group', { name: 'Pattern details' }).getByRole('textbox').click();\n await this.page.locator('input[name=\"months\"]').click();\n await this.page.locator('input[name=\"months\"]').fill(month.toString());\n await this.page.locator('input[name=\"days\"]').click();\n await this.page.locator('input[name=\"days\"]').fill(days.toString());\n await this.page.locator('input[name=\"hours\"]').click();\n await this.page.locator('input[name=\"hours\"]').fill(hours.toString());\n }\n\n async save(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n expect(await this.page.locator('.saved-text').textContent()).toContain('Last saved on ');\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { Util } from '../common/util';\nimport { WithPage } from '../WithPage';\n\nexport class FolderNotificationPage extends WithPage {\n inheritCheckbox: Locator;\n util: Util;\n constructor(page: Page) {\n super(page);\n this.inheritCheckbox = page.getByRole('checkbox');\n this.util = new Util(page);\n }\n\n async checkInheritNotifications(): Promise<void> {\n await this.inheritCheckbox.click();\n if (await this.page.getByText('Override notification settings').isVisible()) {\n await this.page.getByRole('button', { name: 'Ok' }).click();\n }\n await expect(this.page.getByRole('checkbox')).toBeChecked();\n await expect(this.page.locator('.xl-icon.edit-icon')).not.toBeVisible();\n }\n\n async uncheckInheritNotifications(): Promise<void> {\n await this.inheritCheckbox.dblclick();\n await expect(this.page.getByRole('checkbox')).not.toBeChecked();\n await expect(this.page.locator('.xl-icon.edit-icon').first()).toBeVisible();\n }\n\n async expectRecipientsNotToBeEditable(eventName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await expect(this.page.locator(`[data-test=\"${eventName}\"]`).getByText('Edit Message')).not.toBeVisible();\n }\n\n async deleteTeam(eventName: string, teamName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page\n .locator(`[data-test=\"${eventName}\"] div.role`)\n .filter({ hasText: teamName })\n .locator('a.tag-close')\n .click();\n }\n\n async expectEditMessageIsVisible(eventName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await expect(this.page.locator(`[data-test=\"${eventName}\"]`).getByText('Edit Message')).toBeVisible();\n }\n\n async addTeam(eventName: string, teamName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByPlaceholder('Add...').click();\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByPlaceholder('Add...').fill(teamName);\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByText(teamName).click();\n }\n\n async clickEditMessage(eventName: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page.locator(`[data-test=\"${eventName}\"]`).getByText('Edit Message').click();\n await expect(this.page.getByText('Edit message: Active task')).toBeVisible();\n }\n\n async editPriority(eventName: string, priority: string): Promise<void> {\n eventName = eventName.replace(/\\s+/g, '_').toUpperCase();\n await this.page.getByRole('combobox').locator('i').click();\n await this.page.getByRole('option', { name: priority }).click();\n await this.page.getByRole('button', { name: 'Save' }).click();\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { FolderDeliveryPage } from './folder/folderDeliveryPage';\nimport { FolderGroupsPage } from './folder/folderGroupPage';\nimport { FolderPatternPage } from './folder/folderPatternPage';\nimport { FolderNotificationPage } from './folder/folderNotificationPage';\nimport { Util } from './common/util';\nimport { VariablePage } from './variablePage';\nimport { WithPage } from './WithPage';\n\nexport class FolderPage extends WithPage {\n deliveryPage: FolderDeliveryPage;\n expandButton: Locator;\n notificationPage: FolderNotificationPage;\n patternPage: FolderPatternPage;\n folderGroupsPage: FolderGroupsPage;\n util: Util;\n variables: VariablePage;\n\n constructor(page: Page) {\n super(page);\n this.deliveryPage = new FolderDeliveryPage(page);\n this.expandButton = this.page.getByRole('button', { name: ' Expand' });\n this.folderGroupsPage = new FolderGroupsPage(page);\n this.notificationPage = new FolderNotificationPage(page);\n this.patternPage = new FolderPatternPage(page);\n this.util = new Util(page);\n this.variables = new VariablePage(page);\n }\n\n getFolderSearchInputLocator(): Locator {\n return this.page.locator('.folder-list .folder-list-search input');\n }\n\n async openFoldersPage(): Promise<this> {\n await this.page.goto('./#/folders');\n await expect(this.page).toHaveTitle('Folders / Home - Digital.ai Release');\n return this;\n }\n\n async backToAllFolders(): Promise<this> {\n await this.page.locator('.icon-back.dot-i').click();\n await expect(this.page).toHaveTitle('Folders - Digital.ai Release');\n return this;\n }\n\n async createFolder(folderName: string): Promise<this> {\n await this.page.getByRole('button', { name: ' Add folder' }).click();\n await expect(this.page.getByText('Create a new folder in root')).toBeVisible();\n await this.page.getByRole('textbox').fill(folderName);\n await this.page.getByRole('button', { name: 'Create' }).click();\n await expect(this.page.getByRole('link', { name: folderName })).toBeVisible();\n return this;\n }\n\n async openFolder(folderName: string): Promise<this> {\n await this.page.getByTitle(folderName).waitFor({ timeout: 1000 });\n await this.page.getByTitle(folderName).click();\n await expect(this.page.locator('.MuiBreadcrumbs-li').getByRole('link', { name: `${folderName}` })).toBeVisible();\n return this;\n }\n\n async openGroups(): Promise<FolderGroupsPage> {\n await this.util.openSideNavMenu('Groups');\n await expect(this.page.getByLabel('breadcrumb').getByText('Groups')).toBeVisible();\n return this.folderGroupsPage;\n }\n\n async createGroup(groupName: string): Promise<this> {\n await this.page.locator(\"//button[normalize-space()='New release group']\").click();\n await this.page.locator('#title').type(groupName);\n await this.page.locator(\"button[type='submit']\").click();\n return this;\n }\n\n async selectPlannedStatus(): Promise<this> {\n await this.page.locator('.remaining-tags').click();\n await this.page.locator('.xl-react-link:text-is(\"Clear all\")').click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.locator(`.yt-option[title=Planned]`).click();\n await this.page.locator(\"//span[normalize-space()='Status']\").click();\n return this;\n }\n\n async expectReleaseGroupisDisplayed(title: string): Promise<this> {\n //await this.page.locator(`.fc-list-item-title-wrapper .fc-list-item-title strong:text-is('${title}`).isVisible()\n await this.page.waitForSelector(`.fc-list-item-title-wrapper .fc-list-item-title strong:text-is('${title}')`);\n return this;\n }\n\n async createSubFolder(parentFolder: string, subFolderName: string): Promise<void> {\n await this.clickExpandButton();\n await this.page.getByRole('link', { name: parentFolder }).hover();\n await this.clickFolderOptions(parentFolder, 'add');\n await this.page.getByRole('textbox').fill(subFolderName);\n await this.page.getByRole('button', { name: 'Create' }).click();\n await expect(this.page.getByRole('link', { name: subFolderName })).toBeVisible();\n }\n\n async renameFolder(existingFolderName: string, newFolderName: string): Promise<void> {\n await this.clickExpandButton();\n await this.page.getByRole('link', { name: existingFolderName }).hover();\n await this.clickFolderOptions(existingFolderName, 'edit');\n await this.page.getByRole('tab', { name: existingFolderName }).getByRole('textbox').fill(newFolderName);\n await this.page.keyboard.press('Enter');\n await expect(this.page.getByRole('link', { name: newFolderName })).toBeVisible();\n }\n\n async deleteFolder(folderName: string): Promise<void> {\n await this.clickExpandButton();\n await this.page.locator('folder-list-page').getByRole('link', { name: folderName }).hover();\n await this.clickFolderOptions(folderName, 'delete');\n await expect(this.page.getByRole('heading', { name: 'Delete folder' }).locator('span')).toBeVisible();\n await expect(\n this.page\n .locator('.xl-react-modal .confirmation-content')\n .getByText(\n 'You are about to delete the folder ' +\n folderName +\n '. Folders nested in ' +\n folderName +\n ' will also be deleted.',\n ),\n ).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.getByRole('link', { name: folderName })).not.toBeVisible();\n }\n\n async searchFolderByName(folderName: string): Promise<void> {\n await this.getFolderSearchInputLocator().click();\n await this.getFolderSearchInputLocator().clear();\n await this.getFolderSearchInputLocator().fill(folderName);\n await expect(this.page.getByRole('link', { name: folderName })).toBeVisible();\n }\n\n async openPatterns(): Promise<FolderPatternPage> {\n await this.util.openSideNavMenu('Deliveries');\n await this.util.openNestedMenuItem('Patterns');\n await expect(this.page.getByLabel('breadcrumb').getByText('Patterns')).toBeVisible();\n return this.patternPage;\n }\n\n async clickFolderOptions(folderName: string, option: string): Promise<void> {\n await this.page\n .locator('.folder-list-row-wrapper', { hasText: folderName })\n .locator(`.xl-icon.${option}-icon`)\n .click();\n }\n\n async clickExpandButton(): Promise<void> {\n if (await this.expandButton.isEnabled()) {\n await this.expandButton.click();\n }\n }\n\n async openDeliveriesOverview(): Promise<FolderDeliveryPage> {\n await this.util.openSideNavMenu('Deliveries');\n await this.util.openNestedMenuItem('Deliveries overview');\n await expect(this.page.getByLabel('breadcrumb').getByText('Deliveries')).toBeVisible();\n return this.deliveryPage;\n }\n\n async openNotifications(): Promise<void> {\n await this.util.openSideNavMenu('Notifications');\n await expect(this.page.getByLabel('breadcrumb').getByText('Notifications')).toBeVisible();\n }\n\n async openTemplates(): Promise<void> {\n await this.util.openSideNavMenu('Templates');\n await expect(this.page.getByLabel('breadcrumb').getByText('Templates')).toBeVisible();\n }\n\n async openRelease(): Promise<void> {\n await this.util.openSideNavMenu('Releases');\n await expect(this.page.getByLabel('breadcrumb').getByText('Releases')).toBeVisible();\n }\n\n async expectReleaseStarted(releaseName: string): Promise<void> {\n await expect(\n this.page\n .locator('.release')\n .filter({ hasText: releaseName })\n .locator('.release-status')\n .filter({ hasText: 'In progress' }),\n ).toBeVisible();\n }\n\n async openVariables(): Promise<VariablePage> {\n await this.util.openSideNavMenu('Variables');\n await expect(this.page.getByLabel('breadcrumb').getByText('Variables')).toBeVisible();\n return this.variables;\n }\n\n async openCustomDashboard(): Promise<void> {\n await this.util.openSideNavMenu('Custom dashboards');\n await expect(this.page.getByLabel('breadcrumb').getByText('Custom dashboards')).toBeVisible();\n }\n\n async openReleaseByName(releaseName: string): Promise<void> {\n await this.page.getByTitle(releaseName).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { DateUtil } from './common/dateUtil';\n\nexport class GlobalVariable extends WithPage {\n addListValue: Locator;\n listAddButton: Locator;\n addVariableValue: Locator;\n addVariablelabel: Locator;\n constructor(page: Page) {\n super(page);\n this.addListValue = this.page.locator('.variable-selector .xl-components-input-full input');\n this.addVariableValue = this.page.locator('.variable-value .xl-components-input-full input');\n this.addVariablelabel = this.page.locator('.variable-label input');\n this.listAddButton = this.page.getByRole('button', { name: 'Add' });\n }\n\n async addVariableText(valuename: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('StringVariable');\n await this.page.locator('.variable-value').type(valuename);\n await this.submitTheVariable();\n }\n async addVariableListbox(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n await this.addListValue.fill(possiblevalue);\n await this.listAddButton.click();\n await this.page.getByRole('combobox').nth(1).selectOption(possiblevalue);\n await this.submitTheVariable();\n }\n async addVariablePassword(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('PasswordStringVariable');\n await this.page.locator('input[type=\"password\"]').type(possiblevalue);\n await this.submitTheVariable();\n }\n async addVariableCheckbox(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('BooleanVariable');\n await this.page.getByRole('checkbox').check();\n await this.submitTheVariable();\n }\n async addVariableNumber(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('IntegerVariable');\n await this.page.locator('input[ng-model=\"var.value\"]').fill(possiblevalue);\n await this.submitTheVariable();\n }\n async addVariableList(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('ListStringVariable');\n await this.addVariableValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addVariableValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.submitTheVariable();\n }\n async addVariableMultiList(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MultiSelectListBox');\n await this.addListValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addListValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.getByText('Select all', { exact: true }).click();\n await this.submitTheVariable();\n }\n async addVariableDate(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DateVariable');\n await this.page.getByText('Select date').click();\n }\n\n async setDate(date?: string, monthYear?: string): Promise<void> {\n const dateUtil = new DateUtil(this.page);\n await dateUtil.setDate(date, monthYear);\n }\n\n async addVariableKeyValueMap(keys1: string, values1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MapStringStringVariable');\n await this.page.getByPlaceholder('key').fill(keys1);\n await this.page.getByPlaceholder('Value').fill(values1);\n await this.listAddButton.click();\n await this.page.locator('.xl-map-string-string-div-buttons .search-icon').click();\n await this.page.getByRole('row', { name: 'Search' }).getByRole('textbox').fill(keys1);\n const detail = await this.page.locator('table.table-condensed span').allInnerTexts();\n await expect(detail[0]).toEqual(keys1);\n await expect(detail[1]).toEqual(values1);\n await this.submitTheVariable();\n }\n async addVariableSet(possiblevalue1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('SetStringVariable');\n await this.page.locator('.dip-input input').fill(possiblevalue1);\n await this.listAddButton.click();\n await this.submitTheVariable();\n }\n async addNewVariable(variableName: string, labelname: string, description: string): Promise<void> {\n await this.page.getByRole('button', { name: 'New global variable' }).click();\n await this.page.locator(`div.input-group > input`).type(variableName);\n await this.addVariablelabel.fill(labelname);\n await this.page.locator('.variable-description input').fill(description);\n }\n\n async verifyGlobalVariableCreation(variableName: string): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await expect(this.page.locator('.variable.ui-sortable-handle').filter({ hasText: variableName })).toBeVisible();\n }\n async submitTheVariable(): Promise<void> {\n const pagesubmit = await this.page.locator('.button.save');\n await pagesubmit.hover();\n await pagesubmit.click();\n }\n async deleteGlobalVariable(variableName: string): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Delete').click();\n await expect(this.page.locator('h4.ng-binding')).toContainText(variableName);\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n await this.verifyGlobalVariableCreation(variableName);\n await this.page.getByText('Delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n async editVariable(variableName: string, editedvariabletext: string): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Edit').click();\n await this.addVariablelabel.clear();\n await this.addVariablelabel.fill(editedvariabletext);\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(\n this.page.locator('.variable.ui-sortable-handle').getByText(editedvariabletext, { exact: true }),\n ).toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class HomePage extends WithPage {\n configureButton: Locator;\n viewModeButton: Locator;\n constructor(page: Page) {\n super(page);\n this.configureButton = this.page.getByRole('button', { name: 'Configure' });\n this.viewModeButton = this.page.getByRole('button', { name: 'back icon Back to view mode' });\n }\n\n async verifyHomePage(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Digital.ai Release Home' })).toBeVisible();\n }\n\n async verifyConfigureButton(): Promise<void> {\n await this.configureButton.click();\n await expect(this.viewModeButton).toBeVisible();\n await this.viewModeButton.click();\n }\n\n async addReleaseTiles(): Promise<void> {\n await this.configureButton.click();\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByPlaceholder('Search...').fill('releases');\n await this.page.getByPlaceholder('Search...').click();\n await this.page.getByText('Release tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Release tile (Global) Add See' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Releases' }).first()).toBeVisible();\n }\n\n async addWorkflowTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Workflow tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Workflow tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Introducing Workflows' }).first()).toBeVisible();\n }\n\n async addApplicationTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Application tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Application tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Applications' }).first()).toBeVisible();\n }\n\n async addTemplateTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Template tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Template tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Templates' }).first()).toBeVisible();\n }\n\n async addAnnouncementTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Announcement tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Announcement tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('heading', { name: 'Getting started' }).first()).toBeVisible();\n }\n\n async addAnaslyticsTiles(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add tiles' }).click();\n await this.page.getByText('Analytics tile (Global)').hover();\n await this.page\n .locator('xlr-tile-card')\n .filter({ hasText: 'Analytics tile (Global) Add' })\n .getByRole('button')\n .click();\n await this.page.getByRole('button', { name: 'back icon Back to view mode' }).click();\n await expect(this.page.getByRole('button', { name: 'View Analytics' }).nth(1)).toBeVisible();\n }\n /**\n * Remove the tiles from the home page\n * @param tileName name of the tile to be removed\n * tileName TileName should be \"Releases\", \"Workflows\", \"Applications\", \"Templates\", \"Announcements\", \"Analytics\"\n */\n async removeTiles(tileName: string): Promise<void> {\n await this.configureButton.click();\n await this.page\n .locator('.xlr-tile-container[data-title=\"' + tileName + '\"]')\n .last()\n .hover();\n await this.page\n .locator('[data-title=\"' + tileName + '\"] .delete-icon')\n .last()\n .click();\n await expect(this.page.getByRole('heading', { name: 'Delete tile' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await this.viewModeButton.click();\n }\n\n async verifyWhatsNewButton(): Promise<void> {\n await this.page.getByText(`What's new`).waitFor({ state: 'visible' });\n await this.page.getByText(`What's new`).click();\n await expect(this.page.getByText('Introducing Analytics')).toBeVisible();\n await this.page.getByLabel('Close').click();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { Util } from './common/util';\n\nexport class HeaderPage extends WithPage {\n announcementIcon: Locator;\n settingsIcon: Locator;\n aboutMenu: Locator;\n util: Util;\n\n constructor(page: Page) {\n super(page);\n this.announcementIcon = this.page.getByLabel('Open Resource Center');\n this.settingsIcon = this.page.locator('i[aria-label=\"settings-admin-opaque icon\"]');\n this.aboutMenu = this.page.getByText('About Digital.ai Release');\n this.util = new Util(page);\n }\n\n async verifyVersionNumber(versionNumber: string): Promise<void> {\n const year = new Date().getFullYear();\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n await expect(this.page.getByText('Version ' + versionNumber)).toBeVisible();\n await expect(this.page.getByRole('img', { name: 'Release' })).toBeVisible();\n await expect(this.page.getByText(`ⓒ ${year} Digital.ai Software,`)).toBeVisible();\n await this.util.clickCloseIcon();\n }\n\n async verifyProductAnnouncements(): Promise<void> {\n await expect(this.announcementIcon).toBeVisible();\n await this.announcementIcon.click();\n await expect(this.page.locator('#pendo-guide-container')).toContainText('Product updates');\n }\n\n async clickHelpIcon(): Promise<void> {\n await this.page.getByTestId('right-side-nav').getByRole('button', { name: 'Help' }).click();\n }\n\n async verifyOnlineDocumentation(): Promise<void> {\n const versionNumber = await this.getVersionNumber();\n await this.clickHelpIcon();\n const page2Promise = this.page.waitForEvent('popup');\n await expect(this.page.getByText('Online documentation')).toBeVisible();\n await this.page.getByText('Online documentation').click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain(\n 'https://docs.digital.ai/release/docs/' + versionNumber.substring(8, 12) + '/how-to/get-started-with-xl-release',\n );\n await this.page.bringToFront();\n }\n\n async verifySupportRequest(): Promise<void> {\n await expect(this.page.getByRole('menuitem', { name: 'Submit a support request' })).toBeVisible();\n const page2Promise = this.page.waitForEvent('popup');\n await this.page.getByRole('menuitem', { name: 'Submit a support request' }).click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain('https://support.digital.ai/hc/en-us/');\n await this.page.bringToFront();\n }\n\n async verifySuggestAFeature(): Promise<void> {\n await expect(this.page.getByText('Suggest a feature')).toBeVisible();\n const page2Promise = this.page.waitForEvent('popup');\n await this.page.getByText('Suggest a feature').click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain('https://ideas.digital.ai/devops');\n await this.page.bringToFront();\n }\n\n async verifyDigitalAiWebsite(): Promise<void> {\n await expect(this.page.getByText('Digital.ai website')).toBeVisible();\n const page2Promise = this.page.waitForEvent('popup');\n await this.page.getByText('Digital.ai website').click();\n const page2 = await page2Promise;\n expect(page2.url()).toContain('https://digital.ai/');\n await this.page.bringToFront();\n }\n\n async clickAvatarIcon(username: string): Promise<void> {\n await this.page.getByLabel(username, { exact: true }).click();\n }\n\n async verifyUser(userFullName: string): Promise<void> {\n await this.page.locator('li').getByLabel(userFullName).click();\n await expect(this.page.getByRole('heading', { name: 'Personal settings for admin' })).toBeVisible();\n }\n\n async clickAccessTokens(): Promise<void> {\n await this.page.getByText('Access tokens').click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Access tokens')).toBeVisible();\n }\n\n async getVersionNumber(): Promise<string> {\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n const versionNumber = await this.page.locator('.version-text').innerText();\n await this.util.clickCloseIcon();\n return versionNumber;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { Util } from './common/util';\n\nexport class ManagePluginsPage extends WithPage {\n util: Util;\n\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n }\n\n async openPluginGallery(): Promise<void> {\n await this.util.openSideNavMenu('Plugin gallery');\n await expect(this.page.getByLabel('breadcrumb').getByText('Plugin gallery')).toBeVisible();\n }\n\n async openInstalledPlugins(): Promise<void> {\n await this.util.openSideNavMenu('Installed plugins');\n await expect(this.page.getByLabel('breadcrumb').getByText('Installed plugins')).toBeVisible();\n }\n\n async searchForPlugins(searchText: string): Promise<void> {\n await this.page.getByPlaceholder('Search for plugin').fill(searchText);\n expect(await this.page.locator('.PluginTile__title-and-version___1HsNr span').count()).toBeGreaterThan(0);\n }\n\n async refreshPluginList(): Promise<void> {\n await expect(this.page.getByTestId('plugin-refresh-btn')).toBeVisible();\n await this.page.getByTestId('plugin-refresh-btn').click();\n }\n\n async clickInstallNow(pluginName: string): Promise<void> {\n await this.page\n .locator('div')\n .filter({ hasText: 'Install now' + pluginName })\n .getByRole('button')\n .click();\n }\n\n async expectRestartInfo(): Promise<void> {\n await expect(this.page.getByText('Restart Digital.ai Release to finish installing the plugin.')).toBeVisible();\n }\n\n async expectNewPluginInstallationInfo(pluginName: string): Promise<void> {\n await expect(this.page.getByText('New plugin installedPlugin')).toBeVisible();\n await expect(\n this.page.getByText(`release-${pluginName.toLowerCase()}-integration has been installed`),\n ).toBeVisible();\n }\n\n async clickUpload(): Promise<void> {\n await this.page.locator('button', { hasText: 'Upload' }).click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class PersonalAccessTokenPage extends WithPage {\n async openPersonalAccessTokenPage(): Promise<this> {\n // await this.page.locator(\"button.dot-avatar\").click()\n // await this.page.locator(\"//div[normalize-space()='Access tokens']\").click()\n await this.page.goto('./#/personal-access-token');\n await expect(this.page).toHaveTitle('Access tokens / Personal settings - Digital.ai Release');\n return this;\n }\n\n async addNewToken(tokenName: string): Promise<this> {\n //await expect(this.page).toHaveTitle('Access tokens / Personal settings - Digital.ai Release')\n\n await this.page.locator('#tokenText').fill(tokenName);\n await this.page.locator(\"button[type='submit']\").click();\n return this;\n }\n}\n","import { Util } from './common/util';\nimport { WithPage } from './WithPage';\nimport { Page, expect } from '@playwright/test';\n\nexport class PersonalSettingsPage extends WithPage {\n util: Util;\n constructor(page: Page) {\n super(page);\n this.util = new Util(page);\n }\n\n async openProfile(): Promise<void> {\n await this.util.openSideNavMenu('Profile');\n }\n\n async openAccessToken(): Promise<void> {\n await this.util.openSideNavMenu('Access tokens');\n }\n\n async expectEmailDefined(email: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('#email')).toHaveValue(email);\n return this;\n }\n\n async expectNoEmailDefined(): Promise<PersonalSettingsPage> {\n return this.expectEmailDefined('');\n }\n\n async expectFullNameDefined(fullName: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('#full-name')).toHaveValue(fullName);\n return this;\n }\n\n async expectNoFullNameDefined(): Promise<PersonalSettingsPage> {\n return this.expectFullNameDefined('');\n }\n\n async expectPasswordNotToBe(password: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('input[data-test=\"password-input\"]')).not.toHaveValue(password);\n return this;\n }\n\n async expectDateFormatToBe(dateFormat: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('select[ng-model=\"$ctrl.profile.dateFormat\"]')).toHaveValue(dateFormat);\n return this;\n }\n\n async expectTimeFormatToBe(timeFormat: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('select[ng-model=\"$ctrl.profile.timeFormat\"]')).toHaveValue(timeFormat);\n return this;\n }\n\n async expectFirstDayOfWeekToBe(firstDayOfWeek: string): Promise<PersonalSettingsPage> {\n await expect(this.page.locator('select[ng-model=\"$ctrl.profile.firstDayOfWeek\"]')).toHaveValue(firstDayOfWeek);\n return this;\n }\n\n async save(): Promise<PersonalSettingsPage> {\n await this.page.locator('action-toolbar button:has-text(\"Save\"):enabled').click();\n await this.page.locator('.saved-text').waitFor({ state: 'visible' });\n return this;\n }\n\n async setEmail(email: string): Promise<PersonalSettingsPage> {\n await this.page.locator('#email').fill(email);\n return this.save();\n }\n\n async setFullName(fullName: string): Promise<PersonalSettingsPage> {\n await this.page.locator('#full-name').fill(fullName);\n return this.save();\n }\n\n async setPassword(previousPassword: string, password: string): Promise<PersonalSettingsPage> {\n await this.page.locator('#previousPassword').fill(previousPassword);\n await this.page.locator('input[data-test=\"password-input\"]').fill(password);\n await this.page.locator('#passwordConfirmation').fill(password);\n return this.save();\n }\n\n async refresh(): Promise<PersonalSettingsPage> {\n await this.page.reload();\n await this.page.waitForSelector('#profileForm');\n return this;\n }\n\n async editUserProfile(email: string): Promise<void> {\n await this.page.getByLabel('Email address').click();\n await this.page.getByLabel('Email address').fill(email);\n await this.page.getByText('Save').click();\n expect(await this.page.locator('.saved-text').textContent()).toContain('Last saved on ');\n }\n\n async generateNewAccessToken(tokenName: string, expiryOptions: string): Promise<void> {\n await this.page.getByRole('button', { name: 'Generate token' }).click();\n await this.page.getByLabel('Token name').click();\n await this.page.getByLabel('Token name').fill(tokenName);\n await this.page\n .getByRole('textbox', { name: 'Token expiration' })\n .getByLabel('Token expiration')\n .selectOption(expiryOptions);\n await this.page\n .locator('label')\n .filter({ hasText: 'Use all permissions' })\n .getByTestId('RadioButtonCheckedIcon')\n .click();\n await this.page.getByRole('button', { name: 'Generate', exact: true }).click();\n await expect(this.page.getByTestId('alert-button-tooltip').getByTestId('dot-button')).toBeVisible();\n await expect(this.page.getByText(tokenName)).toBeVisible();\n }\n\n async deleteAccessToken(tokenName: string): Promise<void> {\n await this.page.locator('.MuiTableRow-root').filter({ hasText: tokenName }).getByTestId('button-icon-i').click();\n await expect(this.page.getByRole('heading', { name: 'Delete token' })).toBeVisible();\n await expect(this.page.getByLabel('Delete token')).toContainText('Delete token');\n await this.page.getByRole('button', { name: 'delete icon Delete' }).click();\n await expect(this.page.getByText(tokenName)).not.toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class UserModal extends WithPage {\n userName: Locator;\n name: Locator;\n email: Locator;\n password: Locator;\n cnfPassword: Locator;\n saveButton: Locator;\n cancelButton: Locator;\n deleteButton: Locator;\n constructor(page: Page) {\n super(page);\n this.userName = page.locator('#username');\n this.name = page.locator('#fullName');\n this.email = page.locator('#email');\n this.password = page.locator('#password');\n this.cnfPassword = page.locator('#confirmPassword');\n this.saveButton = page.getByRole('button', { name: 'Save' });\n this.cancelButton = page.getByRole('button', { name: 'Cancel' });\n this.deleteButton = page.getByRole('button', { name: 'Delete' });\n }\n\n async setUserName(username: string): Promise<void> {\n return await this.userName.fill(username);\n }\n\n async setFullName(fullName: string): Promise<void> {\n return await this.name.fill(fullName);\n }\n\n async setEmail(email: string): Promise<void> {\n return await this.email.fill(email);\n }\n\n async setPassword(password: string): Promise<void> {\n return await this.password.fill(password);\n }\n\n async setCurrentPassword(password: string): Promise<void> {\n const currentPasswordField = this.page.locator('#previousPassword');\n await currentPasswordField.fill(password);\n await expect(currentPasswordField).toHaveValue(password);\n }\n\n async setConfirmPassword(cnfPassword: string): Promise<void> {\n return await this.cnfPassword.fill(cnfPassword);\n }\n\n async save(): Promise<void> {\n await this.saveButton.isEnabled();\n await expect(this.saveButton).not.toBeDisabled();\n await this.saveButton.focus();\n await this.saveButton.click();\n }\n\n async cancel(): Promise<void> {\n await this.cancelButton.click();\n }\n\n async delete(): Promise<void> {\n await this.deleteButton.click();\n }\n\n async expectSaveButtonEnabled(): Promise<void> {\n await expect(this.saveButton).toBeEnabled();\n }\n\n async expectSaveButtonDisabled(): Promise<void> {\n await expect(this.saveButton).toBeDisabled();\n }\n\n async expectErrorMessage(errorMsg: string): Promise<void> {\n await expect(this.page.locator('.dot-dialog-content [role=\"alert\"]')).toContainText(errorMsg);\n }\n\n async expectNewPasswordBoxDisabled(): Promise<this> {\n await expect(this.page.locator('#password')).toBeDisabled();\n return this;\n }\n\n async expectConfirmPasswordHelperText(text: string): Promise<void> {\n const helperText = this.page.locator('#confirmPassword-helper-text');\n await expect(helperText).toBeVisible();\n await expect(helperText).toHaveText(text);\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { UserModal } from './userModal';\nimport { Util } from '../common/util';\n\nexport class UsersPage extends WithPage {\n page: Page;\n modal: UserModal;\n util: Util;\n constructor(page: Page) {\n super(page);\n this.page = page;\n this.modal = new UserModal(page);\n this.util = new Util(page);\n }\n\n async openUsersPage(): Promise<void> {\n this.page.goto('./#/users', { timeout: 1000 });\n }\n\n async toggleLoginPermission(username: string): Promise<void> {\n await this.page\n .getByRole('row', { name: '' + username + '' })\n .getByRole('checkbox')\n .click();\n await expect(this.page.getByRole('row', { name: '' + username + '' }).locator('.Mui-checked')).toBeChecked();\n }\n\n async addUser(): Promise<UserModal> {\n await this.page.locator('.new-user-btn').click();\n return this.modal;\n }\n\n async createUser(username: string, password: string): Promise<void> {\n await this.modal.setUserName(username);\n await this.modal.setFullName(username);\n await this.modal.setEmail('testuser@company.com');\n await this.modal.setPassword(password);\n await this.modal.setConfirmPassword(password);\n await this.modal.save();\n }\n\n async filterUser(username: string): Promise<void> {\n await this.page.getByPlaceholder('Filter...').fill(username);\n }\n\n async expectToHaveFilteredUser(username: string): Promise<void> {\n return await expect(this.page.getByRole('row', { name: '' + username + '' })).toBeVisible();\n }\n\n async expectToHaveLoginPermission(username: string): Promise<void> {\n return await expect(this.page.getByRole('row', { name: '' + username + '' }).getByRole('checkbox')).toBeChecked();\n }\n\n async deleteUser(username: string): Promise<void> {\n await this.page.getByTestId(`delete-btn-${username}`).click();\n await this.modal.delete();\n }\n async openRoles(): Promise<void> {\n await this.util.openSideNavMenu('Roles');\n await expect(this.page.getByLabel('breadcrumb').getByText('Roles')).toBeVisible();\n }\n\n async openPermissions(): Promise<void> {\n await this.util.openSideNavMenu('Permissions');\n await expect(this.page.locator('.permissions-table-v2')).toBeVisible();\n }\n\n async openTaskAccess(): Promise<void> {\n await this.util.openSideNavMenu('Task access');\n await expect(this.page.getByLabel('breadcrumb').getByText('Task access')).toBeVisible();\n }\n\n async expectUsers(\n users: Array<{ email?: string; external: boolean; externalId?: string; fullName?: string; name: string }>,\n ): Promise<void> {\n for (const user of users) {\n await this.filterUser(user.name);\n const type = user.external ? 'External' : 'Internal';\n expect(await this.page.locator(`tr`).filter({ hasText: user.name }).count()).toBeGreaterThan(0);\n expect(\n await this.page.locator(`tr`).filter({ hasText: user.name }).locator(`td`).filter({ hasText: type }).count(),\n ).toBeGreaterThan(0);\n\n if (user.email) {\n expect(\n await this.page\n .locator(`tr`)\n .filter({ hasText: user.name })\n .locator(`td`)\n .filter({ hasText: user.email })\n .count(),\n ).toBeGreaterThan(0);\n }\n\n if (user.fullName) {\n expect(\n await this.page\n .locator(`tr`)\n .filter({ hasText: user.name })\n .locator(`td`)\n .filter({ hasText: user.fullName })\n .count(),\n ).toBeGreaterThan(0);\n }\n\n if (user.externalId) {\n expect(\n await this.page\n .locator(`tr`)\n .filter({ hasText: user.name })\n .locator(`td`)\n .filter({ hasText: user.externalId })\n .count(),\n ).toBeGreaterThan(0);\n }\n\n expect(\n await this.page.locator(`tr`).filter({ hasText: user.name }).locator(`td .icon-delete`).count(),\n ).toBeGreaterThan(0);\n }\n }\n\n async expectNoUser(username: string): Promise<void> {\n await this.filterUser(username);\n await expect(this.page.locator(`p[aria-label=${username}]`)).not.toBeVisible();\n }\n\n async updateUser(username: string): Promise<UserModal> {\n await this.filterUser(username);\n await this.page\n .getByRole('row', { name: '' + username + '' })\n .locator('.icon-edit')\n .click();\n return this.modal;\n }\n\n async sortByColumn(columnName: string, columnIndex: number): Promise<this> {\n const table = this.page.getByTestId('users-table');\n const column = table.locator(`th[title=\"${columnName}\"]`);\n const columnClick = this.page.getByRole('button', { name: columnName, exact: true });\n const originalData = await table.locator(`tr td:nth-child(${columnIndex})`).allTextContents();\n await columnClick.click();\n const sort = await column.getAttribute('aria-sort');\n if (sort == 'ascending') {\n const data = await table.locator(`td:nth-child(${columnIndex})`).allTextContents();\n originalData.sort();\n expect(data).toEqual(originalData);\n }\n if (sort == 'descending') {\n const data = await table.locator(`td:nth-child(${columnIndex})`).allTextContents();\n expect(data).toEqual([...data].sort((a, b) => a.localeCompare(b)));\n }\n return this;\n }\n\n async expectColumnVisible(column: string, visible = true): Promise<this> {\n if (visible) {\n await expect(this.page.locator(`thead th`).filter({ hasText: column })).toBeVisible();\n } else {\n await expect(this.page.locator(`thead th`).filter({ hasText: column })).toHaveCount(0);\n }\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class WorkflowCatalogPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async installReleaseRunner(headingName: string): Promise<void> {\n await this.page.locator('.workflow-card').filter({ hasText: headingName }).getByTestId('dot-button').click();\n await expect(this.page.getByRole('heading', { name: 'Choose folder' })).toBeVisible();\n await this.page.locator('.xl__dropdown-indicator-container').click();\n await this.page.getByText('Samples & Tutorials').click();\n await this.page.getByRole('button', { name: 'Run workflow' }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Install additional Digital.ai')).toBeVisible();\n await this.page.getByRole('heading', { name: 'Prepare Digital.ai Release URL' }).waitFor();\n await expect(this.page.getByRole('heading', { name: 'Prepare Digital.ai Release URL' })).toBeVisible();\n await this.page.getByRole('heading', { name: 'Digital.ai Release URL' }).nth(2).waitFor();\n await expect(this.page.getByRole('heading', { name: 'Digital.ai Release URL' }).nth(2)).toBeVisible();\n }\n\n async abortInstallation(): Promise<void> {\n await this.page.getByRole('button', { name: 'Abort' }).click();\n await this.page.getByRole('button', { name: 'cancel icon Abort' }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Install additional Digital.ai')).not.toBeVisible();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { WorkflowCatalogPage } from './workflowCatalogPage';\n\nexport class SettingsMenu extends WithPage {\n settingsIcon: Locator;\n configureSystemMessageMenu: Locator;\n usersAndPermissionMenu: Locator;\n managePluginMenu: Locator;\n systemSettingsMenu: Locator;\n taskManagerMenu: Locator;\n runnerMenu: Locator;\n viewSystemInfoMenu: Locator;\n getDataSupportMenu: Locator;\n renewLicenseMenu: Locator;\n aboutMenu: Locator;\n closeIcon: Locator;\n installRunnerButton: Locator;\n workflowCatalogPage: WorkflowCatalogPage;\n\n constructor(page: Page) {\n super(page);\n this.settingsIcon = this.page.getByRole('button', { name: 'Settings' });\n this.usersAndPermissionMenu = this.page.getByRole('menuitem', { name: 'users icon Users and permissions' });\n this.managePluginMenu = this.page.getByRole('menuitem', { name: 'plugins icon Manage plugins' });\n this.systemSettingsMenu = this.page.getByRole('menuitem', { name: 'System settings' });\n this.runnerMenu = this.page.getByText('Runners');\n this.configureSystemMessageMenu = this.page.getByText('Configure system message');\n this.taskManagerMenu = this.page.getByText('Task manager');\n this.viewSystemInfoMenu = this.page.getByText('View system information');\n this.getDataSupportMenu = this.page.getByText('Get data for support');\n this.renewLicenseMenu = this.page.getByText('Renew license');\n this.aboutMenu = this.page.getByText('About Digital.ai Release');\n this.closeIcon = this.page.locator('.xl-icon.close-icon');\n this.installRunnerButton = this.page.getByTestId('create-btn');\n this.workflowCatalogPage = new WorkflowCatalogPage(page);\n }\n\n async openUsersAndPermissions(): Promise<void> {\n await this.settingsIcon.click();\n await this.usersAndPermissionMenu.click();\n }\n\n async openManagePlugin(): Promise<void> {\n await this.settingsIcon.click();\n await this.managePluginMenu.click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Plugin gallery')).toBeVisible();\n }\n\n async openSystemSettings(): Promise<void> {\n await this.settingsIcon.click();\n await this.systemSettingsMenu.click();\n await expect(this.page.getByLabel('breadcrumb').getByText('System settings')).toBeVisible();\n }\n\n async openRunner(): Promise<void> {\n await this.settingsIcon.click();\n await this.runnerMenu.click();\n await expect(this.page.getByRole('link', { name: 'Runners' })).toBeVisible();\n }\n\n async openConfigureSystemMessage(): Promise<void> {\n await this.settingsIcon.click();\n await this.configureSystemMessageMenu.click();\n await expect(this.page.getByRole('heading', { name: 'System message' })).toBeVisible();\n }\n\n async closeConfigureSystemMessage(): Promise<void> {\n await this.closeIcon.first().click();\n }\n\n async configureSystemMessage(message: string): Promise<void> {\n await this.settingsIcon.click();\n await this.configureSystemMessageMenu.click();\n await this.page.getByLabel('Enable system message').check();\n await this.page.getByLabel('Type here...').locator('div').nth(2).click();\n await this.page.getByLabel('Type here...').fill(message);\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.locator('system-message')).toContainText(message);\n }\n\n async disableSystemMessage(): Promise<void> {\n await this.settingsIcon.click();\n await this.configureSystemMessageMenu.click();\n await this.page.getByLabel('Enable system message').uncheck();\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.getByRole('alert')).not.toBeVisible();\n }\n\n async openTaskManager(): Promise<void> {\n await this.settingsIcon.click();\n await this.taskManagerMenu.click();\n await expect(this.page.getByRole('link', { name: 'Task manager' })).toBeVisible();\n }\n\n async openViewSystemInformation(): Promise<void> {\n const versionNumber = await this.getVersionNumber();\n await this.settingsIcon.click();\n await this.viewSystemInfoMenu.click();\n await expect(this.page.getByRole('heading', { name: 'Release system information' })).toBeVisible();\n await expect(this.page.getByRole('rowgroup')).toContainText(versionNumber);\n }\n\n async openGetDataForSupport(): Promise<void> {\n await this.settingsIcon.click();\n await this.getDataSupportMenu.click();\n await expect(this.page.getByRole('heading', { name: 'Get data for support' })).toBeVisible();\n await expect(this.page.locator('support-accelerator-modal')).toContainText(\n 'See https://support.digital.ai for more information or to open a support request.',\n );\n }\n\n async downloadSupportData(): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n const downloadPromise = this.page.waitForEvent('download');\n await this.page.getByRole('button', { name: 'Download' }).click();\n await downloadPromise;\n }\n\n async openRenewLicense(): Promise<void> {\n await this.settingsIcon.click();\n const page1Promise = this.page.waitForEvent('popup');\n await this.page.getByText('Renew license').click();\n const page1 = await page1Promise;\n expect(page1.url()).toContain('/productregistration');\n await expect(page1.getByRole('button', { name: 'Install license' })).toBeVisible();\n await this.page.bringToFront();\n }\n\n async getVersionNumber(): Promise<string> {\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n const versionNumber = await this.page.locator('.version-text').innerText();\n await this.closeIcon.click();\n return versionNumber;\n }\n\n async openAbout(): Promise<Modal> {\n await this.settingsIcon.click();\n await this.aboutMenu.click();\n await expect(this.page.getByRole('heading', { name: 'About' })).toBeVisible();\n return new Modal(this.page);\n }\n}\n\nexport class Modal {\n modalBody: Locator;\n closeIcon: Locator;\n\n constructor(page: Page) {\n this.modalBody = page.locator('.modal-body');\n this.closeIcon = page.locator('.xl-icon.close-icon');\n }\n\n async closeModal(): Promise<void> {\n await this.closeIcon.click();\n await expect(this.modalBody).not.toBeVisible();\n }\n async validateLicenseInfo(): Promise<void> {\n await expect(this.modalBody).toBeVisible();\n await expect(this.modalBody).toContainText('Expires on');\n await expect(this.modalBody).toContainText('1');\n await expect(this.modalBody).toContainText('35');\n await expect(this.modalBody).toContainText('Licensed to XL Release Dev Team');\n await this.closeModal();\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class TaskDetails extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n}\n","import { expect, Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport moment from 'moment';\nimport { ReleasesHeaderPage } from './ReleaseHeaderPage';\n\nexport class ReleaseCalendarPage extends ReleasesHeaderPage {\n private dayFormat!: string;\n private yearFormat!: number;\n private monthFormat!: string;\n private yearFormatString!: string;\n\n async openReleaseCalendarPage(): Promise<this> {\n await this.page.goto('./#/releases/calendar');\n //Define date format to verify different calendar views\n const today = new Date();\n let options: Intl.DateTimeFormatOptions = {\n weekday: 'long',\n year: 'numeric',\n month: 'short',\n day: 'numeric',\n };\n this.dayFormat = today.toLocaleDateString('en-US', options); // Saturday, September 17, 2016\n this.yearFormat = today.getFullYear();\n this.yearFormatString = this.yearFormat.toString();\n options = { month: 'long', year: 'numeric' };\n this.monthFormat = today.toLocaleDateString('en-US', options);\n this.monthFormat = this.monthFormat.replace(/(\\w+) (\\d+)/, '$1, $2');\n await expect(this.page.locator('.tl-viewport')).toBeVisible();\n return this;\n }\n\n async exportCalendar(): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n this.page.on('download', () => {});\n await this.page.getByRole('button', { name: 'download icon Export calendar' }).click();\n const downloadPromise = this.page.waitForEvent('download');\n await this.page.getByRole('button', { name: 'Export' }).click();\n await downloadPromise;\n }\n\n async cancelCalendarExport(): Promise<number> {\n let downloadCount = 0;\n // Listen to download events\n this.page.on('download', (_download) => {\n downloadCount++;\n });\n await this.page.getByRole('button', { name: 'download icon Export calendar' }).click();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return downloadCount;\n }\n\n async verifyDayView(): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct day format displayed at the page bottom\n await expect(this.page.getByText(this.dayFormat)).toBeVisible();\n }\n\n async verifyYearView(): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Year' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct Year format displayed at the page bottom\n await expect(this.page.locator('.tl-footer-label').filter({ hasText: this.yearFormatString })).toHaveText(\n this.yearFormatString,\n );\n }\n\n async verifyMonthView(): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Month' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct Year format displayed at the page bottom\n await expect(this.page.locator('.tl-footer-label').filter({ hasText: this.monthFormat })).toHaveText(\n this.monthFormat,\n );\n }\n\n async verifyPageContent(title: string): Promise<void> {\n const view_type = ['Day', 'Week', 'Month', 'Year'];\n for (const view of view_type) {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: view }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n //Verify Page has correct Year format displayed at the page bottom\n await expect(this.page.getByText(title)).toBeVisible();\n }\n }\n\n async viewRelease(release_title: string, release_id: string): Promise<void> {\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n await expect(async () => {\n await this.page.locator('.tl-event-title').getByText(release_title).scrollIntoViewIfNeeded({ timeout: 1000 });\n await this.page.locator('.tl-event-title').getByText(release_title).click({ timeout: 1000 });\n await expect(this.page.locator('.release-modal-container .xl-icon.release-icon')).toBeVisible({ timeout: 1000 });\n }).toPass();\n\n await this.page.locator('.release-modal-container').locator('.xl-icon.release-icon').click();\n const releaseurl = `/#/releases/${release_id}`;\n // Check if the release name present in redirected URL\n expect(this.page.url()).toContain(releaseurl);\n }\n\n async viewDependency(source_release: string, dest_release: string): Promise<void> {\n const source_text = source_release + 'dependencies';\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n await this.page.getByText(source_release).click();\n await this.page.locator('.release-modal-container').locator('.xl-icon.cluster-dependencies-icon').click();\n await expect(this.page.locator('.tl-drawer-navigation-header')).toHaveText(source_text);\n await expect(this.page.locator('.tl-drawer-dependency-body-title-text')).toHaveText(dest_release);\n }\n\n async downloadIcsCalendar(release_title: string): Promise<number> {\n let downloadCount = 0;\n // Listen to download events\n this.page.on('download', (_download) => {\n downloadCount++;\n });\n await this.page.locator('.tl-header-navigation').getByRole('combobox').click();\n await this.page.getByRole('option', { name: 'Day' }).click();\n await this.page.getByRole('button', { name: 'Today' }).click();\n await this.page.getByText(release_title).click();\n await this.page.locator('.release-modal-container').locator('.xl-icon.calendar-icon').click();\n return downloadCount;\n }\n\n async openBlackoutPeriod(date: string): Promise<BlackoutPeriod> {\n return new BlackoutPeriod(date, this.page);\n }\n}\n\nexport class BlackoutPeriod extends WithPage {\n dateField: string;\n\n constructor(date: string, page: Page) {\n super(page);\n this.dateField = date;\n }\n\n async edit(): Promise<this> {\n await this.findBlackout();\n await this.page.locator('.blackout-popover .blackout-popover-footer .edit-icon').click();\n return this;\n }\n\n async delete(): Promise<this> {\n await this.findBlackout();\n await this.page.locator('.blackout-popover .blackout-popover-footer .delete-icon').click({ force: true });\n await this.page.getByRole('button', { name: 'Delete' }).click({ force: true });\n return this;\n }\n\n async findBlackout(): Promise<void> {\n await expect(async () => {\n await this.page\n .locator(`.tl-blackout-start[data-test-date=\"${this.dateField}\"]`)\n .click({ force: true, position: { x: 4, y: 4 } });\n await expect(this.page.locator('.blackout-popover-container')).toBeVisible({ timeout: 1000 });\n }).toPass();\n }\n\n // Have to revisit here fix the date selection for different months\n async setEndDate(date: Date): Promise<this> {\n const cDate = moment(date).format('dddd, MMMM Do, YYYY');\n await this.page\n .locator('.widget-datetime')\n .filter({ hasText: 'End date' })\n .locator('.xl-react-widget-date input')\n .click();\n await this.page.getByLabel(`Choose ${cDate}`).click();\n return this;\n }\n\n async save(): Promise<this> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n return this;\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleaseGroupPage extends WithPage {\n private dayFormat!: string;\n private yearFormat!: number;\n private monthFormat!: string;\n private yearFormatString!: string;\n\n async setStatus(status: string): Promise<void> {\n await this.page.locator('.react-tagsinput').click({ force: true });\n await this.page.getByText('Clear all').click();\n await this.page.locator('.react-tagsinput').click({ force: true });\n if (status === 'Select all') {\n await this.page.getByText(status).click();\n } else {\n await this.page.getByTitle(status).locator('i').first().click();\n }\n }\n\n async openReleaseGroup(title: string): Promise<void> {\n await this.page.locator('xlr-release-group-row').filter({ hasText: title }).getByRole('link').click();\n await this.page.getByTitle(title).click();\n await expect(this.page).toHaveURL(/.*ReleaseGroup/);\n }\n\n async expectReleaseGroupStatus(status: string): Promise<void> {\n await expect(this.page.locator('.release-status')).toContainText(status);\n }\n\n async expectReleaseGroupDisplayed(title: string): Promise<void> {\n await expect(this.page.locator('.row').getByText(title, { exact: true })).toBeVisible();\n }\n\n async expectReleaseGroupNotDisplayed(title: string): Promise<void> {\n await expect(this.page.locator('.row').getByText(title, { exact: true })).not.toBeVisible();\n }\n\n async searchReleaseGroupByTitle(title: string): Promise<void> {\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).click();\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).fill(title);\n await this.page.getByPlaceholder('Search for groups...', { exact: true }).press('Enter');\n }\n\n async deleteReleaseGroup(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-delete').click();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async clickReleaseGroupEdit(title: string): Promise<void> {\n await this.page.locator('.fc-list-item-line').filter({ hasText: title }).locator('.fc-item-update').click();\n }\n\n async enterReleaseGroupDetails(new_title: string): Promise<void> {\n await this.page.locator('.modal-body').locator('#title').fill(new_title);\n }\n\n async clickSaveButton(): Promise<void> {\n await this.page.locator('.modal-footer').getByRole('button', { name: 'Save' }).click();\n }\n\n async clickCancelButton(): Promise<void> {\n await this.page.locator('.modal-footer').getByRole('button', { name: 'Cancel' }).click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleaseGroupTimelinePage extends WithPage {\n async expectReleaseDisplayed(title: string): Promise<void> {\n await expect(this.page.getByText(title, { exact: true })).toBeVisible();\n }\n\n async expectReleaseNotDisplayed(title: string): Promise<void> {\n await expect(this.page.getByText(title, { exact: true })).not.toBeVisible({ timeout: 10000 });\n }\n\n async expectPhaseDisplayed(title: string): Promise<void> {\n await expect(this.page.getByText(title, { exact: true })).toBeVisible();\n }\n\n async openContextMenu(title: string): Promise<void> {\n await this.page.locator('.timeline-row-name').filter({ hasText: title }).locator('.options-icon').click();\n }\n\n async removeFromReleaseGroup(): Promise<void> {\n await this.page.getByRole('menuitem', { name: 'Remove from group' }).locator('a').click();\n await this.page.getByRole('button', { name: 'Remove' }).click();\n }\n\n async expectNumberOfReleases(num_of_release: number): Promise<void> {\n const elementCount = await this.page.locator('.timeline-row-name-release').count();\n expect(elementCount).toBe(num_of_release);\n }\n\n async openAddReleaseList(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add release' }).click();\n }\n\n async filterReleases(title: string): Promise<void> {\n await this.page.getByPlaceholder('Search for a release...').click();\n await this.page.getByPlaceholder('Search for a release...').fill(title);\n await this.page.waitForTimeout(5000);\n await this.page.getByPlaceholder('Search for a release...').press('Enter');\n }\n\n async expectNumberOfReleasesOnModal(num_of_release: number): Promise<void> {\n const elementCount = await this.page.locator('.release-modal-line').count();\n expect(elementCount).toBe(num_of_release);\n }\n\n async selectAllReleaseCheckbox(): Promise<void> {\n await this.page.getByLabel('Select all').check();\n }\n\n async addReleasesToGroup(): Promise<void> {\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n}\n","import { expect, Locator, Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { waitForOneOf } from '../helper';\nimport { DateUtil } from '../common/dateUtil';\n\ntype ExpectWithLocator = (l: Locator) => void;\n\nexport class ReleaseVariablesPage extends WithPage {\n addListValue: Locator;\n addVariableValue: Locator;\n listAddButton: Locator;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.addListValue = this.page.locator('.variable-selector .xl-components-input-full input');\n this.addVariableValue = this.page.locator('.variable-value .xl-components-input-full input');\n this.dateUtil = new DateUtil(page);\n this.listAddButton = this.page.getByRole('button', { name: 'Add' });\n }\n\n async openVariable(variableKey: string): Promise<ReleaseVariableModal> {\n await this.page.locator(`.variables-list .variable`).getByText(variableKey).click();\n return new ReleaseVariableModal(this.page);\n }\n\n async addNewVariable(variableName: string, labelname: string, description?: string): Promise<void> {\n await this.page.locator('#action-toolbar').getByText('New variable').click();\n await this.page.fill(`[name=\"fieldKey\"]`, variableName);\n await this.page.locator('.variable-label input').fill(labelname);\n if (description) await this.page.locator('.variable-description input').fill(description);\n }\n\n async selectVariableTextType(valuename: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('StringVariable');\n await this.page.locator('.variable-value').type(valuename);\n }\n\n async selectVariableListboxType(\n possiblevalue: Array<string> | string,\n defaultValue: string,\n required?: boolean,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n await this.addListValue.fill(value);\n await this.listAddButton.click();\n }\n } else {\n await this.addListValue.fill(possiblevalue);\n await this.listAddButton.click();\n }\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n } else {\n await this.page.getByRole('checkbox').uncheck();\n }\n }\n\n async selectVariablePasswordType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('PasswordStringVariable');\n await this.page.locator('input[type=\"password\"]').type(possiblevalue);\n }\n\n async selectVariableCheckboxType(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('BooleanVariable');\n await this.page.getByRole('checkbox').check();\n }\n\n async selectVariableNumberType(possiblevalue: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('IntegerVariable');\n await this.page.locator('input[ng-model=\"var.value\"]').fill(possiblevalue);\n }\n\n async selectVariableMultiListType(possiblevalue1: string, possiblevalue2: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MultiSelectListBox');\n await this.addListValue.fill(possiblevalue1);\n await this.listAddButton.click();\n await this.addListValue.fill(possiblevalue2);\n await this.listAddButton.click();\n await this.page.locator('.react-tagsinput').click();\n await this.page.getByText('Select all', { exact: true }).click();\n }\n\n async addVariableDate(): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DateVariable');\n await this.page.getByText('Select date').click();\n }\n\n async setDate(date?: string, monthYear?: string): Promise<void> {\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async addVariableKeyValueMap(keys1: string, values1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('MapStringStringVariable');\n await this.page.getByPlaceholder('key').fill(keys1);\n await this.page.getByPlaceholder('Value').fill(values1);\n await this.listAddButton.click();\n await this.page.locator('.xl-map-string-string-div-buttons .search-icon').click();\n await this.page.getByRole('row', { name: 'Search' }).getByRole('textbox').fill(keys1);\n const detail = await this.page.locator('table.table-condensed span').allInnerTexts();\n expect(detail[0]).toEqual(keys1);\n expect(detail[1]).toEqual(values1);\n }\n\n async addVariableSet(possiblevalue1: string): Promise<void> {\n await this.page.getByRole('combobox').selectOption('SetStringVariable');\n await this.page.locator('.dip-input input').fill(possiblevalue1);\n await this.listAddButton.click();\n }\n\n async submitTheVariable(): Promise<void> {\n const createButton = this.page.locator('.modal-footer .save');\n await expect(createButton).toBeEnabled();\n await createButton.scrollIntoViewIfNeeded();\n await createButton.click();\n // Expect is needed here to avoid flackiness on clicking create button\n await expect(createButton).not.toBeVisible();\n }\n\n async expectVariableWithNameValueAndType(name: string, value: string, type: string): Promise<void> {\n const rowLocator = await this.page.locator('.variable .data-row').allTextContents();\n expect(rowLocator.toString()).toContain(name);\n expect(rowLocator.toString()).toContain(value);\n expect(rowLocator.toString()).toContain(type);\n }\n\n async clickEditVariable(variableName: string): Promise<ReleaseVariableModal> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Edit').first().click();\n return new ReleaseVariableModal(this.page);\n }\n\n async clickDeleteVariable(variableName: string): Promise<DeleteVariableModel> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.locator('.action .delete-icon').first().click();\n return new DeleteVariableModel(this.page);\n }\n\n async expectVariablesCountToBe(count: number): Promise<void> {\n await expect(this.page.locator('.variable .data-row')).toHaveCount(count);\n }\n\n async expectVariableNotPresent(variableName: string): Promise<void> {\n await expect(this.page.locator('.variable').filter({ hasText: variableName })).not.toBeVisible();\n }\n\n async clearSearch(): Promise<void> {\n await this.page.locator(\"[id='variables-filter']\").clear();\n }\n\n async switchPossibleValuesToVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n }\n\n async selectVariableListboxTypeWithVariable(\n variableName: string,\n defaultValue: string,\n required?: boolean,\n ): Promise<void> {\n await this.page.getByRole('combobox').selectOption('DropDownListBox');\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n await this.page.locator('.variable-value select').type(defaultValue);\n if (required) {\n await this.page.getByRole('checkbox').check();\n } else {\n await this.page.getByRole('checkbox').uncheck();\n }\n }\n}\n\nclass ReleaseVariableModal extends WithPage {\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n }\n private async expectValue(locators: Locator[], expectFn: ExpectWithLocator[]): Promise<void> {\n const [index, locator] = await waitForOneOf(locators);\n expectFn[index](locator);\n }\n\n async expectValueToBe(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode .text-container'),\n ],\n [\n (l) => expect(l).toHaveValue(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n (l) => expect(l).toHaveText(value),\n ],\n );\n }\n\n async expectValueToContain(value: string): Promise<void> {\n await this.expectValue(\n [\n this.page.locator('#modal .variable-value input'),\n this.page.locator('#modal .variable-value .field-readonly'),\n this.page.locator('#modal .variable-value .xl-map-string-string'),\n this.page.locator('#modal .variable-value .xl-list-display-mode'),\n ],\n [\n (l) => expect(l.inputValue()).toContain(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n (l) => expect(l).toContainText(value),\n ],\n );\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async expectPossibleValues(possiblevalue: Array<string> | string): Promise<void> {\n const listLocator = await this.page.locator('.editor .xl-list-row').allInnerTexts();\n if (possiblevalue instanceof Array) {\n for (const value of possiblevalue) {\n expect(listLocator).toContain(value);\n }\n } else {\n expect(listLocator).toContain(possiblevalue);\n }\n }\n\n async expectPossibleVariableValues(possiblevariablevalue: string): Promise<void> {\n await expect(this.page.locator('.variable-dropdown input')).toHaveValue(possiblevariablevalue);\n }\n\n async addPossibleValue(value: Array<string> | string): Promise<void> {\n if (value instanceof Array) {\n for (const li of value) {\n await this.page.locator('.xl-components-input-full input').fill(li);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n } else {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n }\n\n async selectVariableValue(defaultValue: string): Promise<void> {\n await this.page.locator('.variable-value select').selectOption(defaultValue);\n }\n\n async save(): Promise<void> {\n const saveButton = this.page.locator('#modal .modal-footer .save');\n await saveButton.scrollIntoViewIfNeeded();\n await saveButton.click({ delay: 2000 });\n // Expect is needed here to avoid flackiness on clicking save button on modal window\n await expect(saveButton).not.toBeVisible();\n }\n\n async createPossibleValuesVariable(variableName: string): Promise<void> {\n await this.page.locator('.variable-toggle button').click();\n await this.page.locator('.ui-autocomplete-input').fill(variableName);\n await this.page\n .locator('.ui-menu-item-wrapper')\n .filter({ hasText: `${variableName}` })\n .click();\n }\n\n async expectVariableValueToBe(value: string): Promise<void> {\n expect(await this.page.locator('.variable-value select option[selected=\"selected\"]').textContent()).toBe(value);\n }\n\n async expectNoVariablesInList(): Promise<void> {\n await expect(this.page.getByText('No variables defined.')).toBeVisible();\n }\n\n async expectNameInput(value: string): Promise<void> {\n await expect(this.page.locator(`#modal .variable-name input`)).toHaveValue(value);\n }\n\n async expectLabel(value: string): Promise<void> {\n await expect(this.page.locator('#modal .variable-label input')).toHaveValue(value);\n }\n\n async expectRequired(value: boolean): Promise<void> {\n if (value == true) await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).toBeChecked();\n else await expect(this.page.locator('.form-group input[ng-model=\"var.requiresValue\"]')).not.toBeChecked();\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.locator('.variable-description input').click();\n await this.page.locator('.variable-description input').clear();\n await this.page.locator('.variable-description input').fill(description);\n }\n\n async setLabel(labelValue: string): Promise<void> {\n await this.page.locator('.variable-label input').fill(labelValue);\n }\n\n async setDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setValue(value: string): Promise<void> {\n await this.page.locator('.variable-value input').fill(value);\n }\n}\nclass DeleteVariableModel extends WithPage {\n model: ReleaseVariableModal;\n dateUtil: DateUtil;\n constructor(page: Page) {\n super(page);\n this.model = new ReleaseVariableModal(page);\n this.dateUtil = new DateUtil(page);\n }\n async deleteVariable(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n }\n\n async replaceItWithVariable(variable: string): Promise<void> {\n await this.model.createPossibleValuesVariable(variable);\n }\n\n async replaceItwithValue(value: string): Promise<void> {\n await this.page.locator('.display').click();\n await this.page.getByLabel('*').fill(value);\n }\n\n async clickReplaceAndDelete(): Promise<void> {\n await this.page.getByRole('button', { name: 'Replace and delete' }).click();\n }\n\n async addValue(value: string): Promise<void> {\n await this.page.locator('.xl-components-input-full input').fill(value);\n await this.page.getByRole('button', { name: 'Add' }).click();\n }\n\n async remove(value: string): Promise<void> {\n await this.page.locator('li').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async expectReplacementPromptDisplayed(): Promise<void> {\n await expect(this.page.getByRole('heading', { name: 'Replace and delete' })).toBeVisible();\n }\n\n async close(): Promise<void> {\n await this.page.locator('#modal .modal-header button.close').click();\n }\n\n async removeItemOnSet(value: string): Promise<void> {\n await this.page.locator('tr').filter({ hasText: value }).locator('i.close-icon').click();\n }\n\n async addValueForSet(key: string, value: string): Promise<void> {\n await this.page.locator('.input-key').fill(key);\n await this.page.locator('.input-value').fill(value);\n }\n\n async replaceWithIntegerValue(value: string): Promise<void> {\n await this.page.locator('.editable').fill(value);\n }\n\n async replaceForBooleanValue(): Promise<void> {\n await this.page.locator('.editor input').click();\n }\n\n async deleteBySettingDate(date: string, monthYear: string): Promise<void> {\n await this.page.locator('#modal .date').click();\n await this.dateUtil.setDate(date, monthYear);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class TaskListPage extends WithPage {\n commentBox: Locator;\n gridView: GridView;\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.commentBox = this.page.locator(`.input-block-level`);\n this.gridView = new GridView(page);\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async openTask(taskName: string): Promise<void> {\n await this.filterTaskByTitle(taskName);\n await this.page.getByText(taskName).first().click();\n await this.taskDrawer.waitForTaskDrawer();\n }\n\n async complete(taskName: string, comment: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('span.complete').click();\n await this.commentBox.click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Complete', exact: true }).click();\n }\n\n async skip(taskName: string, comment: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('span.skip').click();\n await this.commentBox.click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Skip', exact: true }).click();\n }\n\n async fail(taskName: string, comment: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('span.fail').click();\n await this.commentBox.click();\n await this.commentBox.fill(comment);\n await this.page.getByRole('button', { name: 'Fail', exact: true }).click();\n }\n\n async waitForTaskFailed(taskName: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`, { hasText: taskName }).getByText('Failed')).toBeVisible();\n }\n\n async waitForTaskInProgress(taskName: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`, { hasText: taskName }).getByText('In progress')).toBeVisible();\n }\n\n async openTaskInReleaseView(taskName: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator('a.view-in-release').click();\n }\n\n async openCalendarViaTaskDueDate(taskName: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).locator(`.calendar-link a`).click();\n }\n\n async openTaskDrawer(taskName: string): Promise<void> {\n await this.page.locator(`.row.task-inner`, { hasText: taskName }).getByText(taskName).click();\n await this.taskDrawer.waitForTaskDrawer();\n }\n\n async filterTaskByTitle(taskname: string): Promise<void> {\n await this.page.locator('.searchFilter').click();\n await this.page.locator('.searchFilter').fill(taskname);\n await this.page.locator('.searchFilter').press('Enter');\n await expect(this.page.locator('//div[@data-task-title]').filter({ hasText: taskname }).first()).toBeVisible();\n }\n\n async filterTasksByTag(tag: string, taskTitleForValidation: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').click();\n await this.page.locator('.tag-input').fill(tag);\n await this.page.locator('.tag-input').press('Enter');\n //TODO: Validation can be changed based on actual test case implementation\n await expect(\n this.page.locator('//div[@data-task-title]').filter({ hasText: taskTitleForValidation }),\n ).toBeVisible();\n }\n\n async filterTasksByReleaseTitle(releaseTitle: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').click();\n await this.page.locator('.release-input').fill(releaseTitle);\n await this.page.locator('.release-input').press('Enter');\n await expect(this.page.locator('.group-title').filter({ hasText: releaseTitle })).toBeVisible();\n }\n\n async openSingleTask(taskId: string, showDetails = false): Promise<void> {\n await this.page.goto(`./#/tasks/${taskId}?showDetails=${showDetails}`);\n }\n\n async expectReleaseLinksDisplayed(releaseTitle: string, displayed = true): Promise<void> {\n if (displayed) {\n await expect(this.page.getByRole('link', { name: '' + releaseTitle + '' })).toBeVisible();\n await expect(this.page.locator('.view-in-release')).toBeVisible();\n } else {\n await expect(this.page.getByRole('link', { name: '' + releaseTitle + '' })).not.toBeVisible();\n await expect(this.page.locator('.view-in-release')).not.toBeVisible();\n }\n }\n\n async openTaskList(): Promise<void> {\n await this.page.goto('./#/tasks');\n }\n\n async clickOnAssigneeButton(title: string): Promise<void> {\n await this.page.locator(`.btn-group-filter.btn-group button.btn.btn-flat[title=\"${title}\"]`).click();\n }\n\n async clickOnAssignedToMe(): Promise<void> {\n await this.page.locator(`button[title=\"Assigned to me\"]`).click();\n }\n\n async clickOnAssignedToMyTeams(): Promise<void> {\n await this.page.locator(`button[title=\"Assigned to my teams\"]`).click();\n }\n\n async clickOnAssignedToAllAvailable(): Promise<void> {\n await this.page.locator(`button[title=\"All available\"]`).click();\n }\n\n async expectTaskToNotBeDisplayed(taskTitle: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`).filter({ hasText: taskTitle }).getByText(taskTitle)).toHaveCount(\n 0,\n );\n }\n\n async expectTaskToBeDisplayed(taskTitle: string): Promise<void> {\n await expect(this.page.locator(`.row.task-inner`).filter({ hasText: taskTitle }).getByText(taskTitle)).toHaveCount(\n 1,\n );\n }\n\n async expectTasksToBeDisplayed(tasks: { [key: string]: boolean }): Promise<void> {\n for (const [taskTitle, shouldBeDisplayed] of Object.entries(tasks)) {\n if (shouldBeDisplayed) {\n await this.expectTaskToBeDisplayed(taskTitle);\n } else {\n await this.expectTaskToNotBeDisplayed(taskTitle);\n }\n }\n }\n\n async expectTasksDisplayedInOrder(\n expectedTasks: { releaseTitle: string; taskPosition: number; taskTitle: string }[],\n ): Promise<void> {\n for (const task of expectedTasks) {\n const taskElement = await this.page\n .locator(`[data-release-title='${task.releaseTitle}'] .row .task`)\n .nth(task.taskPosition);\n await expect(taskElement).toHaveAttribute('data-task-title', task.taskTitle);\n }\n }\n\n async setOrderBy(orderBy: string): Promise<void> {\n await this.page.locator('.order-selector .btn:first-child').click();\n await this.page.locator(`.order-selector .bootstrap-link:has-text('${orderBy}')`).click();\n }\n\n async expectTaskCountForRelease(releaseTitle: string, expectedCount: number): Promise<void> {\n await expect(\n this.page.locator(`#tasks-content #task-list-grouped-view div:has-text('${releaseTitle}') .task`),\n ).toHaveCount(expectedCount);\n }\n\n async setSearchFilter(filterText: string): Promise<void> {\n await this.page.locator('.searchFilter').fill(filterText);\n }\n\n async clearSearchFilter(): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n }\n\n async setTagsFilter(filterText: string): Promise<void> {\n await this.page.locator('.tag-input').fill(filterText);\n await this.page.locator('.tag-input').press('Enter');\n }\n\n async clickOnStatusField(): Promise<void> {\n await this.page.locator('.ci-filter-status.ng-isolate-scope').click();\n }\n\n async clickOnStatus(statusNames: string[]): Promise<void> {\n await this.clickOnStatusClearAll();\n await this.clickOnStatusField();\n for (let i = 0; i < statusNames.length; i++) {\n await this.page.locator(`i.xl-icon.icon-s.checkbox[data='${statusNames[i]}']`).click();\n }\n // Clicking outside to close the grid dropdown\n await this.clickOnTasksLabel();\n }\n\n async clickOnStatusClearAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Clear all' }).click();\n await this.clickOnTasksLabel();\n }\n\n async clickOnStatusSelectAll(): Promise<void> {\n await this.clickOnStatusField();\n await this.page.locator('a.xl-react-link', { hasText: 'Select all' }).click();\n await this.clickOnTasksLabel();\n }\n\n async assignTaskToMe(title: string): Promise<void> {\n await this.page.locator(`.task-line`).filter({ hasText: title }).locator(`.assign-to-me`).click();\n await this.page.locator('.modal:visible >> text=\"Assign to me\"').click();\n }\n\n async expectTaskAssignedToMe(title: string): Promise<void> {\n await this.expectTaskAssignedTo(title, 'me');\n }\n\n async expectTaskAssignedTo(title: string, user: string): Promise<void> {\n await expect(this.page.locator(`.task-line:has-text(\"${title}\") >> text=\"${user}\"`).first()).toHaveCount(1);\n }\n\n async expectTaskTitle(taskTitle: string): Promise<void> {\n await expect(this.page.locator('#tasks0')).toContainText(taskTitle);\n }\n\n async clickOnTasksLabel(): Promise<void> {\n await this.page.getByLabel('breadcrumb').getByText('Tasks').click();\n }\n\n async expectGroupView(expected = true): Promise<void> {\n if (expected) {\n await expect(this.page.locator('#group-tasks-by-release')).toBeChecked();\n await expect(this.page.locator('#task-list-grouped-view')).toBeVisible();\n await expect(this.page.locator('#task-ungrouped-view')).not.toBeVisible();\n } else {\n await expect(this.page.locator('#group-tasks-by-release')).not.toBeChecked();\n await expect(this.page.locator('#task-list-grouped-view')).not.toBeVisible();\n await expect(this.page.locator('#task-ungrouped-view')).toBeVisible();\n }\n }\n\n async changeGroupView(): Promise<void> {\n await this.page.locator('#group-tasks-by-release').click();\n }\n\n async enableGroupByReleaseView(): Promise<void> {\n await this.page.getByRole('checkbox', { name: 'Group by release' }).check();\n }\n\n async disableGroupByReleaseView(): Promise<void> {\n await this.page.getByRole('checkbox', { name: 'Group by release' }).uncheck();\n }\n\n async switchToGridView(): Promise<GridView> {\n await this.page.locator('.xl-icon.grid-icon').click();\n return this.gridView;\n }\n}\n\nclass GridView extends WithPage {\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n }\n\n async expectTaskCountInGridView(count: number): Promise<void> {\n await expect(this.page.locator('task-grid .task-wrapper')).toHaveCount(count);\n }\n\n // eslint-disable-next-line max-params\n async expectTaskDetailsInGridView(\n taskId: string,\n taskStatus: string,\n taskTitle: string,\n assignedTo?: string,\n release?: string,\n phase?: string,\n startDate?: string,\n ): Promise<this> {\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] .label`)).toContainText(taskStatus);\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] .title`)).toContainText(taskTitle);\n if (assignedTo)\n await expect(\n this.page.locator(`[data-test-id=\"${taskId}\"] span`).filter({ hasText: 'Assigned to ' }).first(),\n ).toContainText(assignedTo);\n if (release)\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] [data-test=\"release\"]`)).toContainText(release);\n if (phase)\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] [data-test=\"phase\"] span`)).toContainText(phase);\n if (startDate) {\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] [data-test=\"started\"]`)).toContainText(startDate);\n } else {\n await expect(this.page.locator(`[data-test-id=\"${taskId}\"] .caption`).getByText('Started')).not.toBeVisible();\n }\n return this;\n }\n\n async openTaskDrawerFromGridView(taskId: string, taskTitle: string): Promise<TaskDrawer> {\n await this.page.locator(`[data-test-id=\"${taskId}\"] .title`).filter({ hasText: taskTitle }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openContextualMenu(taskId: string): Promise<void> {\n await this.page.locator(`[data-test-id=\"${taskId}\"] .xl-icon.options-icon`).click();\n }\n\n async expectContextMenuHas(taskId: string, enabled: Array<string>, disabled: Array<string>): Promise<this> {\n await this.openContextualMenu(taskId);\n for (const e of enabled) {\n await expect(\n this.page.locator(`[data-test-id=\"${taskId}\"] #context-menu-container li:not(.disabled) a`).getByText(e),\n ).toBeVisible();\n }\n for (const e of disabled) {\n await expect(\n this.page.locator(`[data-test-id=\"${taskId}\"] #context-menu-container li.disabled a`).getByText(e),\n ).toBeVisible();\n }\n return this;\n }\n\n async waitForTaskNotDisplayed(taskId: string): Promise<this> {\n await expect(this.page.locator(`div.task[data-test-id=${taskId}]`)).not.toBeVisible();\n return this;\n }\n\n async triggerContextMenuAction(action: string): Promise<this> {\n await this.page.locator(`#context-menu-container li a`).filter({ hasText: action }).click();\n if (action === 'Complete') {\n await this.page.locator('#modal textarea[mentio]').fill('complete');\n await this.page.locator('#modal button.primary').filter({ hasText: 'Complete' }).click();\n return this;\n }\n return this;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { DateUtil } from '../common/dateUtil';\n\nexport class TemplatePropertiesPage extends WithPage {\n dateUtil: DateUtil;\n scheduledStartDate: Locator;\n constructor(page: Page) {\n super(page);\n this.dateUtil = new DateUtil(page);\n this.scheduledStartDate = this.page.locator(`.scheduled-start-date .date`);\n }\n\n async getAttachmentsListCount(): Promise<number> {\n return await this.page.locator('.attachments tr').count();\n }\n\n async uploadFile(filePath: string): Promise<void> {\n const fileChooserPromise = this.page.waitForEvent('filechooser');\n await this.page.locator('input[type=\"file\"]').click();\n const fileChooser = await fileChooserPromise;\n await fileChooser.setFiles(filePath);\n }\n\n async expectWithAttachment(filename: string): Promise<void> {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).toBeVisible();\n }\n\n async expectWithNoAttachment(filename: string): Promise<void> {\n const test = await this.page.locator('.attachments').isVisible();\n if (test) {\n await expect(this.page.locator('.attachments tr td a').filter({ hasText: filename })).not.toBeVisible();\n }\n }\n\n async downloadFile(filename: string): Promise<void> {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n const downloadPromise1 = this.page.waitForEvent('download');\n await this.page.getByText(filename).click();\n const download = await downloadPromise1;\n // Wait for the download process to complete and save the downloaded file in given path.\n await download.saveAs('./core/xlr-ui/build/playwright/' + download.suggestedFilename());\n expect(download.suggestedFilename()).toBe(filename);\n }\n\n async deleteAttachment(fileName: string): Promise<void> {\n await this.page.getByRole('row', { name: fileName }).locator('span').click();\n await this.page.getByText('Remove').click();\n }\n\n async save(): Promise<void> {\n await this.page.getByRole('button', { name: 'Save' }).click({ timeout: 8000 });\n await expect(this.page.locator('.form-footer .last-saved')).toBeVisible();\n }\n\n async reset(): Promise<void> {\n await this.page.getByRole('button', { name: 'Reset' }).waitFor();\n await this.page.getByRole('button', { name: 'Reset' }).click();\n }\n\n async removeDueDate(): Promise<void> {\n await this.page.locator('.due-date .close-icon').click();\n }\n\n async setScheduledStartDate(date: string, monthYear: string): Promise<void> {\n await this.scheduledStartDate.click();\n await this.dateUtil.setDate(date, monthYear);\n }\n\n async setDuration(days?: string, hours?: string, mins?: string): Promise<void> {\n await this.page.locator('.duration-editor').click();\n if (typeof days !== 'undefined') {\n await this.page.locator('.days').fill(days);\n }\n if (typeof hours !== 'undefined') {\n await this.page.locator('.hours').fill(hours);\n }\n if (typeof mins !== 'undefined') {\n await this.page.locator('.minutes').fill(mins);\n }\n }\n\n async expectScheduledStartDateToBe(date: string): Promise<void> {\n expect(await this.page.locator(`.scheduled-start-date .date input`).getAttribute('value')).toBe(date);\n }\n\n async expectDueDateToBe(date: string): Promise<void> {\n expect(await this.page.locator('.due-date .date-editor .date > .light-text').getAttribute('value')).toContain(date);\n }\n\n async expectedDueDateTime(time: string): Promise<void> {\n expect(await this.page.locator('.due-date .date-editor .time-picker-holder input').getAttribute('value')).toContain(\n time,\n );\n }\n\n async expectDurationToBe(duration: string): Promise<void> {\n expect(await this.page.locator('.duration-editor').textContent()).toBe(duration);\n }\n\n async setUsername(username: string): Promise<void> {\n await this.page.locator('.script-username').click();\n await this.page.locator('user-input-with-variable').getByLabel('*').fill(username);\n await this.page.locator('user-input-with-variable').press('Enter');\n }\n\n async setPassword(password: string): Promise<void> {\n await this.page.locator('.field > .display').click();\n await this.page.locator('input[name=\"scriptUserPassword\"]').fill(password);\n await this.page.locator('input[name=\"scriptUserPassword\"]').press('Enter');\n }\n\n async expectScriptUsernameToBe(username: string): Promise<void> {\n expect(await this.page.locator('.script-username').textContent()).toContain(username);\n }\n\n async expectScriptUserPasswordToBe(password: string): Promise<void> {\n expect(await this.page.locator('span[name=\"scriptUserPassword\"]').textContent()).toContain(password);\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TemplateCreatePage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setName(name: string): Promise<void> {\n await this.page.locator('#release-form-title').fill(name);\n }\n\n async setDescription(description: string): Promise<void> {\n await this.page.getByText('Set description...').hover();\n await this.page.locator('.display').filter({ hasText: 'Set description' }).locator('.edit-icon').click();\n await this.page.locator('textarea').click();\n await this.page.locator('textarea').clear();\n await this.page.locator('textarea').fill(description);\n await this.page.getByText('Save', { exact: true }).click();\n }\n\n async create(): Promise<void> {\n await this.page.getByRole('button', { name: 'Create' }).click();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TemplateTriggerPage extends WithPage {\n create: CreateNewTriggerPage;\n constructor(page: Page) {\n super(page);\n this.create = new CreateNewTriggerPage(page);\n }\n\n async expectAllowConcurrentReleasesFromTrigger(expectedValue: boolean): Promise<void> {\n if (expectedValue) {\n await this.page.locator('.col-xs-2 .trigger-item-state').textContent({ timeout: 3000 });\n expect(await this.page.locator('.col-xs-2 .trigger-item-state').textContent()).toContain('Enabled');\n } else {\n await this.page.locator('.col-xs-2 .trigger-item-state').textContent({ timeout: 3000 });\n expect(await this.page.locator('.col-xs-2 .trigger-item-state').textContent()).toContain('Disabled');\n }\n }\n\n async setAllowConcurrentReleasesFromTriggerAndSubmit(checked: boolean): Promise<void> {\n const result = await this.page.locator('.col-xs-2 .trigger-item-state').textContent({ timeout: 3000 });\n if ((result === 'Enabled' && checked === false) || (result == 'Disabled' && checked === true)) {\n await this.page.locator('form[name=\"releaseTriggerOptions\"] label[for=\"cb\"]').click();\n }\n }\n\n async expectTriggersVisible(amount: number): Promise<void> {\n await expect(this.page.locator('.xlr-trigger-row .trigger-row-content')).toHaveCount(amount);\n }\n\n async expectNoNewTriggerButtonShown(): Promise<void> {\n await expect(this.page.locator('.trigger-header a.button.primary')).not.toBeVisible();\n }\n\n async clickAddTrigger(): Promise<CreateNewTriggerPage> {\n await this.page.getByRole('button', { name: 'Add trigger' }).click();\n return new CreateNewTriggerPage(this.page);\n }\n\n async openContextualMenuForTrigger(triggerName: string): Promise<this> {\n await this.page\n .locator('.xlr-trigger-row')\n .filter({ has: this.page.locator('div[data-test-column=\"triggerTitle\"]').getByText(triggerName) })\n .locator('.context-menu-button')\n .click();\n return this;\n }\n\n async selectContextualMenuItem(triggerName: string, menuItem: string): Promise<this> {\n await this.openContextualMenuForTrigger(triggerName);\n await this.page.locator('#context-menu-container').getByRole('menuitem', { name: menuItem }).click();\n return this;\n }\n}\n\nexport class CreateNewTriggerPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setTriggerTitle(title: string): Promise<void> {\n await this.page.locator('#title').fill(title);\n }\n\n async setTriggerType(triggerType: string): Promise<void> {\n await this.page.getByRole('textbox', { name: 'Select trigger type...' }).click();\n await this.page.getByRole('textbox', { name: 'Select trigger type...' }).fill(triggerType);\n await this.page.getByText(triggerType).click();\n }\n\n async setFieldInput(field: string, value: string): Promise<void> {\n await this.page.getByRole('textbox', { name: field }).click();\n await this.page.getByRole('textbox', { name: field }).fill(value);\n }\n\n async setValuesForVariable(variableId: string, value: string): Promise<this> {\n await this.page.locator(`#${variableId}`).scrollIntoViewIfNeeded();\n await this.page.locator(`#${variableId}`).click();\n await this.page.locator(`#${variableId} input`).clear();\n await this.page.locator(`#${variableId} input`).fill(value);\n return this;\n }\n\n async save(): Promise<void> {\n await expect(this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Save' })).toBeEnabled();\n await this.page.locator('.action-toolbar-actions button').filter({ hasText: 'Save' }).click({ force: true });\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TemplateVariablesPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async clickEditVariable(variableName: string): Promise<TemplateVariableModal> {\n await this.page.locator(\"[id='variables-filter']\").fill(variableName);\n await this.page.getByText('Edit').click();\n return new TemplateVariableModal(this.page);\n }\n}\n\nclass TemplateVariableModal extends WithPage {\n async setLabel(label: string): Promise<void> {\n await this.page.locator('.variable-label input').fill(label);\n }\n\n async setDefalutValue(value: string): Promise<void> {\n await this.page.locator('.variable-value input').fill(value);\n }\n\n async save(): Promise<void> {\n await this.page.locator('#modal .button.save').click();\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\nimport { TemplatePropertiesPage } from './templatePropertiesPage';\nimport { TemplateCreatePage } from './templateCreatePage';\nimport { TemplateTriggerPage } from './templateTriggerPage';\nimport { TemplateVariablesPage } from './templateVaraiablePage';\nimport { Util } from '../common/util';\nimport { ReleaseGanttPage } from '../releases/releaseGanttPage';\n\nexport class TemplatePage extends WithPage {\n taskDrawer: TaskDrawer;\n phaseTitle: Locator;\n properties: TemplatePropertiesPage;\n createTemplatePage: TemplateCreatePage;\n triggers: TemplateTriggerPage;\n util: Util;\n variables: TemplateVariablesPage;\n plannerView: ReleaseGanttPage;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n this.phaseTitle = page.locator('.phase .phase-title');\n this.properties = new TemplatePropertiesPage(page);\n this.createTemplatePage = new TemplateCreatePage(page);\n this.triggers = new TemplateTriggerPage(page);\n this.util = new Util(page);\n this.variables = new TemplateVariablesPage(page);\n this.plannerView = new ReleaseGanttPage(page);\n }\n\n private async openTemplateMenu(menuItem: string): Promise<void> {\n await this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }).click();\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromTableView(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.name-cell-title').getByText(taskName, { exact: true }).click();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openTaskDrawerFromGrantt(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.gantt_tree_content').getByText(taskName, { exact: true }).dblclick();\n await this.taskDrawer.waitForTaskDrawer();\n return this.taskDrawer;\n }\n\n async openProperties(): Promise<void> {\n await this.util.openSideNavMenu('Properties');\n await expect(this.page.getByLabel('breadcrumb').getByText('Properties')).toBeVisible();\n }\n\n async openVariables(): Promise<void> {\n await this.util.openSideNavMenu('Variables');\n await expect(this.page.getByLabel('breadcrumb').getByText('Variables')).toBeVisible();\n }\n\n async openRelationships(): Promise<void> {\n await this.util.openSideNavMenu('Relationships');\n await expect(this.page.getByLabel('breadcrumb').getByText('Relationships')).toBeVisible();\n }\n\n async openTeamsPermissions(): Promise<void> {\n await this.util.openSideNavMenu('Teams & Permissions');\n await expect(this.page.getByLabel('breadcrumb').getByText('Teams & Permissions')).toBeVisible();\n }\n\n async openDashboard(): Promise<void> {\n await this.util.openSideNavMenu('Dashboard');\n await expect(this.page.getByLabel('breadcrumb').getByText('Dashboard')).toBeVisible();\n }\n\n async openHistory(): Promise<void> {\n await this.util.openSideNavMenu('History');\n await expect(this.page.getByLabel('breadcrumb').getByText('History')).toBeVisible();\n }\n\n async openTriggers(): Promise<void> {\n await this.openTemplateMenu('Triggers');\n await expect(this.page.getByLabel('breadcrumb').getByText('Triggers', { exact: true })).toBeVisible();\n }\n\n async backToTemplate(): Promise<void> {\n await this.page.locator('.icon-back').click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Templates')).toBeVisible();\n }\n\n async expectTemplateLabelToBePresent(): Promise<void> {\n await expect(this.page.getByTestId('template-workflow-pill').getByText('Template')).toBeVisible();\n }\n\n async expectSubPage(menuItem: string, toBePresent: boolean): Promise<void> {\n if (toBePresent)\n await expect(this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true })).toBeVisible();\n else\n await expect(\n this.page.locator(`navigation-sidebar ul li`).getByText(menuItem, { exact: true }),\n ).not.toBeVisible();\n }\n\n async openFlowView(): Promise<void> {\n await this.util.openSideNavMenu('Flow');\n await expect(this.page.locator('#release-content')).toBeVisible();\n }\n\n async openTableView(): Promise<void> {\n await this.util.openSideNavMenu('Table');\n await expect(this.page.locator('.release-grid-container')).toBeVisible();\n }\n\n async openPlannerView(): Promise<ReleaseGanttPage> {\n await this.util.openSideNavMenu('Planner');\n await expect(this.page.locator('.gantt-container')).toBeVisible();\n return this.plannerView;\n }\n\n async openCodeView(): Promise<void> {\n await this.util.openSideNavMenu('Code');\n await expect(this.page.getByLabel('breadcrumb').getByText('Code')).toBeVisible();\n }\n\n async expandGanttFolder(): Promise<void> {\n const icExpandTreeview1 = this.page.locator('.gantt_tree_icon.gantt_open');\n for (const element of await icExpandTreeview1.all()) {\n const blnVal = await element.isVisible();\n if (blnVal) {\n await element.click();\n await this.expandGanttFolder();\n }\n }\n }\n\n async addNewPhase(phaseName?: string): Promise<void> {\n await this.page.getByTestId('add-phase-btn').click();\n if (phaseName) {\n await this.phaseTitle.getByText('New Phase').click();\n await this.phaseTitle.getByRole('textbox').clear();\n await this.phaseTitle.getByRole('textbox').fill(phaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: phaseName })).toBeVisible();\n }\n }\n\n async renamePhase(oldPhaseName: string, newPhaseName: string): Promise<void> {\n await this.phaseTitle.getByText(oldPhaseName).click();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').clear();\n await this.phaseTitle.filter({ hasText: oldPhaseName }).locator('.editable').fill(newPhaseName);\n await this.page.keyboard.press('Enter');\n await expect(this.phaseTitle.filter({ hasText: newPhaseName })).toBeVisible();\n }\n\n async clickNewRelease(): Promise<void> {\n await this.page.getByTestId('new-release-btn').click();\n await expect(this.page.locator('.release-properties-form')).toBeVisible();\n }\n\n getPhase(phaseName: string): Phase {\n return new Phase(this.page, phaseName);\n }\n}\nclass Phase extends WithPage {\n private readonly phaseLocator: Locator;\n\n constructor(page: Page, phaseName: string) {\n super(page);\n this.phaseLocator = page.locator('.phase', { hasText: phaseName });\n }\n\n async setTitle(title: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header .display').click();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').clear();\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').fill(title);\n await this.phaseLocator.locator('.phase-header input[type=\"text\"]').blur();\n }\n\n async expectTaskBorderWithColor(taskName: string, color: string): Promise<void> {\n await expect(this.page.locator(`.task-box:has-text('${taskName}')`)).toHaveCSS('border-top-color', color);\n }\n\n /**\n *\n * @param taskTitle Title of the task\n * @param taskType : Type of the task\n * @param taskTypeSelector : Selector of the task\n */\n\n async addTaskInPhase(taskTitle: string, taskGroup: string, taskType: string): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.page.locator('#task-selector').hover();\n await this.page.locator('button[aria-label=\"Clear\"]').click();\n await this.page.locator('#task-selector').fill(taskGroup);\n await this.page.getByTestId(taskType).click();\n await this.page.locator('.icon-close').click();\n await this.page.locator('#task-title').fill(taskTitle);\n await this.page.getByTestId('save-select-task-btn').click();\n await this.page.locator('#release-header').click();\n await expect(this.phaseLocator.locator('.task-title').filter({ hasText: taskTitle })).toBeVisible();\n }\n\n async getNumberOfTasks(): Promise<number> {\n return await this.phaseLocator.locator('.task').count();\n }\n\n async expectToHaveNoneditableTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title > span')).toContainText(phaseTitle);\n }\n\n async expectToHaveTitle(phaseTitle: string): Promise<void> {\n await expect(this.phaseLocator.locator('.phase-title')).toContainText(phaseTitle);\n }\n\n async deleteTaskInPhase(taskName: string): Promise<void> {\n await this.page.locator('.task').filter({ hasText: taskName }).locator('.xl-icon.options-icon').click();\n await this.page.locator('.remove-task-button').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Task' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.phaseLocator.locator('li').filter({ hasText: taskName })).not.toBeVisible();\n }\n\n async deletePhase(phaseName: string): Promise<void> {\n await this.page.locator('.phase-header').filter({ hasText: phaseName }).locator('.actions').hover();\n await this.page.locator('.phase-header').filter({ hasText: phaseName }).locator('.delete-icon').click();\n await expect(this.page.getByRole('heading', { name: 'Delete Phase' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.phase-header').filter({ hasText: phaseName })).not.toBeVisible();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { TemplatePage } from './templates/templatePage';\n\nexport class TemplateListPage extends WithPage {\n templatePage: TemplatePage;\n constructor(page: Page) {\n super(page);\n this.templatePage = new TemplatePage(page);\n }\n\n async openTemplatesList(filter: string): Promise<void> {\n let url = '/templates';\n if (filter) {\n url += `?has_filter&filter=${filter}`;\n }\n await this.page.goto(url);\n }\n\n async searchBy(criteria: string): Promise<void> {\n await this.page.locator('.searchFilter').clear();\n await this.page.locator('.searchFilter').fill(criteria);\n }\n\n async copy(originTitle: string, targetTitle: string): Promise<void> {\n await this.page.locator('.title').filter({ hasText: originTitle }).locator('.copy').click();\n await this.page.getByLabel('Template name').clear();\n await this.page.getByLabel('Template name').fill(targetTitle);\n await this.page.getByLabel('Description').clear();\n await this.page.getByLabel('Description').fill('description');\n await this.page.getByRole('button', { name: 'Continue' }).click();\n await expect(this.page.getByTestId('template-workflow-pill').getByText('Template')).toBeVisible();\n }\n\n async move(templateName: string, targetFolder: string): Promise<void> {\n await this.page.locator('.template').filter({ hasText: templateName }).locator('.template-actions .move').click();\n await expect(this.page.getByText('Move template to')).toBeVisible();\n if (await this.page.getByRole('button', { name: 'Expand' }).isEnabled())\n await this.page.getByRole('button', { name: 'Expand' }).click();\n await this.page.getByPlaceholder('Search folder...').click();\n await this.page.getByPlaceholder('Search folder...').fill(targetFolder);\n await this.page.getByRole('button', { name: targetFolder }).click();\n await this.page.getByRole('button', { name: 'Move' }).click();\n await expect(this.page.getByText('Add', { exact: true })).toBeVisible();\n await expect(this.page.getByText('Remove')).toBeVisible();\n await this.page.getByRole('button', { name: 'Move' }).click();\n }\n\n async metaInformation(templateName: string, validationMsg?: string): Promise<void> {\n await this.page.locator('.title').filter({ hasText: templateName }).locator('.template-context-menu').click();\n await this.page.getByRole('menuitem', { name: 'Meta information' }).locator('a').click();\n await expect(this.page.getByRole('heading', { name: 'Meta information - ' + templateName })).toBeVisible();\n if (validationMsg) {\n await expect(this.page.getByText(validationMsg)).toBeVisible();\n }\n await expect(this.page.getByRole('button', { name: 'Close' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Close' }).click();\n }\n\n async expectTemplateVisible(title: string, expected = true): Promise<void> {\n if (expected) {\n await this.page.locator('.template').filter({ hasText: title }).waitFor();\n expect(this.page.locator('.template').filter({ hasText: title })).toBeVisible();\n } else {\n await this.page.locator('.template').filter({ hasText: title }).waitFor();\n expect(this.page.locator('.template').filter({ hasText: title })).not.toBeVisible();\n }\n }\n\n async delete(title: string): Promise<void> {\n await this.searchBy(title);\n await this.page.locator('.title').filter({ hasText: title }).locator('.delete').waitFor();\n await this.page.locator('.title').filter({ hasText: title }).locator('.delete').click();\n await this.page.locator('.modal .modal-content').waitFor({ state: 'visible' });\n await this.page.getByRole('button', { name: 'Delete' }).click();\n await expect(this.page.locator('.title').filter({ hasText: title })).not.toBeVisible();\n }\n\n async clickCreateNewTemplate(): Promise<void> {\n await this.page.locator('.action-toolbar-actions').getByRole('button', { name: 'New template' }).click();\n await this.page.locator('.action-toolbar-actions').getByRole('menuitem', { name: 'Create new template' }).click();\n }\n\n async openTemplateByName(templateName: string): Promise<void> {\n await this.filterByTitle(templateName);\n await this.page.locator(`.template`).filter({ hasText: templateName }).locator(`.raised-link`).waitFor();\n await this.page.locator(`.template`).filter({ hasText: templateName }).locator(`.raised-link`).click();\n }\n\n async clickNewReleaseIcon(templateName: string): Promise<void> {\n await this.page\n .locator('xlr-template-row-component')\n .filter({ hasText: templateName })\n .locator('.link .add-icon')\n .click();\n await expect(this.page.getByRole('heading', { name: 'Create new release' })).toBeVisible();\n }\n\n async createTemplate(templateName: string, description: string): Promise<void> {\n await this.clickCreateNewTemplate();\n await this.templatePage.createTemplatePage.setName(templateName);\n await this.templatePage.createTemplatePage.setDescription(description);\n await this.templatePage.createTemplatePage.create();\n await expect(this.page.getByLabel('breadcrumb').getByText('Flow')).toBeVisible();\n }\n\n async filterByTitle(templateName: string): Promise<void> {\n await this.page.getByPlaceholder('Filter by title...', { exact: true }).click();\n await this.page.getByPlaceholder('Filter by title...', { exact: true }).fill(templateName);\n await this.page.getByPlaceholder('Filter by title...', { exact: true }).press('Enter');\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class RolesModal extends WithPage {\n roleName: Locator;\n newRoleName: Locator;\n addPrincipal: Locator;\n saveButton: Locator;\n editIcon: Locator;\n deleteButton: Locator;\n searchRoles: Locator;\n constructor(page: Page) {\n super(page);\n this.roleName = page.locator('Role name *');\n this.newRoleName = page.locator('Role name *');\n this.addPrincipal = page.locator('Add a principal...');\n this.saveButton = page.getByRole('button', { name: 'Save' });\n this.editIcon = page.getByRole('row', { name: '' }).getByLabel('Edit', { exact: true });\n this.deleteButton = page.getByRole('button', { name: 'Delete' });\n this.searchRoles = page.getByPlaceholder('Search roles...');\n }\n\n async setRoleName(roleName: string): Promise<void> {\n return await this.page.getByLabel('Role name *').fill(roleName, { timeout: 1000 });\n }\n\n async editRoleName(newRoleName: string): Promise<void> {\n return await this.page.getByLabel('Role name *').fill(newRoleName, { timeout: 1000 });\n }\n\n async setPrincipal(addPrincipal: string): Promise<void> {\n await this.page.getByPlaceholder('Add a principal...').fill(addPrincipal, { timeout: 1000 });\n }\n\n async searchRoleByRoleName(searchRoles: string): Promise<void> {\n await this.page.getByPlaceholder('Search roles...').fill(searchRoles, { timeout: 1000 });\n }\n async save(): Promise<void> {\n await this.saveButton.isEnabled();\n await expect(this.saveButton).not.toBeDisabled();\n await this.saveButton.focus();\n await this.saveButton.click();\n }\n\n async delete(): Promise<void> {\n await this.deleteButton.click();\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { RolesModal } from './rolesModal';\n\nexport class RolesPage extends WithPage {\n page: Page;\n newRoleButton: Locator;\n modal: RolesModal;\n\n constructor(page: Page) {\n super(page);\n this.page = page;\n this.newRoleButton = this.page.getByTestId('new-role-btn');\n this.modal = new RolesModal(page);\n }\n\n async createRole(roleName: string, addPrincipal: string): Promise<void> {\n await this.newRoleButton.click();\n await this.modal.setRoleName(roleName);\n await this.modal.setPrincipal(addPrincipal);\n await this.modal.save();\n await this.expectToViewCreatedRole(roleName);\n }\n\n async editRole(roleName: string, newRoleName: string): Promise<void> {\n await this.page.getByRole('row', { name: roleName }).getByLabel('Edit', { exact: true }).click();\n await this.modal.editRoleName(newRoleName);\n await this.modal.save();\n }\n\n async searchRoleByRoleName(searchRoles: string): Promise<void> {\n await this.page.getByPlaceholder('Search roles...').fill(searchRoles, { timeout: 1000 });\n }\n\n async searchRoleByAssignedUsername(searchRolesByUsername: string): Promise<void> {\n await this.page\n .getByPlaceholder('Search assigned usernames or external groups...')\n .fill(searchRolesByUsername, { timeout: 1000 });\n }\n\n async deleteRole(roleName: string): Promise<void> {\n await this.page.getByRole('row', { name: roleName }).getByLabel('Delete', { exact: true }).click();\n await this.modal.delete();\n }\n\n async expectToViewRolesPage(): Promise<void> {\n await expect(this.page.locator('text=Principals')).toBeVisible();\n }\n\n async expectToViewCreatedRole(roleName: string): Promise<void> {\n await expect(this.page.getByRole('cell', { name: roleName })).toBeVisible();\n }\n\n async expectToViewEditedRole(roleName: string): Promise<void> {\n await expect(this.page.getByRole('cell', { name: roleName })).toBeVisible();\n }\n\n async expectRoleToBeDeleted(roleName: string): Promise<void> {\n await expect(this.page.getByRole('cell', { name: roleName })).toBeHidden();\n }\n\n async expectToViewSearchedRole(roleName: string): Promise<void> {\n await expect(this.page.locator('roles-page')).toContainText(roleName);\n }\n\n async expectToViewSearchedRoleByUsername(userName: string): Promise<void> {\n await expect(this.page.locator('roles-page')).toContainText(userName);\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class RisksPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async getValue(classIdentifier: string): Promise<string> {\n return await this.page.locator(`.rz-bubble.${classIdentifier}-label`).innerText();\n }\n\n async setPointerValue(elem: Locator, value: number, isIncrease: boolean): Promise<void> {\n await elem.waitFor({ state: 'visible' });\n await elem.click();\n for (let i = 0; i < value; i++) {\n if (isIncrease) {\n await this.page.keyboard.press('ArrowRight');\n } else {\n await this.page.keyboard.press('ArrowLeft');\n }\n await elem.click();\n }\n }\n\n async setValue(identifier: string, newValue: number): Promise<void> {\n const value = await this.getValue(identifier);\n const initialDiff = newValue - parseInt(value);\n const elem = this.page.locator(`.rz-pointer-${identifier}`);\n const diffValue = Math.abs(initialDiff);\n await this.setPointerValue(elem, diffValue, initialDiff > 0);\n await this.checkValue(identifier, newValue);\n }\n\n async checkValue(identifier: string, value: number): Promise<void> {\n expect(await this.getValue(identifier)).toEqual(value.toString());\n }\n\n async shouldHaveEditButton(present = true): Promise<void> {\n const locator = this.page.locator('#editRisk');\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async shouldHaveSaveButton(present = true): Promise<void> {\n const locator = this.page.getByTestId('save-btn');\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async startEditGlobalRiskThreshold(): Promise<void> {\n await this.page.locator('#editRisk').click();\n }\n\n async setInitialValues(): Promise<void> {\n await this.setValue('min', 10);\n await this.setValue('max', 50);\n }\n\n async changeValuesAndSave(minValue: number, maxValue: number): Promise<void> {\n await this.setValue('min', minValue);\n await this.setValue('max', maxValue);\n await this.page.locator('#submit').click();\n }\n\n async checkValuesChanged(minValue: number, maxValue: number): Promise<void> {\n await this.checkValue('min', minValue);\n await this.checkValue('max', maxValue);\n }\n\n async expectRiskProfileToBePresent(title: string, present = true): Promise<void> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n const locator = this.page.locator('.risk-profile .data-row').filter({ hasText: title });\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async expectDefaultRiskProfileToBeFirst(): Promise<void> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n await expect(this.page.locator('.risk-profile .data-row .ng-binding').first()).toHaveText('Default risk profile');\n }\n\n async openRiskProfile(title: string): Promise<RisksProfilePage> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).click();\n return new RisksProfilePage(this.page);\n }\n\n async shouldHaveCopyButtonEnabledForRiskProfile(title: string, enabled = true): Promise<void> {\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).waitFor({ state: 'visible' });\n const locator = this.page.locator('.risk-profile .data-row').filter({ hasText: title }).locator('.copy-action');\n if (enabled) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async shouldHaveDeleteButtonEnabledForRiskProfile(title: string, enabled = true): Promise<void> {\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).waitFor({ state: 'visible' });\n const locator = this.page.locator(`.risk-profile .data-row`).filter({ hasText: title }).locator(`.remove-action`);\n if (enabled) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async clickNewRiskProfile(): Promise<RisksProfilePage> {\n await this.page.getByTestId('new-risk-btn').waitFor({ state: 'visible' });\n await this.page.getByTestId('new-risk-btn').click();\n return new RisksProfilePage(this.page);\n }\n\n async deleteRiskProfile(title: string): Promise<void> {\n await this.page\n .locator('.risk-profile .data-row')\n .filter({ hasText: title })\n .locator('.remove-action')\n .waitFor({ state: 'visible' });\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).locator('.remove-action').click();\n await this.page.locator('.modal-footer .button.save').click();\n }\n\n async expectSuccessMessageOnRisksPage(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Risk Profile Created Successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async copyRiskProfile(title: string): Promise<void> {\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).waitFor({ state: 'visible' });\n await this.page.locator('.risk-profile .data-row').filter({ hasText: title }).locator('.copy-action').click();\n }\n\n async expectSuccessMessageOnUpdateRiskProfile(): Promise<void> {\n await expect(this.page.getByLabel('success')).toBeVisible();\n await expect(this.page.locator('.success').filter({ hasText: 'Risk Profile Updated Successfully' })).toBeVisible();\n await this.closeNotificationBanner();\n }\n\n async filter(filterText: string): Promise<void> {\n await this.page.locator('#risk-profile-filter').waitFor({ state: 'visible' });\n await this.page.locator('#risk-profile-filter').clear();\n await this.page.locator('#risk-profile-filter').fill(filterText);\n }\n\n async shouldHaveNVisibleRiskProfiles(numberOfVisibleRiskProfiles: number): Promise<void> {\n await this.page.locator('#risk-profile-table').waitFor({ state: 'visible' });\n expect(await this.page.locator('#risk-profile-table .data-row').count()).toEqual(numberOfVisibleRiskProfiles);\n }\n\n async shouldHaveNewRiskProfileButton(present = true): Promise<void> {\n const locator = this.page.getByTestId('new-risk-btn');\n if (present) {\n await expect(locator).toBeVisible();\n } else {\n await expect(locator).not.toBeVisible();\n }\n }\n\n async closeNotificationBanner(): Promise<void> {\n const closeIcon = this.page.getByTestId(`CloseIcon`);\n if (await closeIcon.isVisible()) {\n await closeIcon.click();\n }\n }\n}\n\nclass RisksProfilePage extends WithPage {\n async shouldBeEditable(editable: boolean): Promise<void> {\n const elem = this.page.locator('#riskProfileTitle');\n if (editable) {\n await expect(elem).toBeEnabled();\n } else {\n await expect(elem).toBeDisabled();\n }\n }\n\n async setName(name: string): Promise<void> {\n await this.page.locator('#riskProfileTitle').waitFor({ state: 'visible' });\n await this.page.locator('#riskProfileTitle').click();\n await this.page.locator('#riskProfileTitle').clear();\n await this.page.locator('#riskProfileTitle').fill(name);\n }\n\n async save(): Promise<void> {\n await this.page.getByTestId('save-btn').click();\n await expect(this.page.locator('#risk-profile-table')).toBeVisible();\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class advancedSettingsPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n}\n","import { Page, expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class experimentalSettingsPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async getFeatureControl(feature: string, control: string): Promise<Locator> {\n return this.page.locator(`.settings-card`).filter({ hasText: feature }).locator(`#${control}`);\n }\n\n async expectFeatureToBeEnabled(feature: string, state: boolean, control: string): Promise<this> {\n if (state) await expect(await this.getFeatureControl(feature, control)).toBeChecked();\n else await expect(await this.getFeatureControl(feature, control)).not.toBeChecked();\n return this;\n }\n\n async expectSaveToBeEnabled(state: boolean): Promise<this> {\n if (state) await expect(this.page.getByTestId(`save-button`)).toBeEnabled();\n else await expect(this.page.getByTestId(`save-button`)).not.toBeEnabled();\n return this;\n }\n\n async expectResetToBeEnabled(state: boolean): Promise<this> {\n if (state) await expect(this.page.getByTestId('reset-button')).toBeEnabled();\n else await expect(this.page.getByTestId('reset-button')).not.toBeEnabled();\n return this;\n }\n\n async disableFeature(feature: string, control: string): Promise<this> {\n await this.page.locator(`.settings-card`).filter({ hasText: feature }).locator(`#${control}`).uncheck();\n return this;\n }\n\n async expectToBeSaved(): Promise<this> {\n await expect(this.page.locator('.dot-snackbar[severity=\"success\"]')).toBeVisible();\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class TaskSettingsPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async setStatusPollingInterval(value: string): Promise<this> {\n await this.page.locator('#taskStatusInterval').clear();\n await this.page.locator('#taskStatusInterval').fill(value);\n return this;\n }\n\n async setListPollingInterval(value: string): Promise<this> {\n await this.page.locator('#taskListInterval').clear();\n await this.page.locator('#taskListInterval').fill(value);\n return this;\n }\n\n async expectStatusPollingInterval(value: string): Promise<this> {\n await expect(this.page.locator('#taskStatusInterval')).toHaveValue(value);\n return this;\n }\n\n async expectListPollingInterval(value: string): Promise<this> {\n await expect(this.page.locator('#taskListInterval')).toHaveValue(value);\n return this;\n }\n\n async restoreDefaultPollingSettings(): Promise<this> {\n const defaultTaskStatusInterval = '1';\n const defaultTaskListInterval = '30';\n\n await this.setStatusPollingInterval(defaultTaskStatusInterval);\n await this.setListPollingInterval(defaultTaskListInterval);\n\n await this.settings.save();\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class ReportsSettingsPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async setWarningThreshold(value: string): Promise<this> {\n await this.page.locator('#warningThreshold').clear();\n await this.page.locator('#warningThreshold').fill(value);\n return this;\n }\n\n async setErrorThreshold(value: string): Promise<this> {\n await this.page.locator('#errorThreshold').clear();\n await this.page.locator('#errorThreshold').fill(value);\n return this;\n }\n\n async setCriticalPhaseThreshold(value: string): Promise<this> {\n await this.page.locator('#criticalPhaseThreshold').clear();\n await this.page.locator('#criticalPhaseThreshold').fill(value);\n return this;\n }\n\n async expectWarningThreshold(value: string): Promise<this> {\n await expect(this.page.locator('#warningThreshold')).toHaveValue(value);\n return this;\n }\n\n async expectErrorThreshold(value: string): Promise<this> {\n await expect(this.page.locator('#errorThreshold')).toHaveValue(value);\n return this;\n }\n\n async expectCriticalPhaseThreshold(value: string): Promise<this> {\n await expect(this.page.locator('#criticalPhaseThreshold')).toHaveValue(value);\n return this;\n }\n\n async restoreDefaultReportSettings(): Promise<void> {\n const defaultWarningThreshold = '2';\n const defaultErrorThreshold = '4';\n const defaultCriticalPhaseThreshold = '6';\n\n await this.setWarningThreshold(defaultWarningThreshold);\n await this.setErrorThreshold(defaultErrorThreshold);\n await this.setCriticalPhaseThreshold(defaultCriticalPhaseThreshold);\n\n await this.settings.save();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { SystemSettingsPage } from '../systemSettingsPage';\n\nexport class ReleaseAndTriggersPage extends WithPage {\n settings: SystemSettingsPage;\n constructor(page: Page) {\n super(page);\n this.settings = new SystemSettingsPage(page);\n }\n\n async setArchivingSettingsDeleteIntervalUnit(value: string): Promise<this> {\n const setDeleteInterval = this.page.locator('select#time-selector-releaseAgeToDeleteFromJcr');\n await setDeleteInterval.scrollIntoViewIfNeeded();\n await setDeleteInterval.selectOption(value);\n return this;\n }\n\n async expectArchivePurgeEnableState(value: boolean): Promise<this> {\n if (value) {\n await expect(this.page.locator('#purgingEnabled')).toBeChecked();\n } else {\n await expect(this.page.locator('#purgingEnabled')).not.toBeChecked();\n }\n return this;\n }\n\n async setArchivePurgeEnableState(value: boolean): Promise<this> {\n if (value) {\n await this.page.locator('#purgingEnabled').check({ force: true });\n } else {\n await this.page.locator('#purgingEnabled').uncheck({ force: true });\n }\n return this;\n }\n\n async expectConfirmEnableArchivePurgeModal(): Promise<this> {\n await expect(this.page.getByRole('heading', { name: 'Verify archive purge change' })).toBeVisible();\n await expect(this.page.locator('.dot-dialog')).toBeVisible();\n return this;\n }\n\n async confirmEnableArchivePurgeModal(): Promise<this> {\n await expect(this.page.getByRole('button', { name: 'Confirm' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Confirm' }).click();\n return this;\n }\n\n async cancelEnableArchivePurgeModal(): Promise<this> {\n await expect(this.page.getByRole('button', { name: 'Cancel' })).toBeVisible();\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async setMaxArchiveRetentionPeriodIntervalUnit(value: string): Promise<this> {\n await this.page.locator('#time-selector-maximumArchiveRetentionPeriod').selectOption(value);\n return this;\n }\n\n async setMaxArchiveRetentionPeriodInterval(value: string): Promise<this> {\n await this.page.getByRole('spinbutton', { name: 'Maximum archive retention' }).fill(value);\n return this;\n }\n\n async expectInputFieldToBeDisabled(fieldName: string): Promise<this> {\n await expect(this.page.getByRole('spinbutton', { name: fieldName })).toHaveAttribute('readonly', '');\n return this;\n }\n}\n","import { WithPage } from './WithPage';\nimport { expect, Locator, Page } from '@playwright/test';\n\nexport class NotificationPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async getTasksTableElement(): Promise<Locator> {\n return this.page.locator('.tasks-table table');\n }\n\n async getTasksTableRows(): Promise<Locator> {\n return (await this.getTasksTableElement()).locator('tbody tr');\n }\n\n async getEventElement(eventName: string): Promise<Locator> {\n return this.page.locator(`tbody > tr `).filter({ hasText: eventName });\n }\n\n async getEventRowElement(eventName: string): Promise<Locator> {\n return (await this.getEventElement(eventName)).locator('td');\n }\n\n async findAddTagInputElementOnRow(eventRowElement: Locator): Promise<Locator> {\n return eventRowElement.locator('input[type=text].tag-input');\n }\n\n async getTasksEventIdSearchInput(): Promise<Locator> {\n return (await this.getTasksTableElement()).locator('.with-search > input[type=text]').first();\n }\n\n async getSuggestedRoleElement(roleName: string): Promise<Locator> {\n return this.page.locator(`.xlr-tags-suggestions .tag-label`).filter({ hasText: roleName });\n }\n\n async getRoleElementFromEvent(eventName: string, roleName: string): Promise<Locator> {\n return (await this.getEventRowElement(eventName)).locator(`.role-cell .tag.role`).filter({ hasText: roleName });\n }\n\n async getCloseTagElements(): Promise<Locator> {\n return this.page.locator('.tag.role a.tag-close');\n }\n\n async getEditMessageElements(): Promise<Locator> {\n return this.page.locator('a.action.link').filter({ hasText: 'Edit Message' });\n }\n\n async findEditMessageLinkElementOnRow(eventRowElement: Locator): Promise<Locator> {\n return eventRowElement.locator('a.action.link').filter({ hasText: 'Edit Message' });\n }\n\n async typeRoleTagNameInEventInput(eventName: string, roleName: string): Promise<this> {\n const eventRowElement = await this.getEventRowElement(eventName);\n await (await this.findAddTagInputElementOnRow(eventRowElement)).fill(roleName);\n return this;\n }\n\n async clearRoleTagNameInEventInput(eventName: string): Promise<this> {\n const eventRowElement = await this.getEventRowElement(eventName);\n await (await this.findAddTagInputElementOnRow(eventRowElement)).clear();\n return this;\n }\n\n async filterTaskTableByEventId(filterText: string): Promise<this> {\n await (await this.getTasksEventIdSearchInput()).fill(filterText);\n return this;\n }\n\n async expectSuggestedRoleToBeVisible(roleName: string, shouldBeVisible = true): Promise<this> {\n shouldBeVisible\n ? expect(await this.getSuggestedRoleElement(roleName)).toBeTruthy()\n : expect(await this.getSuggestedRoleElement(roleName)).toBeFalsy();\n return this;\n }\n\n async expectRoleTagToBePresentOnEvent(eventName: string, roleName: string, shouldBePresent = true): Promise<this> {\n shouldBePresent\n ? await expect(await this.getRoleElementFromEvent(eventName, roleName)).toBeVisible()\n : await expect(await this.getRoleElementFromEvent(eventName, roleName)).not.toBeVisible();\n return this;\n }\n\n async expectTaskEventTableToHaveNumberOfRows(numberOfRows: number): Promise<this> {\n await expect(await this.getTasksTableRows()).toHaveCount(numberOfRows);\n return this;\n }\n\n async expectTablesToBeInReadOnlyMode(shouldBeReadOnly = true): Promise<this> {\n if (shouldBeReadOnly) {\n await expect(await this.getEditMessageElements()).toHaveCount(0);\n await expect(await this.getCloseTagElements()).toHaveCount(0);\n } else {\n expect(await (await this.getEditMessageElements()).count()).toBeGreaterThan(0);\n expect(await (await this.getCloseTagElements()).count()).toBeGreaterThan(0);\n }\n return this;\n }\n\n async removeRoleTagFromEvent(eventName: string, roleName: string): Promise<this> {\n await this.page\n .locator(`[data-test=\"${await this.toConstantFormat(eventName)}\"] div .tag.role`)\n .filter({ hasText: roleName })\n .locator('a.tag-close')\n .click();\n return this;\n }\n\n async toConstantFormat(input: string): Promise<string> {\n return input.trim().toUpperCase().replace(/\\s+/g, '_');\n }\n}\n\nexport class NotificationModalPage extends NotificationPage {\n constructor(page: Page) {\n super(page);\n }\n\n async findBodySaveElement(): Promise<Locator> {\n return this.page.locator(`.modal-body .actions-wrapper button[data-testid=\"save-button\"]`);\n }\n\n async findBodyCloseElement(): Promise<Locator> {\n return this.page.locator(`.modal-body .actions-wrapper button[data-testid=\"cancel-button\"]`);\n }\n\n async expectBodyTextareaControlsToExist(shouldExist = true): Promise<this> {\n if (shouldExist) {\n expect(await (await this.findBodySaveElement()).count()).toBeGreaterThan(0);\n expect(await (await this.findBodyCloseElement()).count()).toBeGreaterThan(0);\n } else {\n await expect(await this.findBodySaveElement()).toHaveCount(0);\n await expect(await this.findBodyCloseElement()).toHaveCount(0);\n }\n return this;\n }\n\n async getPriorityDropdownElement(): Promise<Locator> {\n return this.page.locator('.priority-group .xlr-react-select');\n }\n\n async getPriorityDropdownItemElement(priority: string): Promise<Locator> {\n return this.page.locator(`.ant-select-dropdown .ant-select-dropdown-menu-item`).filter({ hasText: priority });\n }\n\n async getModalCancelButtonElement(): Promise<Locator> {\n return this.page.locator('.modal-footer .button.cancel');\n }\n\n async getModalSaveButtonElement(): Promise<Locator> {\n return this.page.locator('.modal-footer .button.primary');\n }\n\n async setPriority(priority: string): Promise<this> {\n await (await this.getPriorityDropdownElement()).click();\n await (await this.getPriorityDropdownItemElement(priority)).click();\n return this;\n }\n\n async expectModalSaveButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n if (shouldBeEnabled) {\n await expect(await this.getModalSaveButtonElement()).toBeEnabled();\n } else {\n await expect(await this.getModalSaveButtonElement()).toBeDisabled();\n }\n return this;\n }\n\n async expectModalCancelButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n if (shouldBeEnabled) {\n await expect(await this.getModalCancelButtonElement()).toBeEnabled();\n } else {\n await expect(await this.getModalCancelButtonElement()).toBeDisabled();\n }\n return this;\n }\n\n async hasPriority(priority: string): Promise<this> {\n await expect(this.page.locator('.ant-select-selection-selected-value')).toHaveText(priority);\n return this;\n }\n\n async setSubject(subject: string): Promise<this> {\n const subjectElem = this.page.getByRole('textbox');\n await subjectElem.click();\n await subjectElem.clear();\n await subjectElem.fill(subject);\n return this;\n }\n\n async hasSubject(subject: string): Promise<this> {\n await expect(this.page.locator(`input[name=\"subject\"]`)).toHaveValue(subject);\n return this;\n }\n\n async writeIntoBodyTextarea(bodyText: string): Promise<this> {\n await this.page.getByLabel('Double-click to edit').waitFor({ timeout: 10000 });\n await this.page.getByLabel('Double-click to edit').hover();\n await this.page.locator('.markdown-viewer-actions').getByTestId('edit-button').click();\n const bodyTextareaElem = this.page.locator(`textarea[id=\"body-input\"]`);\n await bodyTextareaElem.clear();\n await bodyTextareaElem.fill(bodyText);\n return this;\n }\n\n async saveTextInsideOfBodyTextarea(): Promise<this> {\n await expect(this.page.getByTestId('save-button')).toBeVisible();\n await this.page.getByTestId('save-button').click();\n return this;\n }\n\n async setBody(body: string): Promise<this> {\n await this.writeIntoBodyTextarea(body);\n await this.expectBodyTextareaControlsToExist();\n await this.saveTextInsideOfBodyTextarea();\n return this;\n }\n\n async hasBody(body: string): Promise<this> {\n await expect(this.page.locator('.markdown-wrapper')).toContainText(body);\n return this;\n }\n\n async save(): Promise<this> {\n await (await this.getModalSaveButtonElement()).click();\n return this;\n }\n\n async cancel(): Promise<this> {\n await (await this.getModalCancelButtonElement()).click();\n return this;\n }\n\n async confirmLeave(): Promise<this> {\n await this.page.locator('.leave-confirmation-dialog').getByRole('button', { name: 'Leave' }).click();\n return this;\n }\n\n async expectNotificationSettingsModalToBeVisible(shouldBeVisible = true): Promise<this> {\n const modal = this.page.locator(`[role='dialog'] .xl-react-widget-modal-dialog`);\n if (shouldBeVisible) {\n await expect(modal).toBeVisible();\n } else {\n await expect(modal).toHaveCount(0);\n }\n return this;\n }\n\n async expectModalControlButtonsToBeEnabled(shouldBeEnabled = true): Promise<this> {\n await this.expectModalSaveButtonToBeEnabled(shouldBeEnabled);\n await this.expectModalCancelButtonToBeEnabled(shouldBeEnabled);\n return this;\n }\n\n async changeEmailDataWithAssertion(priority: string, subject: string, body: string): Promise<this> {\n await this.expectBodyTextareaControlsToExist(false);\n await this.setPriority(priority);\n await this.expectModalCancelButtonToBeEnabled();\n await this.hasPriority(priority);\n await this.expectModalCancelButtonToBeEnabled();\n await this.setSubject(subject);\n await this.expectModalCancelButtonToBeEnabled();\n await this.hasSubject(subject);\n await this.setBody(body);\n await this.expectModalCancelButtonToBeEnabled();\n await this.hasBody(body);\n await this.expectModalControlButtonsToBeEnabled();\n return this;\n }\n\n async changeEmailDataSaveChangesAndAssert(priority: string, subject: string, body: string): Promise<this> {\n await this.changeEmailDataWithAssertion(priority, subject, body);\n await this.save();\n await this.expectNotificationSettingsModalToBeVisible(false);\n return this;\n }\n\n async changeEmailDataCancelChangesAndAssert(priority: string, subject: string, body: string): Promise<this> {\n await this.changeEmailDataWithAssertion(priority, subject, body);\n await this.cancel();\n await this.expectLeaveConfirmationModalToBeVisible();\n await this.confirmLeave();\n return this;\n }\n\n async expectLeaveConfirmationModalToBeVisible(shouldBeVisible = true): Promise<this> {\n shouldBeVisible\n ? await expect(this.page.locator('.leave-confirmation-dialog')).toBeVisible()\n : await expect(this.page.locator('.leave-confirmation-dialog')).toHaveCount(0);\n return this;\n }\n\n async openModalAndExpectData(priority: string, subject: string, body: string): Promise<this> {\n await this.hasPriority(priority);\n await this.hasSubject(subject);\n await this.hasBody(body);\n return this;\n }\n}\n","import { Locator, Page, expect } from '@playwright/test';\nimport { NotificationModalPage, NotificationPage } from '../notificationPage';\n\nexport class NotificationSettingsPage extends NotificationPage {\n constructor(page: Page) {\n super(page);\n }\n\n async getResetButtonElement(): Promise<Locator> {\n return this.page.getByTestId('reset-btn');\n }\n\n async getSaveButtonElement(): Promise<Locator> {\n return this.page.getByTestId('save-btn');\n }\n\n async getSuggestionTag(): Promise<Locator> {\n return this.page.locator('.xlr-tags-suggestions .tag-label');\n }\n\n async getSuggestedRoleElement(roleName: string): Promise<Locator> {\n return this.page.locator(`.xlr-tags-suggestions .tag-label`).filter({ hasText: roleName });\n }\n\n async selectSuggestedRole(roleName: string): Promise<this> {\n await (await this.getSuggestedRoleElement(roleName)).click();\n return this;\n }\n\n async getEventElement(eventName: string): Promise<Locator> {\n return this.page.locator(`tbody > tr `).filter({ hasText: eventName });\n }\n\n async getEventRowElement(eventName: string): Promise<Locator> {\n return (await this.getEventElement(eventName)).locator('td');\n }\n\n async getRoleElementFromEvent(eventName: string, roleName: string): Promise<Locator> {\n return (await this.getEventRowElement(eventName))\n .locator(`.role-cell .tag.role span`)\n .filter({ hasText: roleName });\n }\n\n async expectResetButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n shouldBeEnabled\n ? await expect(await this.getResetButtonElement()).toBeEnabled()\n : await expect(await this.getResetButtonElement()).toBeDisabled();\n return this;\n }\n\n async expectSaveButtonToBeEnabled(shouldBeEnabled = true): Promise<this> {\n shouldBeEnabled\n ? await expect(await this.getSaveButtonElement()).toBeEnabled()\n : await expect(await this.getSaveButtonElement()).toBeDisabled();\n return this;\n }\n\n async expectTableWithRecipients(tableTitle: string, recipientEnabled: boolean): Promise<this> {\n const countElement = this.page\n .locator(`.collapsible-component`)\n .filter({ hasText: tableTitle })\n .locator(`.tags.react-tags-wrapper`);\n recipientEnabled\n ? expect(await countElement.count()).toBeGreaterThan(0)\n : expect(await countElement.count()).toBe(0);\n return this;\n }\n\n async typeRoleText(eventId: string, roleText: string): Promise<this> {\n await this.page.locator(`.events-permissions-table input#${eventId}`).fill(roleText);\n return this;\n }\n\n async addRoleToEvent(eventId: string, roleName: string): Promise<this> {\n await this.typeRoleText(eventId, roleName);\n await this.selectSuggestedRole(roleName);\n return this;\n }\n\n async removeRoleFromEvent(eventId: string, roleName: string): Promise<this> {\n const roleElem = await this.getRoleElementFromEvent(roleName, eventId);\n await roleElem.locator('.role .tag-close').click();\n return this;\n }\n\n async expectSuggestionTagToHaveText(expectedText: string): Promise<this> {\n await expect(await this.getSuggestionTag()).toHaveText(expectedText);\n return this;\n }\n\n async expectCancelAndSaveButtonsToBeEnabled(shouldBeEnabled = true): Promise<this> {\n shouldBeEnabled\n ? await expect(await this.getResetButtonElement()).toBeEnabled()\n : await expect(await this.getSaveButtonElement()).toBeDisabled();\n return this;\n }\n\n async addRoleToEventWithAssertions(eventName: string, roleName: string): Promise<this> {\n await this.typeRoleTagNameInEventInput(eventName, roleName);\n await this.expectSuggestedRoleToBeVisible(roleName);\n await this.selectSuggestedRole(roleName);\n await this.expectRoleTagToBePresentOnEvent(eventName, roleName);\n await this.expectCancelAndSaveButtonsToBeEnabled();\n return this;\n }\n\n async removeRoleAndAssert(eventName: string, roleName: string): Promise<this> {\n await this.expectTablesToBeInReadOnlyMode(false);\n await this.removeRoleTagFromEvent(eventName, roleName);\n await this.expectRoleTagToBePresentOnEvent(eventName, roleName, false);\n await this.expectCancelAndSaveButtonsToBeEnabled();\n return this;\n }\n\n async openEditMessageFromEvent(eventName: string): Promise<NotificationModalPage> {\n await this.page\n .locator(`[data-test=\"${await this.toConstantFormat(eventName)}\"]`)\n .getByText('Edit Message')\n .click();\n return new NotificationModalPage(this.page);\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { RisksPage } from './systemSettings/risksProfilePage';\nimport { WithPage } from './WithPage';\nimport { Util } from './common/util';\nimport { advancedSettingsPage } from './systemSettings/advancedSettingsPage';\nimport { experimentalSettingsPage } from './systemSettings/experimentalSettingsPage';\nimport { TaskSettingsPage } from './systemSettings/taskSettingsPage';\nimport { ReportsSettingsPage } from './systemSettings/reportsSettingsPage';\nimport { ReleaseAndTriggersPage } from './systemSettings/releaseAndTriggersPage';\nimport { NotificationSettingsPage } from './systemSettings/notificationSettingsPage';\n\nexport class SystemSettingsPage extends WithPage {\n util: Util;\n risksPage: RisksPage;\n constructor(page: Page) {\n super(page);\n this.risksPage = new RisksPage(page);\n this.util = new Util(page);\n }\n\n async openGeneralSettings(): Promise<GeneralSettings> {\n await this.util.openSideNavMenu('General');\n await expect(this.page.getByLabel('breadcrumb').getByText('General')).toBeVisible();\n return new GeneralSettings(this.page);\n }\n\n async openReleasesAndTriggers(): Promise<ReleaseAndTriggersPage> {\n await this.util.openSideNavMenu('Releases and Triggers');\n await expect(this.page.getByLabel('breadcrumb').getByText('Releases and Triggers')).toBeVisible();\n return new ReleaseAndTriggersPage(this.page);\n }\n\n async openTasks(): Promise<TaskSettingsPage> {\n await this.util.openSideNavMenu('Tasks');\n await expect(this.page.getByLabel('breadcrumb').getByText('Tasks')).toBeVisible();\n return new TaskSettingsPage(this.page);\n }\n\n async openReports(): Promise<ReportsSettingsPage> {\n await this.util.openSideNavMenu('Reports');\n await expect(this.page.getByLabel('breadcrumb').getByText('Reports')).toBeVisible();\n return new ReportsSettingsPage(this.page);\n }\n\n async openAdvanced(): Promise<advancedSettingsPage> {\n await this.util.openSideNavMenu('Advanced');\n await expect(this.page.getByLabel('breadcrumb').getByText('Advanced')).toBeVisible();\n return new advancedSettingsPage(this.page);\n }\n\n async openExperimental(): Promise<experimentalSettingsPage> {\n await this.util.openSideNavMenu('Experimental');\n await expect(this.page.getByLabel('breadcrumb').getByText('Experimental')).toBeVisible();\n return new experimentalSettingsPage(this.page);\n }\n\n async openNotifications(): Promise<NotificationSettingsPage> {\n await this.util.openSideNavMenu('Notifications');\n await expect(this.page.getByLabel('breadcrumb').getByText('Notifications')).toBeVisible();\n return new NotificationSettingsPage(this.page);\n }\n\n async openRiskProfiles(): Promise<RisksPage> {\n await this.util.openSideNavMenu('Risk profiles');\n await expect(this.page.getByLabel('breadcrumb').getByText('Risk profiles')).toBeVisible();\n return new RisksPage(this.page);\n }\n\n async openWorkflowCategories(): Promise<void> {\n await this.util.openSideNavMenu('Workflow categories');\n await expect(this.page.getByLabel('breadcrumb').getByText('Workflow categories')).toBeVisible();\n }\n\n async openSMTPServer(): Promise<void> {\n await this.util.openSideNavMenu('SMTP server');\n await expect(this.page.getByLabel('breadcrumb').getByText('SMTP server')).toBeVisible();\n }\n\n async _saveDoNotAssert(): Promise<void> {\n // Check if the \"Save\" button is enabled and save if needed\n const saveButton = await this.page.getByTestId('save-button').isDisabled();\n if (!saveButton) {\n await this.page.getByTestId('save-button').click();\n }\n }\n\n async expectCards(cardTitles: string[] | string): Promise<this> {\n await expect(this.page.locator(`.settings-card .dot-card-header-title`)).toHaveCount(cardTitles.length);\n for (let i = 0; i < cardTitles.length; i++) {\n const cardTitle = cardTitles[i];\n await expect(\n this.page.locator(`.settings-card .dot-card-header-title`).filter({ hasText: cardTitle }),\n ).toBeVisible();\n }\n return this;\n }\n\n async save(): Promise<this> {\n await expect(this.page.getByTestId('save-button')).toBeVisible();\n await this.page.getByTestId('save-button').click();\n await expect(this.page.locator('.success').filter({ hasText: 'Changes saved successfully' })).toBeVisible();\n await this.page.locator('.success').getByRole('button').click();\n await expect(this.page.locator('.success').filter({ hasText: 'Changes saved successfully' })).not.toBeVisible();\n return this;\n }\n\n async reset(): Promise<this> {\n await this.page.getByTestId(`reset-button`).click();\n await expect(this.page.getByTestId('reset-button')).toBeDisabled();\n return this;\n }\n}\n\nexport class GeneralSettings extends SystemSettingsPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setInstanceName(value: string): Promise<this> {\n await this.page.locator('input#headerName').click({ force: true });\n await this.page.getByRole('textbox', { name: 'Instance name' }).fill(value);\n return this;\n }\n\n async setLoginMessage(message: string): Promise<this> {\n await this.page.locator('div#loginMessage').click({ force: true });\n const input = this.page.locator('input#loginMessage');\n\n const currentValue = await input.inputValue();\n if (currentValue.trim() !== '') {\n await input.fill('');\n }\n\n await input.fill(message);\n await input.press('Tab');\n return this;\n }\n\n async clearLoginMessage(): Promise<this> {\n await this.page.locator('div#loginMessage').click({ force: true });\n const input = this.page.locator('input#loginMessage');\n await input.fill('');\n await input.press('Tab');\n return this;\n }\n\n async setHeaderColor(colorName: string): Promise<this> {\n await this.page.locator('.color-picker button').click({ force: true });\n await this.page.locator(`.color-picker-list-item`).getByText(colorName).click({ force: true });\n return this;\n }\n\n async clickNotificationsMenu(): Promise<void> {\n await this.util.openSideNavMenu('Notifications');\n }\n\n async expectInstanceName(value: string): Promise<this> {\n await expect(this.page.locator('top-toolbar .dot-pill')).toHaveText(value);\n return this;\n }\n\n async restoreDefaultThemeSettings(): Promise<void> {\n await this._clearHeaderInstanceName();\n await this.setHeaderColor('Green');\n await this._saveDoNotAssert();\n }\n\n async _clearHeaderInstanceName(): Promise<void> {\n await this.page.locator('input#headerName').click({ force: true });\n await this.page.locator('input#headerName').clear();\n }\n\n async expectHeaderColor(value: string): Promise<this> {\n await expect(this.page.locator('top-toolbar .dot-app-toolbar')).toHaveAttribute(\n 'style',\n `border-bottom-color: ${value};`,\n );\n return this;\n }\n\n async expectConfirmationPopUp(): Promise<this> {\n await expect(this.page.getByRole('heading', { name: 'Confirm leave' })).toBeVisible();\n await expect(this.page.getByRole('paragraph')).toContainText('You have unsaved changes that will be lost.');\n await this.page.getByRole('button', { name: 'Leave without saving' }).click();\n return this;\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ConnectionsPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async addNewInstance(typeName: string): Promise<ConfigurationInstancePage> {\n await this.page\n .locator(`.configuration-type`)\n .filter({ hasText: typeName })\n .locator(`.new-instance .button`)\n .first()\n .click({ force: true });\n return new ConfigurationInstancePage(this.page);\n }\n\n async expectInstanceDisplayed(instanceName: string): Promise<this> {\n await this.page.locator('#configuration').waitFor({ state: 'visible', timeout: 200000 });\n await expect(this.page.locator(`.configuration-instance`).filter({ hasText: instanceName })).toBeVisible();\n return this;\n }\n\n async expectInstanceNotDisplayed(instanceName: string): Promise<this> {\n await this.page.locator('#configuration').waitFor({ state: 'visible' });\n await expect(this.page.locator(`.configuration-instance`).filter({ hasText: instanceName })).not.toBeVisible();\n return this;\n }\n\n async openInstance(instanceName: string): Promise<ConfigurationInstancePage> {\n await this.page\n .locator(`.configuration-instance`)\n .filter({ hasText: instanceName })\n .locator(`.edit-instance`)\n .click({ force: true });\n return new ConfigurationInstancePage(this.page);\n }\n\n async deleteInstance(instanceName: string): Promise<this> {\n await this.page\n .locator(`.configuration-instance`)\n .filter({ hasText: instanceName })\n .locator(`.delete-instance`)\n .click({ force: true });\n return this;\n }\n\n async expectSuccessMsgToBeDisplayed(text: string): Promise<this> {\n await expect(this.page.locator('.success')).toContainText(text);\n await this.page.locator('.success').getByRole('button').click();\n return this;\n }\n\n async clearFilter(): Promise<this> {\n await this.page.locator('.search-input-filter input').clear({ force: true });\n return this;\n }\n\n async searchInstances(instanceName: string): Promise<this> {\n await this.page.getByPlaceholder('Search...').click();\n await this.page.getByPlaceholder('Search...').fill(instanceName);\n return this;\n }\n\n async expectErrorDisplayed(): Promise<void> {\n await expect(this.page.locator('.modal-header h4')).toContainText('Error');\n await this.page.locator('.modal-header .xl-icon.close-icon').click();\n }\n}\n\nclass ConfigurationInstancePage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setTextField(fieldName: string, fieldValue: string): Promise<this> {\n await this.page.locator(`input[name=${fieldName}]`).clear({ force: true });\n await this.page.locator(`input[name=${fieldName}]`).fill(fieldValue, { force: true });\n return this;\n }\n\n async setNumberField(fieldName: string, fieldValue: number): Promise<this> {\n await this.page.locator(`#${fieldName}`).clear({ force: true });\n await this.page.locator(`#${fieldName}`).fill(fieldValue.toString(), { force: true });\n return this;\n }\n\n async selectFromDropdown(fieldName: string, element: string): Promise<this> {\n await this.page.getByLabel(fieldName).click();\n await this.page.getByRole('option', { name: element }).click();\n return this;\n }\n\n async save(): Promise<this> {\n await this.page.getByRole('button', { name: 'Save' }).click();\n await expect(this.page.getByLabel('success')).toBeVisible();\n return this;\n }\n\n async test(): Promise<this> {\n await this.page.getByRole('button', { name: 'Test' }).click();\n return this;\n }\n\n async cancel(): Promise<this> {\n await this.page.getByRole('button', { name: 'Cancel' }).click();\n return this;\n }\n\n async expectResultBanner(message: string): Promise<this> {\n await expect(this.page.locator('.configuration-result-banner')).toBeVisible();\n await expect(this.page.locator('.configuration-result-banner')).toContainText(message);\n return this;\n }\n\n async expectDropdownToBe(fieldName: string, fieldValue: string): Promise<this> {\n const value = await this.page.locator(`#${fieldName}`).getAttribute('value');\n expect(value).toBe(fieldValue);\n return this;\n }\n\n async clearDropdown(fieldName: string): Promise<this> {\n await this.page.locator(`input[id=${fieldName}]`).click({ force: true });\n await this.page.getByRole(`button`, { name: 'Clear' }).click();\n return this;\n }\n\n async clickField(fieldName: string): Promise<this> {\n await this.page.getByLabel(fieldName).click();\n return this;\n }\n\n async expectTextFieldNotToExist(fieldName: string): Promise<this> {\n const locator = this.page.locator(`.input-scalar[data-test-id=\"${fieldName}\"]`);\n await expect(locator).toHaveCount(0);\n return this;\n }\n\n // To avoid flakiness and clicking around the page, we can directly click on the header\n async clickHeader(): Promise<void> {\n await this.page.locator('.configuration-instance-page h2').click();\n }\n\n async expectTextFieldToBe(fieldName: string, fieldValue: string): Promise<this> {\n expect(await this.page.locator(`input[name=${fieldName}]`).getAttribute('value')).toContain(fieldValue);\n return this;\n }\n\n async setStringList(value: Array<string> | string): Promise<this> {\n await this.page.locator('.input-list input#stringList').click();\n if (value instanceof Array) {\n for (const val of value) {\n await this.page.locator('.input-list input#stringList').fill(val);\n await this.page.locator('[data-test-id=\"stringList\"]').getByLabel('add icon button').click();\n }\n } else {\n await this.page.locator('.input-list input#stringList').fill(value);\n }\n return this;\n }\n\n async expectStringListCountToBe(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"stringList\"] .list`).count()).toBe(count);\n return this;\n }\n\n async removeString(value: string): Promise<this> {\n await this.page.locator('li').filter({ hasText: value }).getByLabel('close icon button').click();\n return this;\n }\n\n async setStringSet(value: Array<string> | string): Promise<this> {\n await this.page.locator('.input-list input#stringSet').click();\n if (value instanceof Array) {\n for (const val of value) {\n await this.page.locator('.input-list input#stringSet').fill(val);\n await this.page.locator('[data-test-id=\"stringSet\"]').getByLabel('add icon button').click();\n }\n } else {\n await this.page.locator('.input-list input#stringSet').fill(value);\n }\n return this;\n }\n\n async expectStringSetCountToBe(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"stringSet\"] .list`).count()).toBe(count);\n return this;\n }\n\n async setStringMap(pairs: { key: string; value: string }): Promise<void> {\n await this.page\n .locator('[data-test-id=\"stringMap\"]')\n .getByTestId('icon-button-tooltip')\n .getByLabel('Add key-value pair')\n .click();\n await this.page.locator('#new-row-key-input').fill(pairs.key);\n await this.page.locator('#new-row-value-input').fill(pairs.value);\n await this.page.getByRole('button', { name: 'check-line icon' }).click();\n }\n\n async expectStringMapCountToBe(count: number): Promise<this> {\n expect(await this.page.locator(`[data-test-id=\"stringMap\"] .map-data-row`).count()).toBe(count);\n return this;\n }\n\n async expectTestButtonToBeDisabled(): Promise<this> {\n await expect(this.page.locator('action-toolbar button').filter({ hasText: 'Test' })).toBeDisabled();\n return this;\n }\n\n async togglePasswordFieldVariable(fieldName: string): Promise<this> {\n await this.page.locator(`.input-with-variables[data-test-id=\"${fieldName}\"] button`).click({ force: true });\n return this;\n }\n\n async setPasswordFieldVariable(fieldName: string, fieldValue: string): Promise<this> {\n await this.page.locator(`.input-with-variables[data-test-id=\"${fieldName}\"] input`).click({ force: true });\n await this.page\n .locator(`.input-with-variables[data-test-id=\"${fieldName}\"] li`)\n .filter({ hasText: fieldValue })\n .click();\n return this;\n }\n\n async expectFieldsToNotBeVisible(fieldNames: Array<string> | string): Promise<this> {\n if (typeof fieldNames !== 'string') {\n for (const fName of fieldNames) {\n await expect(this.page.locator(`#${fName}`)).not.toBeVisible();\n }\n } else {\n await expect(this.page.locator(`#${fieldNames}`)).not.toBeVisible();\n }\n return this;\n }\n\n async expectFieldsToBeVisible(fieldNames: Array<string> | string): Promise<this> {\n if (typeof fieldNames !== 'string') {\n for (const fName of fieldNames) {\n await expect(this.page.locator(`input[name=${fName}]`)).toBeVisible();\n }\n } else {\n await expect(this.page.locator(`input[name=${fieldNames}]`)).toBeVisible();\n }\n return this;\n }\n}\n","import { Page } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class TaskAccessPage extends WithPage {\n constructor(page: Page) {\n super(page);\n }\n\n async setTaskAvailableToAllUsers(taskName: string, enable?: boolean): Promise<void> {\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .scrollIntoViewIfNeeded();\n const checkboxElement = this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox');\n const isChecked = await checkboxElement.isChecked();\n if (isChecked && !enable) {\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .scrollIntoViewIfNeeded();\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .click();\n await this.page.getByTestId('save-btn').click();\n await this.page.locator('.saved-text').waitFor();\n } else if (!isChecked && enable) {\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .scrollIntoViewIfNeeded();\n await this.page\n .locator('tr.ng-scope')\n .filter({ has: this.page.getByText(taskName, { exact: true }) })\n .getByRole('checkbox')\n .click();\n await this.page.getByTestId('save-btn').click();\n await this.page.locator('.saved-text').waitFor();\n }\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { ReleasePage } from './releases/ReleasePage';\nimport { ApplicationsPage } from './ApplicationsPage';\nimport { DataRandomGenerator } from './common/dataRandomGenerator';\nimport { DateUtil } from './common/dateUtil';\nimport { FolderPage } from './FolderPage';\nimport { GlobalVariable } from './globalVariablePage';\nimport { HomePage } from './homePage';\nimport { HeaderPage } from './headerPage';\nimport { ManagePluginsPage } from './managePluginsPage';\nimport { PersonalAccessTokenPage } from './PersonalAccessTokenPage';\nimport { PersonalSettingsPage } from './personalSettingsPage';\nimport { UsersPage } from './users/usersPage';\nimport { SettingsMenu } from './settingsMenu';\nimport { TaskDetails } from './taskDetails';\nimport { ReleaseCalendarPage } from './ReleaseCalendarPage';\nimport { ReleaseGroupPage } from './ReleaseGroupPage';\nimport { ReleaseGroupTimelinePage } from './ReleaseGroupTimelinePage';\nimport { ReleasesListPage } from './ReleasesListPage';\nimport { ReleaseVariablesPage } from './releases/ReleaseVariablesPage';\nimport { TaskListPage } from './tasks/taskListPage';\nimport { TemplatePage } from './templates/templatePage';\nimport { TemplateListPage } from './templateListPage';\nimport { Util } from './common/util';\nimport { RolesPage } from './users/rolesPage';\nimport { WorkflowCatalogPage } from './workflowCatalogPage';\nimport { SystemSettingsPage } from './systemSettingsPage';\nimport { ReleaseGanttPage } from './releases/releaseGanttPage';\nimport { ConnectionsPage } from './connectionsPage';\nimport { TaskAccessPage } from './tasks/taskAccessPage';\nimport { FolderDeliveryPage } from './folder/folderDeliveryPage';\n\nexport class Navigation {\n private readonly page: Page;\n connections: ConnectionsPage;\n dataRandomGenerator: DataRandomGenerator;\n dateUtil: DateUtil;\n folderPage: FolderPage;\n globalvariable: GlobalVariable;\n homePage: HomePage;\n header: HeaderPage;\n managePluginsPage: ManagePluginsPage;\n releasePage: ReleasePage;\n settingsMenu: SettingsMenu;\n systemSettingsPage: SystemSettingsPage;\n usersPage: UsersPage;\n applicationPage: ApplicationsPage;\n taskDetailsPage: TaskDetails;\n taskListPage: TaskListPage;\n templatePage: TemplatePage;\n templateListPage: TemplateListPage;\n personalSettingsPage: PersonalSettingsPage;\n releaseCalendarPage: ReleaseCalendarPage;\n releaseGroupPage: ReleaseGroupPage;\n releaseGroupTimelinePage: ReleaseGroupTimelinePage;\n releaseGanttPage: ReleaseGanttPage;\n releaseListPage: ReleasesListPage;\n rolesPage: RolesPage;\n util: Util;\n workflowCatalogPage: WorkflowCatalogPage;\n taskAccessPage: TaskAccessPage;\n\n constructor(page: Page) {\n this.page = page;\n this.connections = new ConnectionsPage(page);\n this.dataRandomGenerator = new DataRandomGenerator();\n this.dateUtil = new DateUtil(page);\n this.folderPage = new FolderPage(page);\n this.globalvariable = new GlobalVariable(page);\n this.homePage = new HomePage(page);\n this.header = new HeaderPage(page);\n this.managePluginsPage = new ManagePluginsPage(page);\n this.releasePage = new ReleasePage(page);\n this.settingsMenu = new SettingsMenu(page);\n this.systemSettingsPage = new SystemSettingsPage(page);\n this.usersPage = new UsersPage(page);\n this.applicationPage = new ApplicationsPage(page);\n this.taskDetailsPage = new TaskDetails(page);\n this.taskListPage = new TaskListPage(page);\n this.templatePage = new TemplatePage(page);\n this.templateListPage = new TemplateListPage(page);\n this.personalSettingsPage = new PersonalSettingsPage(page);\n this.releaseCalendarPage = new ReleaseCalendarPage(page);\n this.releaseGroupPage = new ReleaseGroupPage(page);\n this.releaseGroupTimelinePage = new ReleaseGroupTimelinePage(page);\n this.releaseListPage = new ReleasesListPage(page);\n this.releaseGanttPage = new ReleaseGanttPage(page);\n this.rolesPage = new RolesPage(page);\n this.util = new Util(page);\n this.workflowCatalogPage = new WorkflowCatalogPage(page);\n this.taskAccessPage = new TaskAccessPage(page);\n }\n\n async openTemplate(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, false);\n }\n\n async openFolder(id: string): Promise<FolderPage> {\n await this.page.goto(`./#/folders/${id}/releases`);\n await this.page.waitForSelector('#releases-content');\n return new FolderPage(this.page);\n }\n\n async openProfilePage(): Promise<PersonalSettingsPage> {\n await this.page.goto(`./#/profile`);\n return new PersonalSettingsPage(this.page);\n }\n\n async openVariablesOnReleasePage(releaseId: string): Promise<ReleaseVariablesPage> {\n await this.page.goto(`./#/releases/${releaseId}/variables`);\n await this.page.waitForSelector('#release-variables');\n return new ReleaseVariablesPage(this.page);\n }\n\n async openRelease(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, true);\n }\n\n async openPlannerView(releaseId: string): Promise<ReleaseGanttPage> {\n await this.page.goto(`#/releases/${releaseId}/planner`);\n return new ReleaseGanttPage(this.page);\n }\n\n async openApplicationsPage(): Promise<ApplicationsPage> {\n return new ApplicationsPage(this.page).goToApplicationsPage();\n }\n\n async openPersonalAccessTokenPage(): Promise<PersonalAccessTokenPage> {\n return new PersonalAccessTokenPage(this.page).openPersonalAccessTokenPage();\n }\n\n async gotoHomePage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Home', { exact: true }).click();\n }\n\n async gotoFolderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Folders', { exact: true }).click();\n }\n\n async gotoTaskPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Tasks', { exact: true }).click();\n }\n\n async gotoReleasePage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Releases', { exact: true }).click();\n }\n\n async gotoWorkflowCatalogPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Workflow catalog', { exact: true }).click();\n }\n\n async gotoWorkflowsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Workflows', { exact: true }).click();\n }\n\n async gotoGroupsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Groups', { exact: true }).click();\n }\n\n async gotoReleaseCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Release calendar', { exact: true }).click();\n }\n\n async gotoDeliveriesPage(): Promise<FolderDeliveryPage> {\n await this.page.locator('ul.side-nav li').getByLabel('Deliveries', { exact: true }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Deliveries')).toBeVisible();\n return new FolderDeliveryPage(this.page);\n }\n\n async gotoTriggersPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Triggers', { exact: true }).click();\n }\n\n async gotoDigitalAnalyticsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Digital.ai Analytics', { exact: true }).click();\n }\n\n async gotoReportsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Reports', { exact: true }).click();\n }\n\n async gotoTemplatesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Templates', { exact: true }).click();\n }\n\n async gotoEnvironmentsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Environments', { exact: true }).click();\n }\n\n async gotoEnvironmentsCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Environments calendar', { exact: true }).click();\n }\n\n async gotoGobalVariablesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Global variables', { exact: true }).click();\n }\n\n async gotoConnectionsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByLabel('Connections', { exact: true }).click();\n await expect(this.page.getByLabel('breadcrumb').getByText('Connections')).toBeVisible();\n }\n\n private async openReleaseOrTemplate(id: string, release: boolean): Promise<ReleasePage> {\n const url = release ? 'releases' : 'templates';\n await this.page.goto(`./#/${url}/${id}`);\n await this.page.waitForSelector('#release');\n return new ReleasePage(this.page);\n }\n\n async collapseSideView(): Promise<void> {\n await this.page.getByLabel('Collapse Q').click();\n await expect(this.page.getByLabel('Collapse Q')).not.toBeVisible();\n }\n\n async expandSideView(): Promise<void> {\n await this.page.getByLabel('Expand Q').click();\n await expect(this.page.getByLabel('Expand Q')).not.toBeVisible();\n }\n\n async openRisksProfile(): Promise<void> {\n await this.page.goto('./#/risks');\n }\n\n async openConnection(): Promise<void> {\n await this.page.goto('./#/configuration');\n await expect(this.page.getByLabel('breadcrumb').getByText('Connections')).toBeVisible();\n }\n\n async clickOnPrimaryLogo(): Promise<void> {\n await this.page.getByTestId('primary-logo').click();\n }\n async gotoTaskAccessPage(): Promise<TaskAccessPage> {\n await this.page.goto('#/task-access');\n return new TaskAccessPage(this.page);\n }\n}\n","import { expect, Locator } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class LoginPage extends WithPage {\n /**\n * Login with username and password\n * @param userName\n * @param password\n */\n async login(userName: string, password: string): Promise<void> {\n await this.page.goto('./#/login');\n await expect(this.page).toHaveTitle('Digital.ai Release');\n await this.page.getByPlaceholder('User').fill(userName, { timeout: 1000 });\n await this.page.getByPlaceholder('Password').fill(password, { timeout: 10000 });\n await this.page.getByRole('button', { name: 'Log in' }).click({ timeout: 10000 });\n await this.page.waitForTimeout(1000);\n await this.closePendoModalWindow();\n }\n\n async loginWithoutReload(userName: string, password: string): Promise<void> {\n let loadTriggered = false;\n this.page.on('load', () => {\n loadTriggered = true;\n });\n await this.page.evaluate(() => {\n window.location.hash = '#tasks';\n });\n expect(loadTriggered).toBe(false);\n await this.login(userName, password);\n }\n\n /**\n * Logout as authenticated user\n */\n async logout(): Promise<void> {\n await this.page.locator('button.dot-avatar').click();\n await this.page.getByText('Log out', { exact: true }).click();\n }\n\n /**\n * Expect login to be restricted for a user\n */\n async expectLoginDisallowed(): Promise<void> {\n const val = await this.page.textContent('.error-content span[ng-show=\"loginInfo.failedStatus == 403\"]');\n expect(val).toContain(\"You do not have 'login' permission.\");\n }\n\n /**\n * Expect the respective user is logged In\n * @param username\n */\n async expectToBeLogged(username: string): Promise<void> {\n const val = await this.page.locator('top-toolbar .avatar-wrapper span.dot-tooltip').getAttribute('aria-label');\n expect(val).toContain(username);\n }\n\n async closePendoModalWindow(): Promise<void> {\n await this.page.waitForTimeout(1000);\n if ((await this.page.locator('._pendo-close-guide').count()) > 0) {\n await this.page.locator('._pendo-close-guide').click();\n }\n }\n\n async expectUserNotVisible(): Promise<void> {\n const tooltip: Locator = this.page.locator('top-toolbar .avatar-wrapper .dot-tooltip');\n await tooltip.waitFor({ state: 'hidden' });\n }\n\n async expectUserVisible(): Promise<void> {\n const tooltip: Locator = this.page.locator('top-toolbar .avatar-wrapper .dot-tooltip');\n await tooltip.waitFor({ state: 'visible' });\n }\n\n async expectLoginPage(): Promise<void> {\n await expect(this.page).toHaveURL('./#/login');\n await expect(this.page.getByPlaceholder('User')).toBeVisible();\n await expect(this.page.getByPlaceholder('Password')).toBeVisible();\n await expect(this.page.getByRole('button', { name: 'Log in' })).toBeVisible();\n }\n}\n","import isUndefined from 'lodash/isUndefined';\nimport each from 'lodash/each';\nimport forEach from 'lodash/forEach';\nimport defaults from 'lodash/defaults';\nimport toPairs from 'lodash/toPairs';\n\nimport { Container, Dashboard, Phase, Release, Task, Tile, Variable, VariableValueProvider } from '../types';\n\nexport const initReleaseDefaults = (function () {\n const RELEASE_TYPE = 'xlrelease.Release';\n const PHASE_TYPE = 'xlrelease.Phase';\n const TEAM_TYPE = 'xlrelease.Team';\n const TASK_TYPE = 'xlrelease.Task';\n const COMMENT_TYPE = 'xlrelease.Comment';\n const CONDITION_TYPE = 'xlrelease.GateCondition';\n const DEPENDENCY_TYPE = 'xlrelease.Dependency';\n const LINK_TYPE = 'xlrelease.Link';\n const ATTACHMENT_TYPE = 'xlrelease.Attachment';\n const DASHBOARD_TYPE = 'xlrelease.Dashboard';\n const _TRIGGER_TYPE = 'xlrelease.ReleaseTrigger';\n const JIRA_TYPE = 'jira.CreateIssue';\n const DEFAULT_TASK_OWNER = 'Itchy';\n\n const processTasks = (task: Task, container: Container, index: number): void => {\n if (isUndefined(task.type)) task.type = TASK_TYPE;\n task.id = task.id || `${container.id}/Task${index}`;\n if (isUndefined(task.owner) && task.type !== JIRA_TYPE) task.owner = DEFAULT_TASK_OWNER;\n if (task.owner === null) delete task.owner;\n\n each(task.conditions, function (condition, idx) {\n condition.type = CONDITION_TYPE;\n condition.id = `${task.id}/GateCondition${idx}`;\n });\n each(task.dependencies, function (dependency, idx) {\n dependency.type = DEPENDENCY_TYPE;\n dependency.id = `${task.id}/Dependency${idx}`;\n });\n each(task.links, function (link, idx) {\n link.type = LINK_TYPE;\n link.id = `${task.id}/Link${idx}`;\n });\n each(task.comments, function (comment, idx) {\n comment.type = COMMENT_TYPE;\n comment.id = `${task.id}/Comment${idx}`;\n });\n each(task.tasks, function (subTask, idx) {\n processTasks(subTask, task, idx);\n });\n each(task.templateVariables, function (variable, idx) {\n if (variable.value !== undefined) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n defaults(variable, getVariableEntity(variable.value, variable.key, task.id, idx));\n }\n });\n each(task.attachments, function (attachment, idx) {\n attachment.type = ATTACHMENT_TYPE;\n attachment.id = `${task.id}/Attachment${idx}`;\n });\n if (task.pythonScript) {\n const pythonScript = task.pythonScript;\n pythonScript.id = `${task.id}/PythonScript`;\n pythonScript.customScriptTask = task.id;\n }\n };\n\n const processPhases = (phase: Phase, release: Release, index: number): void => {\n phase.type = PHASE_TYPE;\n phase.id = `${release.id}/Phase${index}`;\n\n forEach(phase.tasks, (task, idx): void => {\n processTasks(task, phase, idx);\n });\n };\n\n const getVariableEntity = (\n value: string | Array<string> | boolean,\n key: string,\n containerId: string,\n index: number,\n password?: boolean,\n // eslint-disable-next-line max-params\n ): Variable => {\n const keyNoSyntax = key.replace('${', '').replace('}', '');\n return {\n id: `${containerId}/Variable${index}`,\n key: keyNoSyntax,\n requiresValue: true,\n showOnReleaseStart: true,\n type: password ? 'xlrelease.PasswordStringVariable' : 'xlrelease.StringVariable',\n value: value,\n };\n };\n\n const getValueProviderConfigurationEntity = function (containerId: string): VariableValueProvider {\n return {\n id: `${containerId}/valueProvider`,\n variable: containerId,\n };\n };\n\n const getDashboardExtension = (dashboard: Dashboard, releaseId: string): Dashboard => {\n const dashboardExtension: Dashboard = {\n id: `${releaseId}/summary`,\n type: DASHBOARD_TYPE,\n tiles: [],\n };\n if (dashboard.tiles) {\n forEach(dashboard.tiles, function (tile, index) {\n dashboardExtension.tiles.push(getTileEntity(tile, `${releaseId}/summary`, index));\n });\n }\n return dashboardExtension;\n };\n\n function getTileEntity(tile: Tile, containerId: string, index: number): Tile {\n tile.id = tile.id || `${containerId}/Tile${index}`;\n return tile;\n }\n\n return function (release: Release) {\n release.type = RELEASE_TYPE;\n if (release.id.indexOf('Applications/') === -1) {\n release.id = `Applications/${release.id}`;\n }\n if (release.startDate) {\n release.queryableStartDate = release.startDate;\n } else if (release.scheduledStartDate) {\n release.queryableStartDate = release.scheduledStartDate;\n }\n if (release.endDate) {\n release.queryableEndDate = release.endDate;\n } else if (release.dueDate) {\n release.queryableEndDate = release.dueDate;\n }\n if (isUndefined(release.owner)) release.owner = 'Itchy'; // default release manager\n\n forEach(release.phases, function (phase, index) {\n processPhases(phase, release, index);\n });\n forEach(release.teams, function (team, index) {\n team.type = TEAM_TYPE;\n team.id = `${release.id}/Team${index}`;\n });\n forEach(release.attachments, function (attachment, index) {\n attachment.type = ATTACHMENT_TYPE;\n attachment.id = `${release.id}/Attachment${index}`;\n });\n forEach(release.variables, function (variable: Variable, index) {\n if (variable.value !== undefined) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n defaults(variable, getVariableEntity(variable.value, variable.key, release.id, index));\n }\n if (variable.valueProvider) {\n defaults(variable.valueProvider, getValueProviderConfigurationEntity(variable.id));\n }\n });\n forEach(toPairs(release.variableValues), function (keyValue, index) {\n if (!release.variables) release.variables = [];\n release.variables.push(getVariableEntity(keyValue[1], keyValue[0], release.id, 1000 + index));\n release.variableValues = undefined;\n });\n forEach(toPairs(release.passwordVariableValues), function (keyValue, index) {\n if (!release.variables) release.variables = [];\n release.variables.push(getVariableEntity(keyValue[1], keyValue[0], release.id, 1500 + index, true));\n release.passwordVariableValues = undefined;\n });\n\n if (release.summary) {\n release.extensions = [getDashboardExtension(release.summary, release.id)];\n release.summary = undefined;\n }\n };\n})();\n","import { test as base, expect, Page, APIResponse } from '@playwright/test';\nimport { execFile } from 'child_process';\nimport { APIRequestContext } from 'playwright-core';\nimport isNil from 'lodash/isNil';\nimport { Navigation } from '../pages';\nimport { LoginPage } from '../pages/login-page';\nimport { initReleaseDefaults } from './helper';\nimport * as process from 'process';\nimport {\n Delivery,\n Dashboard,\n Facet,\n FixtureActivityLog,\n FixtureCi,\n FixtureConfiguration,\n FixtureFeature,\n FixtureGlobalRole,\n FixturePermissions,\n FixtureRelease,\n FixtureRoles,\n FixtureTrigger,\n Folder,\n Release,\n RiskProfile,\n Variable,\n ReleaseGroup,\n FixtureTeam,\n EnvironmentFixture,\n Reservation,\n ApplicationFixture,\n} from '../types';\n\nconst JIRA_ISSUE_API_URL = 'https://digitalai.atlassian.net/rest/api/2/issue';\n\nconst adminHeaders = {\n Authorization: 'Basic YWRtaW46YWRtaW4=',\n Cookie: 'XSRF-TOKEN=1;',\n 'X-XSRF-TOKEN': '1',\n};\n\ntype ReleaseFixtures = {\n fixtures: Fixtures;\n loginPage: LoginPage;\n navigation: Navigation;\n};\n\nexport const test = base.extend<ReleaseFixtures>({\n fixtures: async ({ request, page }, use) => {\n const fixtures = new Fixtures(request, page);\n await use(fixtures);\n return fixtures;\n },\n loginPage: async ({ page }, use) => {\n const loginPage = new LoginPage(page);\n await use(loginPage);\n return loginPage;\n },\n navigation: async ({ page }, use) => {\n const navigationPage = new Navigation(page);\n await use(navigationPage);\n return navigationPage;\n },\n});\n\nclass Fixtures {\n private readonly request: APIRequestContext;\n private readonly page: Page;\n\n private applicationIds: Array<string> = [];\n private archivedReleaseIds: Array<string> = [];\n private ciIds: Array<string> = [];\n private environmentIds: Array<string> = [];\n private environmentStageIds: Array<string> = [];\n private releaseIds: Array<string> = [];\n private riskProfiles: Array<string> = [];\n private reservationIds: Array<string> = [];\n private triggerIds: Array<string> = [];\n private configurationIds: Array<string> = [];\n private globalVariableIds: Array<string> = [];\n private folderIds: Array<string> = [];\n private usernames: Array<string> = [];\n private userProfiles: Array<string> = [];\n private folderVariableIds: Array<string> = [];\n\n constructor(request: APIRequestContext, page: Page) {\n this.request = request;\n this.page = page;\n }\n\n release(release: FixtureRelease): Promise<APIResponse> {\n this.initDefaults(release);\n this.releaseIds.push(release.id);\n return this.deleteRelease(release.id)\n .then(() => this.deleteArchivedRelease(release.id))\n .then(() => this.doPost('fixtures/release', release));\n }\n\n archivedRelease(release: FixtureRelease): Promise<APIResponse> {\n this.initDefaults(release);\n this.archivedReleaseIds.push(release.id);\n return this.doPost('fixtures/archived', release);\n }\n\n configuration(ci: FixtureConfiguration): Promise<APIResponse> {\n this.configurationIds.push(ci.id);\n return this.doPost('fixtures/shared', [ci]);\n }\n\n ci(ci: FixtureCi): Promise<APIResponse> {\n this.configurationIds.push(ci.id);\n return this.doPost('fixtures', [ci]);\n }\n\n async deleteCI(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/configuration/${id}`);\n }\n\n getParentId(id: string): string {\n return id.substring(0, id.lastIndexOf('/'));\n }\n\n addSystemTeams(teams: Array<FixtureTeam>): Array<FixtureTeam> {\n const systemTeams = ['Folder Owner', 'Release Admin', 'Template Owner'];\n const teamsToUpdate = teams.map((team) => team.teamName);\n systemTeams.forEach((teamName) => {\n if (teamsToUpdate.indexOf(teamName) === -1) {\n teams.push({\n type: 'xlrelease.Team',\n teamName,\n members: [],\n permissions: [],\n });\n }\n });\n return teams;\n }\n\n async folder(folder: Folder): Promise<APIResponse> {\n const parentId = this.getParentId(folder.id);\n folder.type = 'xlrelease.Folder';\n\n let teams = folder.teams;\n delete folder.teams;\n\n const children = folder.children || [];\n delete folder.children;\n\n const folderVariables = (folder.variables || []).map((variable) => {\n variable.folderId = folder.id;\n return variable;\n });\n delete folder.variables;\n\n const response = await this.doPost(`api/v1/folders/${parentId}`, folder);\n\n // Add the folder ID to the list\n this.folderIds.push(folder.id);\n\n // If teams are provided, send a request to add teams to the folder\n if (teams) {\n teams = this.addSystemTeams(teams);\n return await this.doPost(`api/v1/folders/${folder.id}/teams`, teams);\n }\n\n if (children && children.length > 0) {\n await this.folderVariable(folderVariables);\n return await this.folder(children[0]);\n }\n\n if (folderVariables && folderVariables.length > 0) {\n return await this.folderVariable(folderVariables);\n }\n\n return response;\n }\n\n createFolder(folderJson: Folder): Promise<APIResponse> {\n folderJson.type = 'xlrelease.Folder';\n if (folderJson.id) {\n this.folderIds.push(folderJson.id);\n }\n return this.doPost(`fixtures/folders`, [folderJson]);\n }\n\n async folderVariable(variable: any[]): Promise<APIResponse> {\n // Flatten and process the variables\n const variables = ([] as any[])\n .concat(variable)\n .flat()\n // eslint-disable-next-line @typescript-eslint/no-shadow\n .map((variable: any) => {\n variable.id = null;\n variable.type = variable.type || 'xlrelease.StringVariable';\n variable.requiresValue = false;\n variable.showOnReleaseStart = false;\n return variable;\n });\n return await this.doPost('fixtures/folders/variables', variables);\n }\n\n trigger(trigger: FixtureTrigger): Promise<APIResponse> {\n this.triggerIds.push(trigger.id);\n return this.doPost('fixtures/trigger', trigger);\n }\n\n roles(rolePrincipals: FixtureRoles): Promise<APIResponse> {\n return this.doPost('fixtures/roles/principals', rolePrincipals);\n }\n\n permissions(rolePermissions: FixturePermissions): Promise<APIResponse> {\n return this.doPost('fixtures/roles/permissions/global', rolePermissions);\n }\n\n globalRoles(rolePrincipals: FixtureGlobalRole): Promise<APIResponse> {\n return this.doPost(`api/v1/roles/${rolePrincipals.name}`, rolePrincipals);\n }\n\n dashboard(dashboard: Dashboard): Promise<APIResponse> {\n return this.doPost('fixtures/dashboard', dashboard);\n }\n\n deleteGlobalRole(roleName: string): Promise<APIResponse> {\n return this.doDelete(`api/v1/roles/${roleName}`);\n }\n\n updateUserProfile(username: string, profile: any): Promise<APIResponse> {\n profile.id = username;\n profile.type = 'xlrelease.UserProfile';\n profile.canonicalId = username.toLowerCase();\n if (this.userProfiles.indexOf(profile.canonicalId) === -1) {\n this.userProfiles.push(profile.canonicalId);\n }\n return this.doPut('fixtures/userProfile', profile);\n }\n\n deleteRole(roleName: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/role/${roleName}`);\n }\n\n deleteArchivedRelease(id: string): Promise<APIResponse> {\n const releaseId = id.includes('Applications/') ? id : `Applications/${id}`;\n return this.doDelete('fixtures/cis', [\n {\n id: releaseId,\n type: 'xlrelease.Release',\n },\n ]);\n }\n\n deleteRelease(id: string): Promise<APIResponse> {\n const releaseId = id.includes('Applications/') ? id : `Applications/${id}`;\n return this.doDelete(`fixtures/${releaseId}`);\n }\n\n async deleteWelcomeRelease(username: string): Promise<void> {\n await this.deleteReleaseWithTitle(`Welcome ${username}`);\n }\n\n async deleteReleaseWithTitle(title: string): Promise<void> {\n const response = await this.doPost(`api/v1/releases/search`, { title });\n const releasesFromUser: Release[] = await response.json();\n for (const releasesFromUserElement of releasesFromUser) {\n await this.deleteRelease(releasesFromUserElement.id);\n }\n }\n\n deleteUser(username: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/user/${username}`);\n }\n\n deleteUserProfile(userProfile: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/userProfile/${userProfile}`);\n }\n\n deleteReleaseGroup(releaseGroup: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/release-groups/${releaseGroup}`);\n }\n\n deleteTrigger(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/trigger/${id}`);\n }\n\n deleteConfiguration(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/shared`, [id]);\n }\n\n deleteFolder(folderId: string): Promise<APIResponse> {\n return this.doDelete(`api/v1/folders/${folderId}`);\n }\n\n deleteGlobalVariables(): Promise<APIResponse> {\n return this.doDelete('fixtures/globalVariables');\n }\n\n deleteGlobalVariable(id: string): Promise<APIResponse> {\n return this.doDelete(`api/v1/config/${id}`);\n }\n\n activityLogs(id: string, logs: Array<FixtureActivityLog>): Promise<APIResponse> {\n return this.doPost(`fixtures/activityLogs/${id}`, logs);\n }\n\n globalVariable(variable: Variable): Promise<APIResponse> {\n variable.id = variable.id || `Configuration/variables/global/Variable_${variable.key}`;\n this.globalVariableIds.push(variable.id);\n variable.requiresValue = false;\n variable.showOnReleaseStart = false;\n return this.doPost('api/v1/config/Configuration/variables/global', variable);\n }\n\n addDefaultSmtpServer(): Promise<APIResponse> {\n const defaultSmtpServer = [\n {\n type: 'xlrelease.SmtpServer',\n id: 'Configuration/mail/SmtpServer',\n host: 'localhost',\n port: '25',\n fromAddress: 'foo@bar.com',\n authentication: {\n id: 'Configuration/mail/SmtpServer/authentication',\n type: 'xlrelease.NoSmtpAuthentication',\n },\n },\n ];\n return this.doPost('fixtures/', defaultSmtpServer);\n }\n\n riskProfile(riskProfile: RiskProfile): Promise<APIResponse> {\n this.riskProfiles.push(riskProfile.id);\n return this.doPost('fixtures/riskProfiles', riskProfile);\n }\n\n deleteRiskProfile(riskProfileId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/riskProfiles/${riskProfileId}`);\n }\n\n // Release delivery pattern\n createDeliveryPattern(delivery: Delivery, shouldResetPattern = true): Promise<APIResponse> {\n return this.doPost(`fixtures/deliveries/patterns/${shouldResetPattern}`, delivery);\n }\n\n // Release deliveries\n createDelivery(delivery: Delivery): Promise<APIResponse> {\n return this.doPost('fixtures/deliveries', delivery);\n }\n\n async facet(facet: Facet): Promise<APIResponse> {\n return this.doPost('fixtures/facets', facet);\n }\n\n async application(application: ApplicationFixture): Promise<APIResponse> {\n const response = await this.doPost('fixtures/application', application);\n const json = await response.json();\n this.applicationIds.push(json.id);\n return json;\n }\n\n async environment(environment: EnvironmentFixture): Promise<APIResponse> {\n const response = await this.doPost('fixtures/environment', environment);\n const json = await response.json();\n this.environmentIds.push(json.id);\n this.environmentStageIds.push(json.stage);\n return json;\n }\n\n async reservation(reservation: Reservation): Promise<APIResponse> {\n const response = await this.doPost('fixtures/reservation', reservation);\n const json = await response.json();\n this.reservationIds.push(json.id);\n return json;\n }\n\n deleteDelivery(delivery: Delivery): Promise<APIResponse> {\n return this.doDelete(`fixtures/deliveries/${delivery}`);\n }\n\n async deleteApplication(applicationId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/application/${applicationId}`);\n }\n\n async deleteEnvironment(environmentId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/environment/${environmentId}`);\n }\n\n async deleteEnvironmentStage(environmentStageId: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/environment/${environmentStageId}`);\n }\n\n async clearCalendar(): Promise<APIResponse> {\n return this.doDelete('fixtures/calendar');\n }\n\n async deleteReservation(id: string): Promise<APIResponse> {\n return this.doDelete(`fixtures/reservation/${id}`);\n }\n\n async cleanAll(): Promise<void> {\n for (const username of this.usernames) {\n await this.deleteUser(username);\n await this.deleteWelcomeRelease(username);\n }\n for (const userProfile of this.userProfiles) {\n await this.deleteUserProfile(userProfile);\n }\n for (const triggerId of this.triggerIds) {\n await this.deleteTrigger(triggerId);\n }\n for (const releaseId of this.releaseIds.reverse()) {\n await this.deleteRelease(releaseId);\n }\n for (const confId of this.configurationIds) {\n await this.deleteConfiguration(confId);\n }\n for (const folderId of this.folderIds.reverse()) {\n await this.deleteFolder(folderId);\n }\n for (const globalVariableId of this.globalVariableIds) {\n await this.deleteGlobalVariable(globalVariableId);\n }\n for (const reservationId of this.reservationIds) {\n await this.deleteReservation(reservationId);\n }\n for (const applicationId of this.applicationIds) {\n await this.deleteApplication(applicationId);\n }\n for (const environmentId of this.environmentIds) {\n await this.deleteEnvironment(environmentId);\n }\n for (const environmentStageId of this.environmentStageIds) {\n await this.deleteEnvironmentStage(environmentStageId);\n }\n for (const ci of this.ciIds) {\n await this.deleteCI(ci);\n }\n\n this.applicationIds = [];\n this.configurationIds = [];\n this.environmentIds = [];\n this.environmentStageIds = [];\n this.globalVariableIds = [];\n this.folderIds = [];\n this.releaseIds = [];\n this.reservationIds = [];\n this.triggerIds = [];\n this.usernames = [];\n this.userProfiles = [];\n this.ciIds = [];\n }\n\n async addJiraTask(): Promise<string> {\n const data = {\n fields: {\n project: { key: 'RIT' },\n summary: 'Test Task',\n description: 'Test task description',\n issuetype: { name: 'Task' },\n },\n };\n const headers = {\n Authorization: `Basic ${btoa('xlr-jira-testuser@xebialabs.com:zgsXK6c3oLVkJxrWVJQy9DB7')}`,\n Origin: 'https://digitalai.atlassian.net/',\n };\n const response = await this.request.post(JIRA_ISSUE_API_URL, { data, headers });\n const json = await response.json();\n return json.key;\n }\n\n async addBlackout(name: string, from: Date, to: Date): Promise<APIResponse> {\n return this.doPost('calendar/blackouts', {\n label: name,\n startDate: from,\n endDate: to,\n type: 'xlrelease.Blackout',\n id: null,\n });\n }\n\n async addUser(username: string, password: string): Promise<void> {\n this.usernames.push(username);\n await this.doPost('fixtures/user', { username, password });\n }\n\n async addUserProfile(username: string, profile?: any): Promise<void> {\n if (!profile) {\n profile = {};\n }\n profile.id = username;\n profile.type = 'xlrelease.UserProfile';\n profile.canonicalId = username.toLowerCase();\n this.userProfiles.push(profile.canonicalId);\n await this.doPost('fixtures/userProfile', profile);\n }\n\n async resetAdminProfile(): Promise<APIResponse> {\n return this.resetUserProfile('admin', 'Release Administrator');\n }\n\n async resetUserProfile(username: string, fullName?: string): Promise<APIResponse> {\n this.usernames.push(username);\n return this.updateProfile({\n username,\n external: false,\n profileId: username,\n email: '',\n fullName: fullName ? fullName : username,\n loginAllowed: true,\n // dateFormat: \"dd/MM/yy\",\n dateFormat: 'M/d/yy',\n // timeFormat: \"HH:mm\",\n timeFormat: 'h:mm a',\n firstDayOfWeek: 0,\n });\n }\n\n async updateProfile(profile: {\n dateFormat: string;\n email: string;\n external: boolean;\n firstDayOfWeek: number;\n fullName: string;\n loginAllowed: boolean;\n profileId: string;\n timeFormat: string;\n username: string;\n }): Promise<APIResponse> {\n return this.doPut('profile', profile);\n }\n\n async expectJiraTaskStatus(taskId: string, expectedStatus: string): Promise<void> {\n const headers = {\n Authorization: `Basic ${btoa('xlr-jira-testuser@xebialabs.com:zgsXK6c3oLVkJxrWVJQy9DB7')}`,\n Origin: 'https://digitalai.atlassian.net/',\n };\n const response = await this.request.get(`${JIRA_ISSUE_API_URL}/${taskId}`, { headers });\n const json = await response.json();\n const status = json.fields.status.name;\n expect(status).toBe(expectedStatus);\n }\n\n async expectJiraTaskSummary(taskId: string, expectedSummary: string): Promise<void> {\n const headers = {\n Authorization: `Basic ${btoa('xlr-jira-testuser@xebialabs.com:zgsXK6c3oLVkJxrWVJQy9DB7')}`,\n Origin: 'https://digitalai.atlassian.net/',\n };\n const response = await this.request.get(`${JIRA_ISSUE_API_URL}/${taskId}`, { headers });\n const json = await response.json();\n const summary = json.fields.summary;\n expect(summary).toBe(expectedSummary);\n }\n\n async expectContainingAttachments(releaseId: string, tempFile: string): Promise<void> {\n if (releaseId.indexOf('Applications/') === -1) {\n releaseId = 'Applications/' + releaseId;\n }\n await expect(async () => {\n const resp = await this.doPost(`fixtures/expectContainingAttachments/${releaseId}`, {\n name: tempFile,\n expectedContent: tempFile,\n });\n expect(resp).toBe(true);\n }).toPass();\n }\n\n async waitForReleaseStarted(releaseTitle: string): Promise<void> {\n await expect(async () => {\n const resp = await this.doPost('releases/search', {\n inProgress: true,\n paused: true,\n failing: true,\n failed: true,\n title: releaseTitle,\n });\n const page = await resp.json();\n await expect(page.cis.length).toBeGreaterThan(0);\n }).toPass();\n }\n\n async waitForFirstPoll(triggerId: string): Promise<void> {\n await expect(async () => {\n const resp = await this.doGet(`api/v1/triggers/${triggerId}`);\n const trigger = await resp.json();\n await expect(isNil(trigger.triggerState)).toBe(false);\n }).toPass();\n }\n\n exec(path: string): Promise<void> {\n return new Promise<void>((resolve, reject) => {\n execFile(path, (error) => {\n if (error === null) {\n return resolve();\n } else {\n return reject();\n }\n });\n });\n }\n\n getFakeApiUrl(): string {\n return this.getEnvVariable('ENV_FAKE_API') || 'http://localhost:5517';\n }\n\n getEnvVariable(name: string): string | undefined {\n return process.env[name];\n }\n\n async archiveRelease(releaseId: string): Promise<APIResponse> {\n return this.doGet(`fixtures/archive/${releaseId}`);\n }\n\n async preArchiveRelease(releaseId: string): Promise<APIResponse> {\n return this.doGet(`fixtures/preArchive/${releaseId}`);\n }\n\n async setFeatures(features: Array<FixtureFeature>): Promise<APIResponse> {\n return this.doPut('settings/features', features);\n }\n\n async enableTaskDrawer(enabled: boolean): Promise<APIResponse> {\n return this.setFeatures([\n { id: 'Configuration/features/xlrelease.TaskDrawer', type: 'xlrelease.TaskDrawer', enabled: enabled },\n ]);\n }\n\n async createReleaseGroup(releaseGroup: ReleaseGroup): Promise<APIResponse> {\n return this.doPost('fixtures/release-groups', releaseGroup);\n }\n\n private doPost(url: string, body: unknown): Promise<APIResponse> {\n return this.request.post(url, { data: body, headers: adminHeaders });\n }\n\n private doPut(url: string, body: unknown): Promise<APIResponse> {\n return this.request.put(url, { data: body, headers: adminHeaders });\n }\n\n private doGet(url: string): Promise<APIResponse> {\n return this.request.get(url, { headers: adminHeaders });\n }\n\n private doDelete(url: string, body?: unknown): Promise<APIResponse> {\n return this.request.delete(url, { data: body, headers: adminHeaders });\n }\n\n private initDefaults(ci: FixtureRelease): void {\n initReleaseDefaults(ci as Release);\n }\n}\n","export { test } from './fixtures';\n"],"names":[],"version":3,"file":"types.d.ts.map"}
|