@digital-ai/devops-page-object-release 0.0.6 → 0.0.8
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 +16 -0
- package/dist/main.js +1308 -1035
- package/dist/main.js.map +1 -1
- package/dist/module.js +537 -264
- package/dist/module.js.map +1 -1
- package/dist/types.d.ts +199 -104
- package/dist/types.d.ts.map +1 -1
- package/package.json +2 -2
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"mappings":";;AAEA;IACE,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC;gBAElB,IAAI,EAAE,IAAI;CAGvB;ACJD,8BAA8B,SAAQ,QAAQ;IACtC,sBAAsB,CAAC,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ3E,iBAAiB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;CAIpE;ACbD,0BAA0B,SAAQ,QAAQ;IAClC,qBAAqB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAYtE;ACbD;;GAEG;AACH,uBAAuB,SAAQ,QAAQ;IACrC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,EAAE,OAAO,CAAC;gBAEjC,IAAI,EAAE,IAAI;IAKhB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG7B;ACfD;;GAEG;AACH,mCAAmC,SAAQ,SAAS;IAC5C,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIjD,cAAc,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKlE,YAAY,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKhE,oBAAoB,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKxE,qBAAqB,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAkBhF;AEtCD,kCAAkC,SAAQ,QAAQ;IAC1C,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;CAIvE;AAED,kCAA2B,SAAQ,QAAQ;IAMnC,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAW7C,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAelD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG7B;AC7CD,YAAY,UAAU,GAAG,UAAU,GAAG,QAAQ,GAAG,YAAY,GAAG,YAAY,GAAG,YAAY,GAAG,QAAQ,CAAA;AAEtG,wBAAwB,SAAQ,QAAQ;IAEtC,SAAS,CAAC,QAAQ,CAAC,iBAAiB,EAAE,OAAO,CAAC;gBAElC,IAAI,EAAE,IAAI;IAKhB,cAAc,IAAI,OAAO,CAAC,UAAU,CAAC;IAKrC,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAInC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAI7B;AAED,wBAAiB,SAAQ,UAAU;IAEjC,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC;gBAG5B,IAAI,EAAE,IAAI;IAKhB,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIpC,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIrC,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAIrD,mBAAmB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAK5D,cAAc,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMlE,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAKhE,kBAAkB,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKtE,uBAAuB,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK3E,oBAAoB,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIxE,oBAAoB,CAAC,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAO/E,WAAW,CAAC,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAItE,qBAAqB,CAAC,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGxF;ACxFD,yBAAyB,SAAQ,QAAQ;IACjC,YAAY,IAAI,OAAO,CAAC,YAAY,CAAC;IAKrC,KAAK,CAAC,OAAO,SAAsB,GAAG,OAAO,CAAC,IAAI,CAAC;IAMzD,QAAQ,CAAC,SAAS,EAAE,MAAM,GAAG,KAAK;IAI5B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAKtB,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAGtD,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAGnD,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1D;;OAEG;IACG,yBAAyB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAK3E,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAKrD,aAAa,IAAI,OAAO,CAAC,oBAAoB,CAAC;IAK9C,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAOvD;AAED,mBAAY,SAAQ,QAAQ;gBAGd,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM;IAKnC,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CASpF;AC/ED;gBAGc,IAAI,EAAE,IAAI;IAIhB,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI9C,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;CAUpD;ACrBD,uBAAuB,SAAQ,QAAQ;IAC/B,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IASxD,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;CAI9B;ACdD,8BAA8B,SAAQ,QAAQ;IACtC,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC;IAMrC,iBAAiB,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOzD,0BAA0B,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKlE,mCAAmC,CAAC,eAAe,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAS3G;AC5BD,qCAAqC,SAAQ,QAAQ;IAC7C,2BAA2B,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ5C,WAAW,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAOpD;ACnBD;IACE,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd;AAED,kBAAmB,SAAQ,qBAAqB;IAC9C,KAAK,EAAE,MAAM,CAAC;CACf;AAED,iBAAyB,SAAQ,QAAQ;IACvC,kCAAkC,EAAE,OAAO,CAAC;IAC5C,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,UAAU,EAAE,KAAK,CAAC,gBAAgB,CAAC,CAAC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,sBAAsB,CAAC,EAAE,cAAc,CAAC;IACxC,MAAM,EAAE,KAAK,CAAC,OAAK,CAAC,CAAC;IACrB,gBAAgB,CAAC,EAAE,IAAI,CAAC;IACxB,kBAAkB,CAAC,EAAE,IAAI,CAAC;IAC1B,kBAAkB,CAAC,EAAE,IAAI,CAAC;IAC1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,MAAM,EAAE,aAAa,CAAC;IACtB,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;CAC5B;AAED;IACE,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACpB;AAED,kBAA0B,SAAQ,qBAAqB;IACrD,GAAG,EAAE,MAAM,CAAC;IACZ,aAAa,EAAE,OAAO,CAAC;IACvB,kBAAkB,EAAE,OAAO,CAAC;IAC5B,KAAK,EAAE,GAAG,CAAC;IACX,aAAa,CAAC,EAAE,qBAAqB,CAAC;CACvC;AAED;IACE,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,mBAA2B,SAAQ,QAAQ;IACzC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;CACpB;AAED,iBAAuB,SAAQ,SAAS;IACtC,MAAM,EAAE,WAAW,CAAC;CACrB;AAED,cAAsB,SAAQ,QAAQ;IACpC,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAC/B,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;IACzB,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IAC7B,YAAY,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAChC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,MAAM,EAAE,UAAU,CAAC;IACnB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;CACpC;AAED,iBAAiB,QAAQ,CAAC;AAC1B,kBAAkB,QAAQ,CAAC;AAC3B,YAAY,QAAQ,CAAC;AACrB,eAAe,QAAQ,CAAC;AACxB,kBAAkB,QAAQ,CAAC;AAE3B,mBAA2B,SAAQ,gBAAgB;IACjD,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;CACpB;AAED,wBAAwB,qBAAqB,CAAC;AAC9C,YAAmB,qBAAqB,CAAC;AAEzC,sBAAuB,SAAQ,qBAAqB;IAClD,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,qBAAqB,UAAU,GAAG,SAAS,GAAG,aAAa,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,GAAG,WAAW,GAAG,SAAS,CAAC;AACxH,mBAAmB,SAAS,GAAG,aAAa,GAAG,WAAW,GAAG,SAAS,GAAG,QAAQ,GAAG,SAAS,GAAG,SAAS,CAAC;AAC1G,kBACI,aAAa,GACb,SAAS,GACT,oBAAoB,GACpB,sBAAsB,GACtB,WAAW,GACX,SAAS,GACT,SAAS,GACT,SAAS,GACT,yBAAyB,GACzB,QAAQ,GACR,SAAS,GACT,6BAA6B,GAC7B,0BAA0B,GAC1B,0BAA0B,GAC1B,QAAQ,GACR,qBAAqB,GACrB,mBAAmB,GACnB,wBAAwB,CAAC;AAE7B,YAAY,qBAAqB,CAAC;AAElC,uBAAuB,QAAQ,GAAG,YAAY,CAAC;AAC/C,mBAAmB,sBAAsB,CAAC;AAC1C;IACE,QAAQ,EAAE,eAAe,CAAC;IAC1B,OAAO,EAAE,OAAO,CAAC;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;CACnB;AAED,iBAAiB,CAAC,IAAI;KACnB,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,CAAC;AAGF,sBAA6B,YAAY,OAAO,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAExE,8BAAsC,SAAQ,QAAQ;IACpD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAgC,SAAQ,QAAQ;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;CAClB;AE3HD,uBAAuB;IACrB,eAAe,EAAE,gBAAgB,CAAC;IAClC,QAAQ,EAAE,QAAQ,CAAC;IACnB,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,EAAE,UAAU,CAAC;IACvB,uBAAuB,EAAE,uBAAuB,CAAC;CAClD,CAAC;AAEF,OAAO,MAAM,mQA0BX,CAAC;AAEH;gBAQc,OAAO,EAAE,iBAAiB,EAAE,IAAI,EAAE,IAAI;IAKlD,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,WAAW,CAAC;IAQtD,aAAa,CAAC,EAAE,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IAK7D,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,WAAW,CAAC;IAKtD,qBAAqB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAUvD,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAK/C,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI/C,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAIrD,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;IAiBrC,qBAAqB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAc1D,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQxD,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYjC,aAAa,IAAI,MAAM;IAIvB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAI1C,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC,WAAW,CAAC;IAIlE,gBAAgB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CAuB/D","sources":["apps/release/pages/WithPage.ts","apps/release/pages/ReleasesListPage.ts","apps/release/pages/TriggersPage.ts","apps/release/pages/task-modal/TaskModal.ts","apps/release/pages/task-modal/CustomScriptTaskModal.ts","apps/release/pages/helper/index.ts","apps/release/pages/ReleaseVariablesPage.ts","apps/release/pages/task-drawer/TaskDrawer.ts","apps/release/pages/ReleasePage.ts","apps/release/pages/index.ts","apps/release/pages/LoginPage.ts","apps/release/pages/ApplicationsPage.ts","apps/release/pages/PersonalAccessTokenPage.ts","apps/release/types/index.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 { expect } from '@playwright/test';\nimport { ReleasePage } from './ReleasePage';\nimport { WithPage } from './WithPage';\n\nexport class ReleasesListPage extends WithPage {\n async expectNumberOfReleases(releaseTitle: string, amount: number): Promise<void> {\n if (amount === 1) {\n await expect(this.page.locator('.release').getByText(releaseTitle)).toBeVisible();\n } else {\n await expect(this.page.locator('.release').getByText(releaseTitle).count()).toBe(amount);\n }\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","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 { Page, Locator } from '@playwright/test';\n\nimport { WithPage } from '../WithPage';\n\n/**\n * @deprecated Don't use this, use new TaskDrawer\n */\nexport class TaskModal extends WithPage {\n protected readonly taskModalLocator: Locator;\n\n constructor(page: Page) {\n super(page);\n this.taskModalLocator = this.page.locator('.modal-content.task-details');\n }\n\n async close(): Promise<void> {\n await this.taskModalLocator.locator('.modal-header button.close').click();\n }\n}\n","import { expect } from '@playwright/test';\nimport { TaskModal } from './TaskModal';\n\n/**\n * @deprecated Don't use this, use new TaskDrawer\n */\nexport class CustomScriptTaskModal extends TaskModal {\n async expectFieldNotEmpty(field: string): Promise<void> {\n await expect(this.taskModalLocator.locator(`#${field} .display`).textContent).toBeDefined();\n }\n\n async setSelectField(propertyName: string, value: string): Promise<void> {\n await this.focusOnField(propertyName);\n await this.taskModalLocator.locator(`select[name=\"${propertyName}\"]`).selectOption(value);\n }\n\n async setTextField(propertyName: string, value: string): Promise<void> {\n await this.focusOnField(propertyName);\n await this.taskModalLocator.locator(`input[name=\"${propertyName}\"]`).fill(value);\n }\n\n async setAutocompleteField(propertyName: string, value: string): Promise<void> {\n await this.focusOnAutocompleteField(propertyName);\n await this.taskModalLocator.locator(`#${propertyName} ul li`).getByText(value).click();\n }\n\n async expectOutputValueToBe(propertyName: string, value: string): Promise<void> {\n await expect(this.taskModalLocator.locator(`#${propertyName} .field-readonly span`)).toContainText(value);\n }\n\n // TODO move this to a new inline-editor\n private async focusOnField(propertyName: string): Promise<void> {\n await expect(async () => {\n await this.taskModalLocator.locator(`#${propertyName} .display`).click({ force: true });\n await expect(this.taskModalLocator.locator(`#${propertyName} label.edit`)).toBeVisible();\n }).toPass();\n }\n\n private async focusOnAutocompleteField(propertyName: string): Promise<void> {\n await expect(async () => {\n await this.taskModalLocator.locator(`#${propertyName} input`).click({ force: true });\n await expect(this.taskModalLocator.locator(`#${propertyName} ul`)).toBeVisible();\n }).toPass();\n }\n}\n","import { Locator } from '@playwright/test';\n\ntype WaitForRes = [ locatorIndex: number, locator: Locator ];\nexport async function waitForOneOf(\n locators: Locator[],\n): 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 { expect, Locator } from '@playwright/test';\nimport { WithPage } from './WithPage';\nimport { waitForOneOf } from './helper';\n\ntype ExpectWithLocator = (l: Locator) => void;\n\nexport class ReleaseVariablesPage extends WithPage {\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\nclass ReleaseVariableModal extends WithPage {\n private async expectValue(locators: Locator[], expectFn: ExpectWithLocator[]): Promise<void> {\n const [index, locator] = await waitForOneOf(locators);\n await 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 ],\n [(l) => expect(l).toHaveValue(value), (l) => expect(l).toHaveText(value), (l) => expect(l).toHaveText(value)],\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 ],\n [\n (l) => expect(l.inputValue()).toContain(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","import { WithPage } from \"../WithPage\";\nimport { Locator, Page, expect } from \"@playwright/test\";\n\ntype Rail = 'Overview' | 'Activity' | 'Config' | 'Scheduling' | 'Conditions' | 'Attributes' | 'Attach'\n\nexport class TaskDrawer extends WithPage {\n\n protected readonly taskDrawerLocator: Locator;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawerLocator = this.page.locator('task-drawer .dot-drawer');\n }\n\n async openConfigRail(): Promise<ConfigRail> {\n await this.openRail('Config')\n return new ConfigRail(this.page)\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}\n\nclass ConfigRail extends TaskDrawer {\n\n protected readonly railLocator: Locator;\n\n\n constructor(page: Page) {\n super(page);\n this.railLocator = this.taskDrawerLocator.locator('.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(propertyValue);\n }\n}\n","import { Page, Locator, expect } from '@playwright/test';\nimport { TriggersPage } from './TriggersPage';\nimport { WithPage } from './WithPage';\nimport { CustomScriptTaskModal } from './task-modal/CustomScriptTaskModal';\nimport { ReleaseVariablesPage } from './ReleaseVariablesPage';\nimport { TaskDrawer } from \"./task-drawer/TaskDrawer\";\n\nexport class ReleasePage extends WithPage {\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.locator('action-toolbar button', { hasText: 'Abort' }).click();\n await this.page.locator('.modal textarea').fill(comment);\n await this.page.locator('.modal .continue').click();\n }\n\n getPhase(phaseName: string): Phase {\n return new Phase(this.page, phaseName);\n }\n\n async start(): Promise<void> {\n await this.page.locator('action-toolbar button', { hasText: 'Start' }).click();\n await this.page.locator('.modal button.primary').click();\n }\n\n async waitForTaskCompleted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.completed').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n async waitForTaskFailed(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.failed').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n async waitForStatusLine(statusLine: string): Promise<void> {\n await expect(this.page.locator('.task .status-line').getByText(statusLine, { exact: true })).toBeVisible();\n }\n\n /**\n * @deprecated Don't use this, use new TaskDrawer\n */\n async openCustomScriptTaskModal(taskName: string): Promise<CustomScriptTaskModal> {\n await this.page.locator('.task-header').getByText(taskName).click();\n return new CustomScriptTaskModal(this.page);\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.task-header').getByText(taskName).click();\n return new TaskDrawer(this.page);\n }\n\n async openVariables(): Promise<ReleaseVariablesPage> {\n await this.openReleaseMenu('Variables');\n return new ReleaseVariablesPage(this.page);\n }\n\n 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\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 addTask(taskName: string, taskGroup: string, taskType: string): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.phaseLocator.locator('.quick-title').fill(taskName);\n await this.phaseLocator.locator('.xlr-ctx-menu-toggle').click();\n await this.page.locator(`.xlr-ctx-menu-item`).getByTitle(taskGroup, { exact: true }).scrollIntoViewIfNeeded();\n await this.page.locator(`.xlr-ctx-menu-item`).getByTitle(taskGroup, { exact: true }).hover();\n await this.page.locator(`.xlr-ctx-menu.active`).getByTitle(taskType, { exact: true }).click();\n await this.phaseLocator.locator('.quick-controls-container a').getByText('Add', { exact: true }).click();\n }\n}\n","import { Page } from '@playwright/test';\nimport { ReleasePage } from './ReleasePage';\n\nexport class Navigation {\n private readonly page: Page;\n\n constructor(page: Page) {\n this.page = page;\n }\n\n async openTemplate(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, false);\n }\n\n async openRelease(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, true);\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","import { expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class LoginPage extends WithPage {\n async login(userName: string, password: string): Promise<void> {\n await this.page.goto('./');\n await expect(this.page).toHaveTitle('Digital.ai Release');\n await this.page.locator('#inputLogin').fill(userName);\n await this.page.locator('#inputPassword').fill(password);\n await this.page.locator(\"button[type='submit']\").click();\n await expect(this.page.locator('#releases-content')).toBeVisible();\n }\n\n async logout(): Promise<void> {\n await this.page.locator('button.dot-avatar').click();\n await this.page.getByText('Log out').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","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","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 description: string;\n dueDate?: Date;\n endDate?: Date;\n extensions: Array<ReleaseExtension>;\n owner?: string;\n passwordVariableValues?: VariableValues;\n phases: Array<Phase>;\n queryableEndDate?: Date;\n queryableStartDate?: Date;\n scheduledStartDate?: Date;\n scriptUserPassword?: string;\n scriptUsername?: string;\n startDate?: Date;\n status: ReleaseStatus;\n summary?: Dashboard;\n teams: Array<Team>;\n variableValues?: VariableValues;\n variables: Array<Variable>;\n}\n\ninterface VariableValues {\n [key: string]: any;\n}\n\nexport interface Variable extends BaseConfigurationItem {\n key: string;\n requiresValue: boolean;\n showOnReleaseStart: boolean;\n value: any;\n valueProvider?: VariableValueProvider;\n}\n\nexport interface VariableValueProvider {\n id: string;\n variable: string;\n}\n\nexport interface Container extends PlanItem {\n tasks: Array<Task>;\n}\n\nexport interface Phase extends Container {\n status: PhaseStatus;\n}\n\nexport interface Task extends PlanItem {\n attachments: Array<Attachment>;\n comments: Array<Comment>;\n conditions: Array<Condition>;\n dependencies: Array<Dependency>;\n links: Array<Link>;\n owner?: string;\n pythonScript?: PythonScript;\n status: TaskStatus;\n tasks: Array<Task>;\n templateVariables: Array<Variable>;\n}\n\ntype Condition = PlanItem;\ntype Dependency = PlanItem;\ntype Link = PlanItem;\ntype Comment = PlanItem;\ntype Attachment = PlanItem;\n\nexport interface Dashboard extends ReleaseExtension {\n tiles: Array<Tile>;\n}\n\ntype ReleaseExtension = BaseConfigurationItem;\nexport type Tile = BaseConfigurationItem;\n\ninterface PythonScript extends BaseConfigurationItem {\n customScriptTask: 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\ntype Team = BaseConfigurationItem;\n\ntype FeatureCategory = 'Stable' | 'Incubating';\ntype FeatureType = 'xlrelease.TaskDrawer'; // add more as needed\nexport interface FixtureFeature {\n category: FeatureCategory;\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 apiToken?: string;\n password?: string;\n url: string;\n username?: string;\n}\n\nexport interface FixtureTrigger extends PlanItem {\n folderId?: string;\n gitRepository?: string;\n periodicity?: number | string;\n pollType?: string;\n releaseTitle: string;\n template: string;\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 defaults(variable, getVariableEntity(variable.value, variable.key, task.id, idx));\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,\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 defaults(variable, getVariableEntity(variable.value, variable.key, release.id, index));\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/LoginPage';\nimport { ApplicationsPage } from '../pages/ApplicationsPage';\nimport { PersonalAccessTokenPage } from '../pages/PersonalAccessTokenPage';\nimport { initReleaseDefaults } from './helper';\nimport * as process from 'process';\nimport { FixtureConfiguration, FixtureFeature, FixtureRelease, FixtureTrigger, Release } from '../types';\n\nconst adminHeaders = {\n Authorization: 'Basic YWRtaW46YWRtaW4=',\n Cookie: 'XSRF-TOKEN=1;',\n 'X-XSRF-TOKEN': '1',\n};\n\ntype ReleaseFixtures = {\n applicationPage: ApplicationsPage;\n fixtures: Fixtures;\n loginPage: LoginPage;\n navigation: Navigation;\n personalAccessTokenPage: PersonalAccessTokenPage;\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 applicationPage: async ({ page }, use) => {\n const applicationPage = new ApplicationsPage(page);\n await use(applicationPage);\n return applicationPage;\n },\n personalAccessTokenPage: async ({ page }, use) => {\n const personalAccessTokenPage = new PersonalAccessTokenPage(page);\n await use(personalAccessTokenPage);\n return personalAccessTokenPage;\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 releaseIds: Array<string> = [];\n private triggerIds: Array<string> = [];\n private configurationIds: 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 configuration(ci: FixtureConfiguration): Promise<APIResponse> {\n this.configurationIds.push(ci.id);\n return this.doPost('fixtures/shared', [ci]);\n }\n\n trigger(trigger: FixtureTrigger): Promise<APIResponse> {\n this.triggerIds.push(trigger.id);\n return this.doPost('fixtures/trigger', trigger);\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 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 cleanAll(): Promise<Awaited<APIResponse>[]> {\n const promises = [];\n for (const releaseId of this.releaseIds.reverse()) {\n promises.push(this.deleteRelease(releaseId));\n }\n for (const triggerId of this.triggerIds) {\n promises.push(this.deleteTrigger(triggerId));\n }\n for (const confId of this.configurationIds) {\n promises.push(this.deleteConfiguration(confId));\n }\n this.releaseIds = [];\n this.triggerIds = [];\n this.configurationIds = [];\n return Promise.all(promises);\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 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([{ id: 'Configuration/features/xlrelease.TaskDrawer', type: 'xlrelease.TaskDrawer', category: 'Stable', enabled: enabled }]);\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/types/index.ts","apps/release/fixtures/helper.ts","apps/release/pages/WithPage.ts","apps/release/pages/login-page.ts","apps/release/pages/releases/ReleasesListPage.ts","apps/release/pages/TriggersPage.ts","apps/release/pages/helper/index.ts","apps/release/pages/releases/ReleaseVariablesPage.ts","apps/release/pages/task-drawer/taskConfig.ts","apps/release/pages/task-drawer/taskCondition.ts","apps/release/pages/task-drawer/taskDrawer.ts","apps/release/pages/releases/ReleasePage.ts","apps/release/pages/ApplicationsPage.ts","apps/release/pages/PersonalAccessTokenPage.ts","apps/release/pages/users/userModal.ts","apps/release/pages/users/usersPage.ts","apps/release/pages/settingsMenu.ts","apps/release/pages/taskDetails.ts","apps/release/pages/index.ts","apps/release/fixtures/index.ts","apps/release/index.ts"],"sourcesContent":["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 description: string;\n dueDate?: Date;\n endDate?: Date;\n extensions: Array<ReleaseExtension>;\n owner?: string;\n passwordVariableValues?: VariableValues;\n phases: Array<Phase>;\n queryableEndDate?: Date;\n queryableStartDate?: Date;\n scheduledStartDate?: Date;\n scriptUserPassword?: string;\n scriptUsername?: string;\n startDate?: Date;\n status: ReleaseStatus;\n summary?: Dashboard;\n teams: Array<Team>;\n variableValues?: VariableValues;\n variables: Array<Variable>;\n}\n\ninterface VariableValues {\n [key: string]: any;\n}\n\nexport interface Variable extends BaseConfigurationItem {\n key: string;\n requiresValue: boolean;\n showOnReleaseStart: boolean;\n value: any;\n valueProvider?: VariableValueProvider;\n}\n\nexport interface VariableValueProvider {\n id: string;\n variable: string;\n}\n\nexport interface Container extends PlanItem {\n tasks: Array<Task>;\n}\n\nexport interface Phase extends Container {\n status: PhaseStatus;\n}\n\nexport interface Task extends PlanItem {\n attachments: Array<Attachment>;\n comments: Array<Comment>;\n conditions: Array<Condition>;\n dependencies: Array<Dependency>;\n links: Array<Link>;\n owner?: string;\n pythonScript?: PythonScript;\n status: TaskStatus;\n tasks: Array<Task>;\n templateVariables: Array<Variable>;\n}\n\ntype Condition = PlanItem;\ntype Dependency = PlanItem;\ntype Link = PlanItem;\ntype Comment = PlanItem;\ntype Attachment = PlanItem;\n\nexport interface Dashboard extends ReleaseExtension {\n tiles: Array<Tile>;\n}\n\ntype ReleaseExtension = BaseConfigurationItem;\nexport type Tile = BaseConfigurationItem;\n\ninterface PythonScript extends BaseConfigurationItem {\n customScriptTask: 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\ntype Team = BaseConfigurationItem;\n\ntype FeatureCategory = 'Stable' | 'Incubating';\ntype FeatureType = 'xlrelease.TaskDrawer'; // add more as needed\nexport interface FixtureFeature {\n category: FeatureCategory;\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 apiToken?: string;\n password?: string;\n url: string;\n username?: string;\n}\n\nexport interface FixtureTrigger extends PlanItem {\n folderId?: string;\n gitRepository?: string;\n periodicity?: number | string;\n pollType?: string;\n releaseTitle: string;\n template: string;\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 defaults(variable, getVariableEntity(variable.value, variable.key, task.id, idx));\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,\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 defaults(variable, getVariableEntity(variable.value, variable.key, release.id, index));\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 { 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 { expect } 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 this.page.waitForTimeout(1000);\n await expect(this.page).toHaveTitle('Digital.ai Release');\n await this.page.locator('#inputLogin').fill(userName);\n await this.page.locator('#inputPassword').fill(password);\n await this.page.locator(\"button[type='submit']\").click();\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').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","import { expect } from '@playwright/test';\nimport { ReleasePage } from './ReleasePage';\nimport { WithPage } from '../WithPage';\n\nexport class ReleasesListPage extends WithPage {\n async expectNumberOfReleases(releaseTitle: string, amount: number): Promise<void> {\n if (amount === 1) {\n await expect(this.page.locator('.release').getByText(releaseTitle)).toBeVisible();\n } else {\n await expect(this.page.locator('.release').getByText(releaseTitle).count()).toBe(amount);\n }\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","import { expect } from '@playwright/test';\nimport { ReleasesListPage } from './releases/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 { expect, Locator } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { waitForOneOf } from '../helper';\n\ntype ExpectWithLocator = (l: Locator) => void;\n\nexport class ReleaseVariablesPage extends WithPage {\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\nclass ReleaseVariableModal extends WithPage {\n private async expectValue(locators: Locator[], expectFn: ExpectWithLocator[]): Promise<void> {\n const [index, locator] = await waitForOneOf(locators);\n await 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 ],\n [(l) => expect(l).toHaveValue(value), (l) => expect(l).toHaveText(value), (l) => expect(l).toHaveText(value)],\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 ],\n [\n (l) => expect(l.inputValue()).toContain(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","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 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.getByRole('textbox');\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","import { ConfigRail } from './taskConfig';\nimport { WithPage } from '../WithPage';\nimport { Locator, Page } from '@playwright/test';\nimport { ConditionRail } from './taskCondition';\n\ntype Rail = 'Overview' | 'Activity' | 'Config' | 'Scheduling' | 'Conditions' | 'Attributes' | 'Attach' | 'Tags';\n\nexport class TaskDrawer extends WithPage {\n config: ConfigRail;\n condition: ConditionRail;\n taskDrawerLocator: Locator;\n retryButton: Locator;\n cancelButton: Locator;\n commentBox: Locator;\n confirm: Locator;\n skipMenu: Locator;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawerLocator = this.page.locator('task-drawer .dot-drawer');\n this.retryButton = this.page.getByRole('button', { name: 'Retry' });\n this.cancelButton = this.page.getByTestId('task-action-cancel');\n this.commentBox = this.page.getByTestId('task-action-comment');\n this.confirm = this.page.getByTestId('task-action-confirm');\n this.config = new ConfigRail(page);\n this.condition = new ConditionRail(page);\n this.skipMenu = this.page.getByRole('menuitem', { name: 'Skip' });\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<void> {\n await this.openRail('Scheduling');\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 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.retryButton.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n\n async skipTask(comment: string): Promise<void> {\n await this.page.getByRole('button', { name: 'arrow-down icon', exact: true }).click();\n await this.skipMenu.click();\n await this.commentBox.fill(comment);\n await this.confirm.click();\n }\n}\n","import { Page, Locator, expect } from '@playwright/test';\nimport { TriggersPage } from '../TriggersPage';\nimport { WithPage } from '../WithPage';\nimport { ReleaseVariablesPage } from './ReleaseVariablesPage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class ReleasePage extends WithPage {\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(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.locator('action-toolbar button', { hasText: 'Abort' }).click();\n await this.page.locator('.modal textarea').fill(comment);\n await this.page.locator('.modal .continue').click();\n }\n\n getPhase(phaseName: string): Phase {\n return new Phase(this.page, phaseName);\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 }\n\n async waitForTaskCompleted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.completed').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n async waitForTaskFailed(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.failed').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n async waitForTaskSkipped(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.skipped').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n async waitForTaskAborted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.aborted').getByText(taskTitle, { exact: true })).toBeVisible();\n }\n async waitForStatusLine(statusLine: string): Promise<void> {\n await expect(this.page.locator('.task .status-line').getByText(statusLine, { exact: true })).toBeVisible();\n }\n\n async waitForTaskStarted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByTitle(taskTitle, { exact: true })).toBeVisible();\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.task-header').getByText(taskName).click();\n return this.taskDrawer;\n }\n\n async openVariables(): Promise<ReleaseVariablesPage> {\n await this.openReleaseMenu('Variables');\n return new ReleaseVariablesPage(this.page);\n }\n\n 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\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 addTask(taskName: string, taskGroup: string, taskType: string): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.phaseLocator.locator('.quick-title').fill(taskName);\n await this.phaseLocator.locator('.xlr-ctx-menu-toggle').click();\n await this.page.locator(`.xlr-ctx-menu-item`).getByTitle(taskGroup, { exact: true }).scrollIntoViewIfNeeded();\n await this.page.locator(`.xlr-ctx-menu-item`).getByTitle(taskGroup, { exact: true }).hover();\n await this.page.locator(`.xlr-ctx-menu.active`).getByTitle(taskType, { exact: true }).click();\n await this.phaseLocator.locator('.quick-controls-container a').getByText('Add', { exact: true }).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","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 { Locator, Page } 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('#full-name');\n this.email = page.locator('#email');\n this.password = page.locator('[data-test=\"password-input\"]');\n this.cnfPassword = page.locator('#passwordConfirmation');\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 setConfirmPassword(cnfPassword: string): Promise<void> {\n return await this.cnfPassword.fill(cnfPassword);\n }\n\n async save(): Promise<void> {\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","import { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { UserModal } from './userModal';\n\nexport class UsersPage extends WithPage {\n page: Page;\n newUserButton: Locator;\n modal: UserModal;\n constructor(page: Page) {\n super(page);\n this.page = page;\n this.newUserButton = this.page.getByTestId('new-user-btn');\n this.modal = new UserModal(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 .check();\n //await this.page.locator(`tr:contains('${username}') .login-permission input`).click();\n }\n\n async addUser(): Promise<void> {\n await this.newUserButton.click();\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 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\n .getByRole('row', { name: '' + username + '' })\n .locator('i')\n .nth(1)\n .click();\n await this.modal.delete();\n }\n}\n","import { Locator, Page } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class SettingsMenu extends WithPage {\n settingsIcon: Locator;\n usersAndPermissionMenu: Locator;\n managePluginMenu: Locator;\n constructor(page: Page) {\n super(page);\n this.settingsIcon = this.page.getByRole('button', { name: 'Settings' });\n this.usersAndPermissionMenu = this.page.getByTestId('undefined-menu').getByText('Users and permissions');\n this.managePluginMenu = this.page.getByText('Manage plugins');\n }\n\n async openUsersAndPermissions(): Promise<void> {\n await this.settingsIcon.click();\n await this.page.getByTestId('undefined-menu').getByText('Users and permissions').click();\n }\n\n async openManagePlugin(): Promise<void> {\n await this.settingsIcon.click();\n await this.managePluginMenu.click();\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 { Page } from '@playwright/test';\nimport { ReleasePage } from './releases/ReleasePage';\nimport { ApplicationsPage } from './ApplicationsPage';\nimport { PersonalAccessTokenPage } from './PersonalAccessTokenPage';\nimport { UsersPage } from './users/usersPage';\nimport { SettingsMenu } from './settingsMenu';\nimport { TaskDetails } from './taskDetails';\n\nexport class Navigation {\n private readonly page: Page;\n releasePage: ReleasePage;\n settingsMenu: SettingsMenu;\n usersPage: UsersPage;\n applicationPage: ApplicationsPage;\n taskDetailsPage: TaskDetails;\n\n constructor(page: Page) {\n this.page = page;\n this.releasePage = new ReleasePage(page);\n this.settingsMenu = new SettingsMenu(page);\n this.usersPage = new UsersPage(page);\n this.applicationPage = new ApplicationsPage(page);\n this.taskDetailsPage = new TaskDetails(page);\n }\n\n async openTemplate(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, false);\n }\n\n async openRelease(id: string): Promise<ReleasePage> {\n return this.openReleaseOrTemplate(id, true);\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 gotoFolderPage(): Promise<void> {\n await this.page.getByText('Folders').click();\n }\n\n async gotoTaskPage(): Promise<void> {\n await this.page.getByTestId('sideNav-item-3').getByText('Tasks').click();\n }\n\n async gotoReleasePage(): Promise<void> {\n await this.page.getByText('Releases').click();\n }\n\n async gotoWorkflowCatalogPage(): Promise<void> {\n await this.page.getByText('Workflow catalog').click();\n }\n\n async gotoWorkflowsPage(): Promise<void> {\n await this.page.getByTestId('sideNav-item-6').getByText('Workflows').click();\n }\n\n async gotoGroupsPage(): Promise<void> {\n await this.page.getByText('Groups').click();\n }\n\n async gotoReleaseCalenderPage(): Promise<void> {\n await this.page.getByText('Release calendar').click();\n }\n\n async gotoDeliveriesPage(): Promise<void> {\n await this.page.getByText('Deliveries').click();\n }\n\n async gotoTriggersPage(): Promise<void> {\n await this.page.getByText('Triggers').click();\n }\n\n async gotoDigitalAnalyticsPage(): Promise<void> {\n await this.page.getByText('Digital.ai Analytics').click();\n }\n\n async gotoReportsPage(): Promise<void> {\n await this.page.getByText('Reports').click();\n }\n\n async gotoTemplatesPage(): Promise<void> {\n await this.page.getByText('Templates').click();\n }\n\n async gotoEnvironmentsPage(): Promise<void> {\n await this.page.getByText('Environments').click();\n }\n\n async gotoEnvironmentsCalenderPage(): Promise<void> {\n await this.page.getByText('Environments calendar').click();\n }\n\n async gotoGobalVariablesPage(): Promise<void> {\n await this.page.getByText('Global variables').click();\n }\n async gotoConnectionsPage(): Promise<void> {\n await this.page.getByText('Connections').click();\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","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 { initReleaseDefaults } from './helper';\nimport { LoginPage } from '../pages/login-page';\nimport { Navigation } from '../pages';\nimport * as process from 'process';\nimport { FixtureConfiguration, FixtureFeature, FixtureRelease, FixtureTrigger, Release } from '../types';\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 releaseIds: Array<string> = [];\n private triggerIds: Array<string> = [];\n private configurationIds: Array<string> = [];\n private usernames: Array<string> = [];\n private userProfiles: 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 configuration(ci: FixtureConfiguration): Promise<APIResponse> {\n this.configurationIds.push(ci.id);\n return this.doPost('fixtures/shared', [ci]);\n }\n\n trigger(trigger: FixtureTrigger): Promise<APIResponse> {\n this.triggerIds.push(trigger.id);\n return this.doPost('fixtures/trigger', trigger);\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 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 cleanAll(): Promise<Awaited<APIResponse>[]> {\n const promises = [];\n for (const releaseId of this.releaseIds.reverse()) {\n promises.push(this.deleteRelease(releaseId));\n }\n for (const triggerId of this.triggerIds) {\n promises.push(this.deleteTrigger(triggerId));\n }\n for (const confId of this.configurationIds) {\n promises.push(this.deleteConfiguration(confId));\n }\n for (const usernames of this.usernames) {\n promises.push(this.deleteUser(usernames));\n }\n for (const userProfiles of this.userProfiles) {\n promises.push(this.deleteUserProfile(userProfiles));\n }\n this.releaseIds = [];\n this.triggerIds = [];\n this.configurationIds = [];\n this.usernames = [];\n this.userProfiles = [];\n return Promise.all(promises);\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 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 {\n id: 'Configuration/features/xlrelease.TaskDrawer',\n type: 'xlrelease.TaskDrawer',\n category: 'Stable',\n enabled: enabled,\n },\n ]);\n }\n\n async addUser(username: string, password: string): Promise<APIResponse> {\n this.usernames.push(username);\n return await this.doPost('fixtures/user', { username, password });\n }\n\n async addUserProfile(username: string, profile: any): Promise<APIResponse> {\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 return await this.doPost('fixtures/userProfile', profile);\n }\n\n async deleteUser(username: string): Promise<APIResponse> {\n return await this.request.delete(`fixtures/user/${username}`);\n }\n\n async deleteUserProfile(username: string): Promise<APIResponse> {\n return await this.request.delete(`fixtures/userProfile/${username}`);\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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@digital-ai/devops-page-object-release",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.8",
|
|
4
4
|
"source": "index.ts",
|
|
5
5
|
"main": "dist/main.js",
|
|
6
6
|
"module": "dist/module.js",
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
"scripts": {
|
|
41
41
|
"lint": "eslint . --ext .js,.jsx,.ts,.tsx",
|
|
42
42
|
"tsc": "tsc --noEmit",
|
|
43
|
-
"build": "parcel build --cache-dir .parcel-cache
|
|
43
|
+
"build": "parcel build --cache-dir .parcel-cache",
|
|
44
44
|
"e2e": "e2e-test"
|
|
45
45
|
}
|
|
46
46
|
}
|