@digital-ai/devops-page-object-release 0.0.13 → 0.0.14

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.
@@ -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;IAS3E,iBAAiB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAK7D,oBAAoB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAMhE;ACrBD,0BAA0B,SAAQ,QAAQ;IAClC,qBAAqB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAYtE;AEXD,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,wBAAwB,SAAQ,QAAQ;IACtC,WAAW,EAAE,OAAO,CAAC;gBAET,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;CAKxF;AClED,2BAA2B,SAAQ,QAAQ;IACzC,WAAW,EAAE,OAAO,CAAC;IACrB,kBAAkB,EAAE,OAAO,CAAC;IAC5B,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;gBAER,IAAI,EAAE,IAAI;IAQhB,kBAAkB,IAAI,OAAO,CAAC,IAAI,CAAC;IAKnC,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAKpC,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAMrD;AC9BD,0BAA0B,SAAQ,QAAQ;IACxC,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,UAAU,CAAC;gBACX,IAAI,EAAE,IAAI;IAMhB,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;IAMjF,eAAe,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAahF,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMxC,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpD,0BAA0B,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMzD,gCAAgC,IAAI,OAAO,CAAC,IAAI,CAAC;IAKjD,kCAAkC,IAAI,OAAO,CAAC,IAAI,CAAC;IAKnD,2BAA2B,IAAI,OAAO,CAAC,IAAI,CAAC;IAK5C,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOrC,2BAA2B,CAAC,YAAY,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAO/D,yBAAyB,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,UAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBzE,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC;IAMrC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAK9B,oBAAoB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKzD,mBAAmB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAe/D;AAED,wBAAwB,SAAQ,QAAQ;gBAM1B,IAAI,EAAE,IAAI;IAQhB,UAAU,IAAI,OAAO,CAAC,GAAG,CAAC;IAM1B,QAAQ,IAAI,OAAO,CAAC,GAAG,CAAC;IAMxB,OAAO,IAAI,OAAO,CAAC,GAAG,CAAC;IAMvB,UAAU,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAM/C,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAKrB,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAM3C,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMzC,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAI3B,yBAAyB,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAMvD,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAK9B,oBAAoB,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQnD,gBAAgB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMrD,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAI1D;AC1QD,0BAA0B,SAAQ,QAAQ;IAClC,sBAAsB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAG1D;ACJD,4BAA4B,SAAQ,QAAQ;IACpC,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMrD,uBAAuB,IAAI,OAAO,CAAC,MAAM,CAAC;IAI1C,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAO3C,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAW7C,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMjD,sBAAsB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAQ9D;ACrCD,YAAY,UAAU,GAAG,UAAU,GAAG,QAAQ,GAAG,YAAY,GAAG,YAAY,GAAG,YAAY,GAAG,QAAQ,GAAG,MAAM,CAAC;AAEhH,wBAAwB,SAAQ,QAAQ;IACtC,QAAQ,EAAE,YAAY,CAAC;IACvB,UAAU,EAAE,cAAc,CAAC;IAC3B,MAAM,EAAE,UAAU,CAAC;IACnB,SAAS,EAAE,aAAa,CAAC;IACzB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,WAAW,EAAE,OAAO,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;IACtB,UAAU,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,YAAY,CAAC;IACvB,QAAQ,EAAE,OAAO,CAAC;gBAEN,IAAI,EAAE,IAAI;IAehB,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,kBAAkB,IAAI,OAAO,CAAC,IAAI,CAAC;IAInC,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIlC,kBAAkB,IAAI,OAAO,CAAC,IAAI,CAAC;IAInC,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAI7B,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAInC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAItB,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMzC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOxC,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAKxD;AC1FD,mCAAmC,SAAQ,QAAQ;gBACrC,IAAI,EAAE,IAAI;IAIhB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK5C,cAAc,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQlD,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMlD,qBAAqB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMtD,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAKrB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAI7B;ACnCD,yBAAyB,SAAQ,QAAQ;IACvC,UAAU,EAAE,UAAU,CAAC;IACvB,UAAU,EAAE,qBAAqB,CAAC;IAClC,SAAS,EAAE,oBAAoB,CAAC;gBAEpB,IAAI,EAAE,IAAI;IAOhB,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,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIjD,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKtD,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD,kBAAkB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKpD,kBAAkB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKpD,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMpD,kBAAkB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAMpD,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAKrD,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAI9B,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAIhC,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIlC,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIrC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAI9B,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAYjC,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIzC,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAWpC,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAUlC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;CAGrC;AAED,mBAAY,SAAQ,QAAQ;gBAGd,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM;IAKnC,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOtC,yBAAyB,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIzE,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC;IAkB/D,gBAAgB,IAAI,OAAO,CAAC,MAAM,CAAC;IAInC,4BAA4B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI/D,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAG3D;AC/LD,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;AChBD,uBAAuB,SAAQ,QAAQ;IACrC,QAAQ,EAAE,OAAO,CAAC;IAClB,IAAI,EAAE,OAAO,CAAC;IACd,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,OAAO,CAAC;IACpB,YAAY,EAAE,OAAO,CAAC;IACtB,YAAY,EAAE,OAAO,CAAC;gBACV,IAAI,EAAE,IAAI;IAYhB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5C,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5C,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAItC,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5C,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAItD,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAOrB,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAIvB,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;CAG9B;ACtDD,uBAAuB,SAAQ,QAAQ;IACrC,IAAI,EAAE,IAAI,CAAC;IACX,aAAa,EAAE,OAAO,CAAC;IACvB,KAAK,EAAE,SAAS,CAAC;gBACL,IAAI,EAAE,IAAI;IAOhB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAI9B,qBAAqB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQtD,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAIxB,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS7D,2BAA2B,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5D,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAQlD;ACjDD,0BAA0B,SAAQ,QAAQ;IACxC,YAAY,EAAE,OAAO,CAAC;IACtB,sBAAsB,EAAE,OAAO,CAAC;IAChC,gBAAgB,EAAE,OAAO,CAAC;gBACd,IAAI,EAAE,IAAI;IAOhB,uBAAuB,IAAI,OAAO,CAAC,IAAI,CAAC;IAKxC,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;CAIxC;ACpBD,yBAAyB,SAAQ,QAAQ;gBAC3B,IAAI,EAAE,IAAI;CAGvB;ACJD,iCAAiC,SAAQ,QAAQ;IAMzC,uBAAuB,IAAI,OAAO,CAAC,IAAI,CAAC;IAoBxC,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAS/B,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC;IAWvC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAU/B,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAUhC,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAW/C,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQlD,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAUzE,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAa1F,qBAAqB,CAAC,cAAc,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IASnF,mBAAmB,CAAC,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS/E,oBAAoB,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAY1D,WAAW,CAAC,aAAa,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYrE,cAAc,CAAC,cAAc,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAW3E,mBAAmB,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAalE;AC/KD;IAEE,WAAW,EAAE,WAAW,CAAC;IACzB,YAAY,EAAE,YAAY,CAAC;IAC3B,SAAS,EAAE,SAAS,CAAC;IACrB,eAAe,EAAE,gBAAgB,CAAC;IAClC,eAAe,EAAE,WAAW,CAAC;IAC7B,mBAAmB,EAAE,mBAAmB,CAAC;IACzC,eAAe,EAAE,gBAAgB,CAAC;gBAEtB,IAAI,EAAE,IAAI;IAWhB,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI9C,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI7C,oBAAoB,IAAI,OAAO,CAAC,gBAAgB,CAAC;IAIjD,2BAA2B,IAAI,OAAO,CAAC,uBAAuB,CAAC;IAI/D,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAI7B,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAIhC,uBAAuB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIxC,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIlC,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,uBAAuB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIxC,kBAAkB,IAAI,OAAO,CAAC,IAAI,CAAC;IAInC,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,wBAAwB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIzC,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAIhC,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIlC,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIrC,4BAA4B,IAAI,OAAO,CAAC,IAAI,CAAC;IAI7C,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;IAGvC,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;CAS3C;AChHD,uBAAuB,SAAQ,QAAQ;IACrC;;;;OAIG;IACG,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS9D;;OAEG;IACG,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAK7B;;OAEG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAK5C;;;OAGG;IACG,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAIxD;AC1CD;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,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,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,IAAI,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACrB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;CAC5B;AAED,sBAAsB,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AAK1C,kBAA0B,SAAQ,qBAAqB;IACrD,GAAG,EAAE,MAAM,CAAC;IACZ,aAAa,EAAE,OAAO,CAAC;IACvB,kBAAkB,EAAE,OAAO,CAAC;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,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,sBAA4B,SAAQ,QAAQ;IAC1C,kBAAkB,EAAE,OAAO,CAAC;IAC5B,gBAAgB,EAAE,MAAM,CAAC;IACzB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,MAAM,EAAE;QACN,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,QAAQ,EAAE,MAAM,CAAC;CAClB;AACD,gBAAwB,SAAQ,QAAQ;IACtC,QAAQ,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACzB,KAAK,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,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,YAAU,CAAC,CAAC;IAChC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,UAAU,CAAC;IACnB,IAAI,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACrB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;CACpC;AAED,iBAAiB,QAAQ,CAAC;AAC1B,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;AAI7B,cAAsB,SAAQ,QAAQ;IACpC,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAC3B,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,mBAAmB,sBAAsB,CAAC;AAC1C;IACE,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;AAWD,4BAAoC,SAAQ,QAAQ;IAClD,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;CAClB;AEnJD,uBAAuB;IACrB,QAAQ,EAAE,QAAQ,CAAC;IACnB,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,EAAE,UAAU,CAAC;CACxB,CAAC;AAEF,OAAO,MAAM,mQAgBX,CAAC;AAEH;gBAac,OAAO,EAAE,iBAAiB,EAAE,IAAI,EAAE,IAAI;IAKlD,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,WAAW,CAAC;IAQtD,eAAe,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,WAAW,CAAC;IAM9D,aAAa,CAAC,EAAE,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IAK7D,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM;IAI/B,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAa5C,qBAAqB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAUvD,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAK/C,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAIlD,iBAAiB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI5D,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI/C,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAIrD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAKpD,YAAY,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,kBAAkB,CAAC,GAAG,OAAO,CAAC,WAAW,CAAC;IAI/E,cAAc,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC;IAQlD,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IA2BzB,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC;IAkB9B,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1D,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC;IAW9D,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAW3E,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAW7E,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,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAIvD,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAI1D,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC,WAAW,CAAC;IAIlE,gBAAgB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CAyB/D","sources":["apps/release/pages/WithPage.ts","apps/release/pages/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/taskOverview.ts","apps/release/pages/task-drawer/taskActivity.ts","apps/release/pages/task-drawer/taskAttachments.ts","apps/release/pages/task-drawer/taskDrawer.ts","apps/release/pages/releases/releasePropertiesPage.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/ReleaseCalendarPage.ts","apps/release/pages/index.ts","apps/release/pages/login-page.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 './releases/ReleasePage';\nimport { WithPage } from './WithPage';\n\nexport class ReleasesListPage extends WithPage {\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 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 async filterReleaseByTitle(releaseTitle: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').click();\n await this.page.locator('.searchFilter').fill(releaseTitle);\n await this.page.locator('.searchFilter').press('Enter');\n await expect(this.page.locator('.release').getByText(releaseTitle)).toBeVisible();\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 { 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 { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class OverviewRail extends WithPage {\n railLocator: Locator;\n dependency: Dependency;\n constructor(page: Page) {\n super(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-drawer-content');\n this.dependency = new Dependency(page);\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 async setValueFromMap(propertyName: string, key: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-with-map[data-test-id=\"${propertyName}\"] button.add-new-button`).click();\n await this.railLocator\n .locator(`.input-with-map[data-test-id=\"${propertyName}\"] input[id=\"new-row-key-input\"]`)\n .fill(key);\n await this.railLocator\n .locator(`.input-with-map[data-test-id=\"${propertyName}\"] input[id=\"new-row-value-input\"]`)\n .fill(value);\n await this.railLocator\n .locator(`.input-with-map[data-test-id=\"${propertyName}\"] button.map-row-save-button`)\n .click();\n }\n\n async setScript(script: string): Promise<void> {\n await this.page.locator('.code-editor textarea.ace_text-input').clear();\n await this.page.locator('.code-editor textarea.ace_text-input').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.page.locator('.code-editor textarea.ace_text-input').clear();\n await this.page.locator('.code-editor textarea.ace_text-input').fill(script);\n await this.page.locator('.code-editor textarea.ace_text-input').press('.');\n }\n\n async openScriptEditorInSeparateWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-enter-btn').click();\n expect(this.page.locator('#dialogTitle')).toBeVisible();\n }\n\n async closeFullscreenScriptWindowWithESC(): Promise<void> {\n await this.page.locator('#dialogTitle').press('Escape');\n expect(this.page.locator('#dialogTitle')).not.toBeVisible();\n }\n\n async closeFullscreenScriptWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-exit-btn').click();\n 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.getByTestId('task-action-confirm').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 expectCanDeleteDependency(title: string, canDelete = true): Promise<void> {\n if (canDelete) {\n const locat = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options');\n await locat.isVisible();\n await locat.click();\n await expect(this.railLocator.getByRole('menuitem', { name: 'Remove' })).toBeVisible();\n } else {\n await expect(\n this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options'),\n ).not.toBeVisible();\n }\n }\n\n async getDependencyCount(): Promise<number> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n const count = await this.railLocator.locator('.gate-task-dependencies .dependency').count();\n return 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 expectDependencyText(dependencies: string): Promise<void> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n await expect(this.page.getByRole('link', { name: dependencies, exact: true }).first()).toBeVisible();\n }\n\n async clickEditDependency(dependencies: string): Promise<void> {\n const locat = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: dependencies, exact: true }) })\n .locator('.icon-options');\n await locat.isVisible();\n await locat.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 locat.nth(1).click();\n await this.railLocator.getByRole('menuitem', { name: 'Edit' }).click();\n }\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<any> {\n await this.release.isVisible();\n const releaseValue = await this.release.getAttribute('value');\n return releaseValue;\n }\n\n async getPhase(): Promise<any> {\n await this.phase.isVisible();\n const phaseValue = await this.phase.getAttribute('value');\n return phaseValue;\n }\n\n async getTask(): Promise<any> {\n await this.task.isVisible();\n const taskValue = await this.task.getAttribute('value');\n return taskValue;\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 }).click();\n }\n\n async save(): Promise<void> {\n await expect(this.dependencyLocator.getByRole('button', { name: 'OK' })).toBeEnabled();\n await this.dependencyLocator.getByRole('button', { name: 'OK' }).click();\n }\n\n async setPhase(phaseTitle: string): Promise<void> {\n await this.phase.click();\n await this.phase.fill('');\n await this.page.getByRole('option', { name: phaseTitle }).click();\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').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","import { expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ActivityRail extends WithPage {\n async expectCommentToContain(text: string): Promise<void> {\n await expect(this.page.locator('.task-comment .markdown-wrapper p')).toContainText(text);\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 test.isVisible();\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' }).click();\n }\n\n async expectWithNoAttachment(tempFile: string): Promise<void> {\n const test = await this.page.locator('.task-attachments-grid .file-item-text').isVisible();\n if (test) {\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 { ConfigRail } from './taskConfig';\nimport { WithPage } from '../WithPage';\nimport { Locator, Page } from '@playwright/test';\nimport { ConditionRail } from './taskCondition';\nimport { OverviewRail } from './taskOverview';\nimport { ActivityRail } from './taskActivity';\nimport { AttachmentRail } from './taskAttachments';\nimport { expect } from '@playwright/test';\n\ntype Rail = 'Overview' | 'Activity' | 'Config' | 'Scheduling' | 'Conditions' | 'Attributes' | 'Attach' | 'Tags';\n\nexport class TaskDrawer extends WithPage {\n activity: ActivityRail;\n attachment: AttachmentRail;\n config: ConfigRail;\n condition: ConditionRail;\n taskDrawerLocator: Locator;\n retryButton: Locator;\n cancelButton: Locator;\n commentBox: Locator;\n confirm: Locator;\n overview: OverviewRail;\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.activity = new ActivityRail(page);\n this.attachment = new AttachmentRail(page);\n this.config = new ConfigRail(page);\n this.condition = new ConditionRail(page);\n this.overview = new OverviewRail(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 async expectTaskTitle(taskTitle: string): Promise<void> {\n expect(await this.page.locator('.task-drawer .task-title-input .dot-view-mode-typography').innerText()).toContain(\n taskTitle,\n );\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\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('.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' }).click({ timeout: 2000 });\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","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';\nimport { ReleasePropertiesPage } from './releasePropertiesPage';\n\nexport class ReleasePage extends WithPage {\n taskDrawer: TaskDrawer;\n properties: ReleasePropertiesPage;\n variables: ReleaseVariablesPage;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n this.properties = new ReleasePropertiesPage(page);\n this.variables = new ReleaseVariablesPage(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 waitForCompletion(timeout: number): Promise<void> {\n await this.page.locator('#release.completed').waitFor({ timeout });\n }\n\n async waitForTaskCompleted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.completed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForTaskFailed(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.failed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForTaskSkipped(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.skipped').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForTaskAborted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.aborted').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForStatusLine(statusLine: string): Promise<void> {\n await expect(this.page.locator('.task .status-line').getByText(statusLine, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async waitForTaskStarted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByTitle(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.task-header').getByText(taskName, { exact: true }).click();\n return this.taskDrawer;\n }\n\n async openVariables(): Promise<void> {\n await this.openReleaseMenu('Variables');\n }\n\n async openProperties(): Promise<void> {\n await this.openReleaseMenu('Properties');\n }\n\n async openReleaseFlow(): Promise<void> {\n await this.openReleaseMenu('Release flow');\n }\n\n async openRelationships(): Promise<void> {\n await this.openReleaseMenu('Relationships');\n }\n\n async openTeamsPermissions(): Promise<void> {\n await this.openReleaseMenu('Teams & Permissions');\n }\n\n async openDashboard(): Promise<void> {\n await this.openReleaseMenu('Dashboard');\n }\n\n async openActivityLogs(): Promise<void> {\n await this.openReleaseMenu('ActivityLogs');\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 async backToRelease(): Promise<void> {\n await this.page.locator('.icon-back').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 setTitle(title: string): Promise<void> {\n await this.phaseLocator.locator('.phase-header .display').click();\n await this.phaseLocator.locator('.phase-header input').clear();\n await this.phaseLocator.locator('.phase-header input').fill(title);\n await this.phaseLocator.locator('.phase-header input').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 async addTaskInPhase(taskTitle: string, taskType: any): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.phaseLocator.getByPlaceholder('Task title...').click();\n await this.phaseLocator.getByPlaceholder('Task title...').fill(taskTitle);\n await this.phaseLocator.locator('.xlr-ctx-menu-toggle').click();\n const count = taskType.length - 1;\n for (let i = 0; i < count; i++) {\n await this.page\n .locator('[data-test=\"' + taskType[i] + '\"]')\n .getByText(taskType[i])\n .click();\n await this.page.getByText(taskType[i + 1]).click();\n }\n await this.phaseLocator.locator('.quick-controls-container a').getByText('Add', { exact: true }).click();\n await this.phaseLocator.locator('.button.cancel').click();\n await expect(this.phaseLocator.locator('.task').filter({ hasText: taskTitle })).toBeVisible({ timeout: 5_000 });\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","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, 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.getByTestId('save-btn');\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.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","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 .click();\n await expect(this.page.getByRole('row', { name: '' + username + '' }).locator('.Mui-checked')).toBeChecked();\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.getByRole('menuitem', { name: 'users icon Users and permissions' });\n this.managePluginMenu = this.page.getByRole('menuitem', { name: 'plugins icon Manage plugins' });\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 }\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 } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleaseCalendarPage extends WithPage {\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('./#/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).toHaveTitle('Release calendar / Home - Digital.ai Release');\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 filterReleaseByTitle(title: string): Promise<void> {\n await this.page.getByPlaceholder('Filter by release title').click();\n await this.page.getByPlaceholder('Filter by release title').fill(title);\n await this.page.getByPlaceholder('Filter by release title').press('Enter');\n //Verify Page has correct Year format displayed at the page bottom\n await this.verifyPageContent(title);\n }\n\n async filterReleaseByTags(tags: string[], release_title: string): Promise<void> {\n await this.page.locator('.tl-filter-release-tags').locator('.react-tagsinput').click();\n for (let tag of tags) {\n tag = tag.toString();\n await this.page.locator('.tl-filter-release-tags').locator('.react-tagsinput-input').fill(tag);\n await this.page.getByTitle(tag).locator('i').click();\n }\n await this.verifyPageContent(release_title);\n }\n\n async filterTaskByTags(tags: string[], task_title: string, release_title: string): Promise<void> {\n await this.page.locator('.tl-filter-task-tags').locator('.react-tagsinput').click();\n for (let tag of tags) {\n tag = tag.toString();\n await this.page.locator('.tl-filter-task-tags').locator('.react-tagsinput-input').fill(tag);\n await this.page.getByTitle(tag).locator('i').click();\n }\n //Make sure task is visible on calnedar page\n await this.verifyPageContent(task_title);\n //Make sure parent release of the selected task is visible on calnedar page\n await this.verifyPageContent(release_title);\n }\n\n async filterReleaseByStatus(release_status: string, release_title: string): Promise<void> {\n if (!(await this.page.locator('.tl-filter-advanced').isVisible())) {\n await this.page.getByRole('button', { name: 'Advanced filters' }).click();\n }\n await this.page.locator('.tl-filter-release-status').locator('.react-tagsinput').click();\n await this.page.getByTitle(release_status).locator('i').first().click();\n await this.verifyPageContent(release_title);\n }\n\n async filterReleaseByRisk(release_risk: string, release_title: string): Promise<void> {\n if (!(await this.page.locator('.tl-filter-advanced').isVisible())) {\n await this.page.getByRole('button', { name: 'Advanced filters' }).click();\n }\n await this.page.locator('.tl-filter-risk-filter').getByRole('combobox').click();\n await this.page.getByRole('option', { name: release_risk }).click();\n await this.verifyPageContent(release_title);\n }\n\n async filterFlaggedRelease(release_title: string): Promise<void> {\n if (!(await this.page.locator('.tl-filter-advanced').isVisible())) {\n await this.page.getByRole('button', { name: 'Advanced filters' }).click();\n }\n if (\n await this.page.locator('.tl-filter-flag-only.btn.btn-flat.btn-fixed.button-toggle-filter.active').isVisible()\n ) {\n await this.page.getByRole('button', { name: ' Flagged' }).click();\n }\n await this.verifyPageContent(release_title);\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 this.page.getByText(release_title).click();\n await this.page.locator('.release-modal-container').locator('.xl-icon.release-icon').click();\n const releaseurl = `/#/releases/${release_id}`;\n const currentURL = await this.page.url();\n // Check if the release name present in redirected URL\n expect(currentURL).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","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';\nimport { ReleaseCalendarPage } from './ReleaseCalendarPage';\nimport { ReleasesListPage } from './ReleasesListPage';\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 releaseCalendarPage: ReleaseCalendarPage;\n releaseListPage: ReleasesListPage;\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 this.releaseCalendarPage = new ReleaseCalendarPage(page);\n this.releaseListPage = new ReleasesListPage(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.locator('ul.side-nav li').getByText('Folders', { exact: true }).click();\n }\n\n async gotoTaskPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Tasks', { exact: true }).click();\n }\n\n async gotoReleasePage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Releases', { exact: true }).click();\n }\n\n async gotoWorkflowCatalogPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Workflow catalog', { exact: true }).click();\n }\n\n async gotoWorkflowsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Workflows', { exact: true }).click();\n }\n\n async gotoGroupsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Groups', { exact: true }).click();\n }\n\n async gotoReleaseCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Release calendar', { exact: true }).click();\n }\n\n async gotoDeliveriesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Deliveries', { exact: true }).click();\n }\n\n async gotoTriggersPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Triggers', { exact: true }).click();\n }\n\n async gotoDigitalAnalyticsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Digital.ai Analytics', { exact: true }).click();\n }\n\n async gotoReportsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Reports', { exact: true }).click();\n }\n\n async gotoTemplatesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Templates', { exact: true }).click();\n }\n\n async gotoEnvironmentsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Environments', { exact: true }).click();\n }\n\n async gotoEnvironmentsCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Environments calendar', { exact: true }).click();\n }\n\n async gotoGobalVariablesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Global variables', { exact: true }).click();\n }\n async gotoConnectionsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Connections', { exact: true }).click();\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 /**\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 }\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","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 flagStatus?: string;\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 tags?: Array<string>;\n teams: Array<Team>;\n variableValues?: VariableValues;\n variables: Array<Variable>;\n}\n\ntype VariableValues = Record<string, any>;\n// interface VariableValues {\n// [key: string]: any;\n// }\n\nexport interface Variable extends BaseConfigurationItem {\n key: string;\n requiresValue: boolean;\n showOnReleaseStart: boolean;\n value: string;\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 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<Team>;\n}\n\nexport interface Task extends PlanItem {\n attachments: Array<Attachment>;\n comments: Array<Comment>;\n conditions: Array<Condition>;\n dependencies: Array<Dependency>;\n description?: string;\n links: Array<Link>;\n owner?: string;\n precondition: string;\n pythonScript?: PythonScript;\n script: string;\n status: TaskStatus;\n tags?: Array<string>;\n tasks: Array<Task>;\n templateVariables: Array<Variable>;\n}\n\ntype Condition = 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\n//type Team = BaseConfigurationItem;\n\nexport interface Team extends PlanItem {\n members: Array<string>;\n permissions: Array<string>;\n teamName: 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 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\nexport interface FixtureActivityLog extends PlanItem {\n activityType: string;\n eventTime: Date;\n message: string;\n username: 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/login-page';\nimport { initReleaseDefaults } from './helper';\nimport * as process from 'process';\nimport {\n FixtureActivityLog,\n FixtureConfiguration,\n FixtureFeature,\n FixtureRelease,\n Folder,\n Release,\n Variable,\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 archivedReleaseIds: Array<string> = [];\n private releaseIds: 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\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 getParentId(id: string): string {\n return id.substring(0, id.lastIndexOf('/'));\n }\n\n folder(folder: Folder): Promise<APIResponse> {\n const parentId = this.getParentId(folder.id);\n //ToDo: Add system teams\n /* eslint-disable @typescript-eslint/no-unused-vars */\n const teams = folder.teams;\n delete folder.teams;\n //ToDo: Add Children\n const children = folder.children || [];\n delete folder.children;\n /* eslint-disable @typescript-eslint/no-unused-vars */\n return this.doPost(`api/v1/folders/${parentId}`, folder);\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 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 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 const id = this.doGet(`api/v1/folders/${folderId}`);\n return this.doDelete(`api/v1/folders/${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 async cleanAll(): Promise<void> {\n for (const username of this.usernames) {\n await this.deleteUser(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 this.folderIds = [];\n this.releaseIds = [];\n this.triggerIds = [];\n this.configurationIds = [];\n this.usernames = [];\n this.userProfiles = [];\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 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 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 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 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/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/taskOverview.ts","apps/release/pages/task-drawer/taskActivity.ts","apps/release/pages/task-drawer/taskAttachments.ts","apps/release/pages/task-drawer/taskDrawer.ts","apps/release/pages/releases/releasePropertiesPage.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/ReleaseCalendarPage.ts","apps/release/pages/tasks/taskListPage.ts","apps/release/pages/common/file.ts","apps/release/pages/templates/templatePropertiesPage.ts","apps/release/pages/templates/templateCreatePage.ts","apps/release/pages/templates/templateTriggerPage.ts","apps/release/pages/templates/templatePage.ts","apps/release/pages/templateListPage.ts","apps/release/pages/index.ts","apps/release/pages/login-page.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 './releases/ReleasePage';\nimport { WithPage } from './WithPage';\n\nexport class ReleasesListPage extends WithPage {\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 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 async filterReleaseByTitle(releaseTitle: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').click();\n await this.page.locator('.searchFilter').fill(releaseTitle);\n await this.page.locator('.searchFilter').press('Enter');\n await expect(this.page.locator('.release').getByText(releaseTitle)).toBeVisible();\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 { 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 { Locator, Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class OverviewRail extends WithPage {\n railLocator: Locator;\n dependency: Dependency;\n constructor(page: Page) {\n super(page);\n this.railLocator = this.page.locator('task-drawer .dot-drawer .task-drawer-content');\n this.dependency = new Dependency(page);\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 async setValueFromMap(propertyName: string, key: string, value: string): Promise<void> {\n await this.railLocator.locator(`.input-with-map[data-test-id=\"${propertyName}\"] button.add-new-button`).click();\n await this.railLocator\n .locator(`.input-with-map[data-test-id=\"${propertyName}\"] input[id=\"new-row-key-input\"]`)\n .fill(key);\n await this.railLocator\n .locator(`.input-with-map[data-test-id=\"${propertyName}\"] input[id=\"new-row-value-input\"]`)\n .fill(value);\n await this.railLocator\n .locator(`.input-with-map[data-test-id=\"${propertyName}\"] button.map-row-save-button`)\n .click();\n }\n\n async setScript(script: string): Promise<void> {\n await this.page.locator('.code-editor textarea.ace_text-input').clear();\n await this.page.locator('.code-editor textarea.ace_text-input').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.page.locator('.code-editor textarea.ace_text-input').clear();\n await this.page.locator('.code-editor textarea.ace_text-input').fill(script);\n await this.page.locator('.code-editor textarea.ace_text-input').press('.');\n }\n\n async openScriptEditorInSeparateWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-enter-btn').click();\n expect(this.page.locator('#dialogTitle')).toBeVisible();\n }\n\n async closeFullscreenScriptWindowWithESC(): Promise<void> {\n await this.page.locator('#dialogTitle').press('Escape');\n expect(this.page.locator('#dialogTitle')).not.toBeVisible();\n }\n\n async closeFullscreenScriptWindow(): Promise<void> {\n await this.page.getByTestId('fullscreen-exit-btn').click();\n 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.getByTestId('task-action-confirm').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 expectCanDeleteDependency(title: string, canDelete = true): Promise<void> {\n if (canDelete) {\n const locat = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options');\n await locat.isVisible();\n await locat.click();\n await expect(this.railLocator.getByRole('menuitem', { name: 'Remove' })).toBeVisible();\n } else {\n await expect(\n this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: title, exact: true }) })\n .locator('.icon-options'),\n ).not.toBeVisible();\n }\n }\n\n async getDependencyCount(): Promise<number> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n const count = await this.railLocator.locator('.gate-task-dependencies .dependency').count();\n return 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 expectDependencyText(dependencies: string): Promise<void> {\n await expect(this.railLocator.locator('.gate-task-dependencies')).toBeVisible();\n await expect(this.page.getByRole('link', { name: dependencies, exact: true }).first()).toBeVisible();\n }\n\n async clickEditDependency(dependencies: string): Promise<void> {\n const locat = this.page\n .locator('.dependency')\n .filter({ has: this.page.getByRole('link', { name: dependencies, exact: true }) })\n .locator('.icon-options');\n await locat.isVisible();\n await locat.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 locat.nth(1).click();\n await this.railLocator.getByRole('menuitem', { name: 'Edit' }).click();\n }\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<any> {\n await this.release.isVisible();\n const releaseValue = await this.release.getAttribute('value');\n return releaseValue;\n }\n\n async getPhase(): Promise<any> {\n await this.phase.isVisible();\n const phaseValue = await this.phase.getAttribute('value');\n return phaseValue;\n }\n\n async getTask(): Promise<any> {\n await this.task.isVisible();\n const taskValue = await this.task.getAttribute('value');\n return taskValue;\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 }).click();\n }\n\n async save(): Promise<void> {\n await expect(this.dependencyLocator.getByRole('button', { name: 'OK' })).toBeEnabled();\n await this.dependencyLocator.getByRole('button', { name: 'OK' }).click();\n }\n\n async setPhase(phaseTitle: string): Promise<void> {\n await this.phase.click();\n await this.phase.fill('');\n await this.page.getByRole('option', { name: phaseTitle }).click();\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').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","import { expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\n\nexport class ActivityRail extends WithPage {\n async expectCommentToContain(text: string): Promise<void> {\n await expect(this.page.locator('.task-comment .markdown-wrapper p')).toContainText(text);\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 test.isVisible();\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' }).click();\n }\n\n async expectWithNoAttachment(tempFile: string): Promise<void> {\n const test = await this.page.locator('.task-attachments-grid .file-item-text').isVisible();\n if (test) {\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 { ConfigRail } from './taskConfig';\nimport { WithPage } from '../WithPage';\nimport { Locator, Page } from '@playwright/test';\nimport { ConditionRail } from './taskCondition';\nimport { OverviewRail } from './taskOverview';\nimport { ActivityRail } from './taskActivity';\nimport { AttachmentRail } from './taskAttachments';\nimport { expect } from '@playwright/test';\n\ntype Rail = 'Overview' | 'Activity' | 'Config' | 'Scheduling' | 'Conditions' | 'Attributes' | 'Attach' | 'Tags';\n\nexport class TaskDrawer extends WithPage {\n activity: ActivityRail;\n attachment: AttachmentRail;\n config: ConfigRail;\n condition: ConditionRail;\n taskDrawerLocator: Locator;\n retryButton: Locator;\n cancelButton: Locator;\n commentBox: Locator;\n confirm: Locator;\n overview: OverviewRail;\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.activity = new ActivityRail(page);\n this.attachment = new AttachmentRail(page);\n this.config = new ConfigRail(page);\n this.condition = new ConditionRail(page);\n this.overview = new OverviewRail(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 async expectTaskTitle(taskTitle: string): Promise<void> {\n expect(await this.page.locator('.task-drawer .task-title-input .dot-view-mode-typography').innerText()).toContain(\n taskTitle,\n );\n }\n\n async expectTypeToContain(taskType: string): Promise<void> {\n expect(await this.page.locator('.task-drawer .task-type').innerText()).toContain(taskType);\n }\n\n async clickExpand(): Promise<void> {\n await this.page.locator('.icon-fullscreen-enter').click();\n await expect(this.page.locator('.icon-fullscreen-enter')).not.toBeVisible();\n }\n\n async clickShrink(): Promise<void> {\n await this.page.locator('.icon-fullscreen-exit').click();\n await expect(this.page.locator('.icon-fullscreen-exit')).not.toBeVisible();\n }\n}\n","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\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('.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' }).click({ timeout: 2000 });\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","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';\nimport { ReleasePropertiesPage } from './releasePropertiesPage';\n\nexport class ReleasePage extends WithPage {\n taskDrawer: TaskDrawer;\n properties: ReleasePropertiesPage;\n variables: ReleaseVariablesPage;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n this.properties = new ReleasePropertiesPage(page);\n this.variables = new ReleaseVariablesPage(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 waitForCompletion(timeout: number): Promise<void> {\n await this.page.locator('#release.completed').waitFor({ timeout });\n }\n\n async waitForTaskCompleted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.completed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForTaskFailed(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.failed').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForTaskSkipped(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.skipped').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForTaskAborted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.aborted').getByText(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n async waitForStatusLine(statusLine: string): Promise<void> {\n await expect(this.page.locator('.task .status-line').getByText(statusLine, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async waitForTaskStarted(taskTitle: string): Promise<void> {\n await expect(this.page.locator('.task.in_progress').getByTitle(taskTitle, { exact: true })).toBeVisible({\n timeout: 10000,\n });\n }\n\n async openTaskDrawer(taskName: string): Promise<TaskDrawer> {\n await this.page.locator('.task-header').getByText(taskName, { exact: true }).click();\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 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 return this.taskDrawer;\n }\n\n async openVariables(): Promise<void> {\n await this.openReleaseMenu('Variables');\n }\n\n async openProperties(): Promise<void> {\n await this.openReleaseMenu('Properties');\n }\n\n async openReleaseFlow(): Promise<void> {\n await this.openReleaseMenu('Release flow');\n }\n\n async openRelationships(): Promise<void> {\n await this.openReleaseMenu('Relationships');\n }\n\n async openTeamsPermissions(): Promise<void> {\n await this.openReleaseMenu('Teams & Permissions');\n }\n\n async openDashboard(): Promise<void> {\n await this.openReleaseMenu('Dashboard');\n }\n\n async openActivityLogs(): Promise<void> {\n await this.openReleaseMenu('ActivityLogs');\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 async backToRelease(): Promise<void> {\n await this.page.locator('.icon-back').click();\n }\n\n async openTableView(): Promise<void> {\n await this.page.locator('.xl-icon.table-icon').click();\n await expect(this.page.locator('.release-grid-container')).toBeVisible();\n }\n\n async openPlannerView(): Promise<void> {\n await this.page.locator('.xl-icon.planner-icon').click();\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\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').clear();\n await this.phaseLocator.locator('.phase-header input').fill(title);\n await this.phaseLocator.locator('.phase-header input').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 async addTaskInPhase(taskTitle: string, taskType: any): Promise<void> {\n await this.phaseLocator.getByText('Add task').click();\n await this.phaseLocator.getByPlaceholder('Task title...').click();\n await this.phaseLocator.getByPlaceholder('Task title...').fill(taskTitle);\n await this.phaseLocator.locator('.xlr-ctx-menu-toggle').click();\n const count = taskType.length - 1;\n for (let i = 0; i < count; i++) {\n await this.page\n .locator('[data-test=\"' + taskType[i] + '\"]')\n .getByText(taskType[i])\n .click();\n await this.page.getByText(taskType[i + 1]).click();\n }\n await this.phaseLocator.locator('.quick-controls-container a').getByText('Add', { exact: true }).click();\n await this.phaseLocator.locator('.button.cancel').click();\n await expect(this.phaseLocator.locator('.task').filter({ hasText: taskTitle })).toBeVisible({ timeout: 5_000 });\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 expectTemplateLabelNotToBePresent(): Promise<void> {\n await expect(this.page.locator('.dot-chip').filter({ hasText: 'TEMPLATE' })).not.toBeVisible();\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, 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.getByTestId('save-btn');\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.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","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { UserModal } from './userModal';\n\nexport class UsersPage extends WithPage {\n page: Page;\n modal: UserModal;\n constructor(page: Page) {\n super(page);\n this.page = page;\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 .click();\n await expect(this.page.getByRole('row', { name: '' + username + '' }).locator('.Mui-checked')).toBeChecked();\n }\n\n async addUser(): Promise<void> {\n await this.page.locator('.new-user-btn').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.getByRole('menuitem', { name: 'users icon Users and permissions' });\n this.managePluginMenu = this.page.getByRole('menuitem', { name: 'plugins icon Manage plugins' });\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 }\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 } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class ReleaseCalendarPage extends WithPage {\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('./#/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).toHaveTitle('Release calendar / Home - Digital.ai Release');\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 filterReleaseByTitle(title: string): Promise<void> {\n await this.page.getByPlaceholder('Filter by release title').click();\n await this.page.getByPlaceholder('Filter by release title').fill(title);\n await this.page.getByPlaceholder('Filter by release title').press('Enter');\n //Verify Page has correct Year format displayed at the page bottom\n await this.verifyPageContent(title);\n }\n\n async filterReleaseByTags(tags: string[], release_title: string): Promise<void> {\n await this.page.locator('.tl-filter-release-tags').locator('.react-tagsinput').click();\n for (let tag of tags) {\n tag = tag.toString();\n await this.page.locator('.tl-filter-release-tags').locator('.react-tagsinput-input').fill(tag);\n await this.page.getByTitle(tag).locator('i').click();\n }\n await this.verifyPageContent(release_title);\n }\n\n async filterTaskByTags(tags: string[], task_title: string, release_title: string): Promise<void> {\n await this.page.locator('.tl-filter-task-tags').locator('.react-tagsinput').click();\n for (let tag of tags) {\n tag = tag.toString();\n await this.page.locator('.tl-filter-task-tags').locator('.react-tagsinput-input').fill(tag);\n await this.page.getByTitle(tag).locator('i').click();\n }\n //Make sure task is visible on calnedar page\n await this.verifyPageContent(task_title);\n //Make sure parent release of the selected task is visible on calnedar page\n await this.verifyPageContent(release_title);\n }\n\n async filterReleaseByStatus(release_status: string, release_title: string): Promise<void> {\n if (!(await this.page.locator('.tl-filter-advanced').isVisible())) {\n await this.page.getByRole('button', { name: 'Advanced filters' }).click();\n }\n await this.page.locator('.tl-filter-release-status').locator('.react-tagsinput').click();\n await this.page.getByTitle(release_status).locator('i').first().click();\n await this.verifyPageContent(release_title);\n }\n\n async filterReleaseByRisk(release_risk: string, release_title: string): Promise<void> {\n if (!(await this.page.locator('.tl-filter-advanced').isVisible())) {\n await this.page.getByRole('button', { name: 'Advanced filters' }).click();\n }\n await this.page.locator('.tl-filter-risk-filter').getByRole('combobox').click();\n await this.page.getByRole('option', { name: release_risk }).click();\n await this.verifyPageContent(release_title);\n }\n\n async filterFlaggedRelease(release_title: string): Promise<void> {\n if (!(await this.page.locator('.tl-filter-advanced').isVisible())) {\n await this.page.getByRole('button', { name: 'Advanced filters' }).click();\n }\n if (\n await this.page.locator('.tl-filter-flag-only.btn.btn-flat.btn-fixed.button-toggle-filter.active').isVisible()\n ) {\n await this.page.getByRole('button', { name: ' Flagged' }).click();\n }\n await this.verifyPageContent(release_title);\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 this.page.getByText(release_title).click();\n await this.page.locator('.release-modal-container').locator('.xl-icon.release-icon').click();\n const releaseurl = `/#/releases/${release_id}`;\n const currentURL = await this.page.url();\n // Check if the release name present in redirected URL\n expect(currentURL).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","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport { TaskDrawer } from '../task-drawer/taskDrawer';\n\nexport class TaskListPage extends WithPage {\n taskDrawer: TaskDrawer;\n\n constructor(page: Page) {\n super(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).click();\n }\n\n async filterTaskByTitle(taskname: string): Promise<void> {\n await this.page.locator('.toggle-search-filter').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 })).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 expectTaskTitle(taskTitle: string): Promise<void> {\n expect(await this.page.locator('#tasks0').innerText()).toContain(taskTitle);\n }\n}\n","import * as fs from 'fs';\nimport path from 'path';\nimport { WithPage } from '../WithPage';\nimport { Page } from '@playwright/test';\n\nexport class TempFile extends WithPage {\n tempDir: string;\n content: string;\n\n constructor(page: Page) {\n super(page);\n this.tempDir = '';\n this.content = '';\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","import { Page, expect } from '@playwright/test';\nimport { WithPage } from '../WithPage';\nimport moment from 'moment';\n\nexport class TemplatePropertiesPage extends WithPage {\n constructor(page: Page) {\n super(page);\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: number, 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 + '' })\n .first()\n .click();\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...').click();\n await this.page.locator('span').filter({ hasText: 'Set description... * Save' }).locator('i').first().click();\n await this.page.locator('textarea').click();\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 constructor(page: Page) {\n super(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","import { Page, expect } 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';\n\nexport class TemplatePage extends WithPage {\n taskDrawer: TaskDrawer;\n properties: TemplatePropertiesPage;\n createTemplatePage: TemplateCreatePage;\n triggers: TemplateTriggerPage;\n\n constructor(page: Page) {\n super(page);\n this.taskDrawer = new TaskDrawer(page);\n this.properties = new TemplatePropertiesPage(page);\n this.createTemplatePage = new TemplateCreatePage(page);\n this.triggers = new TemplateTriggerPage(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 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 return this.taskDrawer;\n }\n\n async openProperties(): Promise<void> {\n await this.openTemplateMenu('Properties');\n }\n\n async openTriggers(): Promise<void> {\n await this.openTemplateMenu('Triggers');\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.locator('.dot-chip').filter({ hasText: '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.page.locator('.xl-icon.column-icon').click();\n await expect(this.page.locator('#release-content')).toBeVisible();\n }\n\n async openTableView(): Promise<void> {\n await this.page.locator('.xl-icon.table-icon').click();\n await expect(this.page.locator('.release-grid-container')).toBeVisible();\n }\n\n async openPlannerView(): Promise<void> {\n await this.page.locator('.xl-icon.planner-icon').click();\n await expect(this.page.locator('.gantt-container')).toBeVisible();\n }\n\n async openCodeView(): Promise<void> {\n await this.page.locator('.xl-icon.code-icon').click();\n await expect(this.page.locator('#dsl-content')).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","import { Page, expect } from '@playwright/test';\nimport { WithPage } from './WithPage';\n\nexport class TemplateListPage extends WithPage {\n constructor(page: Page) {\n super(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.locator('.dot-chip').filter({ hasText: 'TEMPLATE' })).toBeVisible();\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.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.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.getByTestId('dot-button').click();\n await this.page.getByRole('menuitem', { name: 'Create new template' }).click();\n }\n\n async openTemplateByName(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 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","import { Page, expect } 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';\nimport { ReleaseCalendarPage } from './ReleaseCalendarPage';\nimport { ReleasesListPage } from './ReleasesListPage';\nimport { TaskListPage } from './tasks/taskListPage';\nimport { TempFile } from './common/file';\nimport { TemplatePage } from './templates/templatePage';\nimport { TemplateListPage } from './templateListPage';\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 taskListPage: TaskListPage;\n templatePage: TemplatePage;\n templateListPage: TemplateListPage;\n releaseCalendarPage: ReleaseCalendarPage;\n releaseListPage: ReleasesListPage;\n util: TempFile;\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.taskListPage = new TaskListPage(page);\n this.templatePage = new TemplatePage(page);\n this.templateListPage = new TemplateListPage(page);\n this.taskDetailsPage = new TaskDetails(page);\n this.releaseCalendarPage = new ReleaseCalendarPage(page);\n this.releaseListPage = new ReleasesListPage(page);\n this.util = new TempFile(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.locator('ul.side-nav li').getByText('Folders', { exact: true }).click();\n }\n\n async gotoTaskPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Tasks', { exact: true }).click();\n }\n\n async gotoReleasePage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Releases', { exact: true }).click();\n }\n\n async gotoWorkflowCatalogPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Workflow catalog', { exact: true }).click();\n }\n\n async gotoWorkflowsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Workflows', { exact: true }).click();\n }\n\n async gotoGroupsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Groups', { exact: true }).click();\n }\n\n async gotoReleaseCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Release calendar', { exact: true }).click();\n }\n\n async gotoDeliveriesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Deliveries', { exact: true }).click();\n }\n\n async gotoTriggersPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Triggers', { exact: true }).click();\n }\n\n async gotoDigitalAnalyticsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Digital.ai Analytics', { exact: true }).click();\n }\n\n async gotoReportsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Reports', { exact: true }).click();\n }\n\n async gotoTemplatesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Templates', { exact: true }).click();\n }\n\n async gotoEnvironmentsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Environments', { exact: true }).click();\n }\n\n async gotoEnvironmentsCalenderPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Environments calendar', { exact: true }).click();\n }\n\n async gotoGobalVariablesPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Global variables', { exact: true }).click();\n }\n async gotoConnectionsPage(): Promise<void> {\n await this.page.locator('ul.side-nav li').getByText('Connections', { exact: true }).click();\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.locator('.dot-tooltip[aria-label=\"Collapse\"]').click();\n await expect(this.page.locator('.dot-tooltip[aria-label=\"Collapse\"]')).not.toBeVisible();\n }\n\n async expandSideView(): Promise<void> {\n await this.page.locator('.dot-tooltip[aria-label=\"Expand\"]').click();\n await expect(this.page.locator('.dot-tooltip[aria-label=\"Expand\"]')).not.toBeVisible();\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 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 }\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","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 flagStatus?: string;\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 tags?: Array<string>;\n teams: Array<Team>;\n variableValues?: VariableValues;\n variables: Array<Variable>;\n}\n\ntype VariableValues = Record<string, any>;\n// interface VariableValues {\n// [key: string]: any;\n// }\n\nexport interface Variable extends BaseConfigurationItem {\n key: string;\n requiresValue: boolean;\n showOnReleaseStart: boolean;\n value: string;\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 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<Team>;\n variables?: Array<Variable>;\n}\n\nexport interface Task extends PlanItem {\n attachments: Array<Attachment>;\n comments: Array<Comment>;\n conditions: Array<Condition>;\n dependencies: Array<Dependency>;\n description?: string;\n links: Array<Link>;\n owner?: string;\n precondition: string;\n pythonScript?: PythonScript;\n script: string;\n status: TaskStatus;\n tags?: Array<string>;\n tasks: Array<Task>;\n templateVariables: Array<Variable>;\n}\n\ntype Condition = 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\n//type Team = BaseConfigurationItem;\n\nexport interface Team extends PlanItem {\n members: Array<string>;\n permissions: Array<string>;\n teamName: 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 apiToken?: string;\n password?: 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 message: string;\n username: 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/login-page';\nimport { initReleaseDefaults } from './helper';\nimport * as process from 'process';\nimport {\n FixtureActivityLog,\n FixtureConfiguration,\n FixtureFeature,\n FixtureRelease,\n FixtureTrigger,\n Folder,\n Release,\n Variable,\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 archivedReleaseIds: Array<string> = [];\n private releaseIds: 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\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 getParentId(id: string): string {\n return id.substring(0, id.lastIndexOf('/'));\n }\n\n async folder(folder: Folder): Promise<APIResponse> {\n const parentId = this.getParentId(folder.id);\n folder.type = 'xlrelease.Folder';\n\n //ToDo: Add system teams\n const teams = folder.teams;\n delete folder.teams;\n //ToDo: Add Children\n /* eslint-disable @typescript-eslint/no-unused-vars */\n const children = folder.children || [];\n delete folder.children;\n\n if (teams) return this.doPost(`api/v1/folders/${folder.id}/teams`, teams);\n\n return this.doPost(`api/v1/folders/${parentId}`, folder);\n }\n\n createFolder(folderJson: Folder): Promise<APIResponse> {\n folderJson.type = 'xlrelease.Folder';\n return this.doPost(`fixtures/folders`, [folderJson]);\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 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 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 const id = this.doGet(`api/v1/folders/${folderId}`);\n return this.doDelete(`api/v1/folders/${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 async cleanAll(): Promise<void> {\n for (const username of this.usernames) {\n await this.deleteUser(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 this.folderIds = [];\n this.releaseIds = [];\n this.triggerIds = [];\n this.configurationIds = [];\n this.usernames = [];\n this.userProfiles = [];\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 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 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 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.13",
3
+ "version": "0.0.14",
4
4
  "source": "index.ts",
5
5
  "main": "dist/main.js",
6
6
  "module": "dist/module.js",
@@ -13,7 +13,8 @@
13
13
  },
14
14
  "description": "This is a collection of page objects for Playwright that can be used to automate actions on Digital.ai Release",
15
15
  "dependencies": {
16
- "lodash": "4.17.21"
16
+ "lodash": "4.17.21",
17
+ "moment": "2.29.4"
17
18
  },
18
19
  "devDependencies": {
19
20
  "@parcel/packager-ts": "2.8.3",