From 18a0a85b6d2b3fbe4a659445629acc9549898e4d Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 13 Dec 2024 23:29:10 +0530 Subject: [PATCH 01/14] [Test automation] Verify Topology is a supported plugin and E2E scenario follow-up --- .../topology_test/topology-test.yaml | 88 +++++++++++++++++++ .ibm/pipelines/utils.sh | 3 + .../e2e/plugins/topology/topology.spec.ts | 41 ++++++--- e2e-tests/playwright/utils/ui-helper.ts | 36 ++++++-- 4 files changed, 153 insertions(+), 15 deletions(-) create mode 100644 .ibm/pipelines/resources/topology_test/topology-test.yaml diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml new file mode 100644 index 0000000000..cab688c2ac --- /dev/null +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -0,0 +1,88 @@ +--- +apiVersion: tekton.dev/v1beta1 +kind: Pipeline +metadata: + name: topology-test + namespace: rhdh + labels: + app.kubernetes.io/instance: topology-test + app.kubernetes.io/name: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + tasks: + - name: deploy + taskRef: + kind: ClusterTask + name: openshift-client +--- +apiVersion: tekton.dev/v1beta1 +kind: PipelineRun +metadata: + name: topology-test-run + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + pipelineRef: + name: topology-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: topology-test + namespace: rhdh + labels: + app.kubernetes.io/instance: topology-test + app.kubernetes.io/name: topology-test + backstage.io/kubernetes-id: developer-hub + annotations: + app.openshift.io/vcs-uri: "https://github.com/janus-idp/backstage-showcase" +spec: + replicas: 1 + selector: + matchLabels: + app: topology-test + template: + metadata: + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub + spec: + containers: + - name: topology + image: nginxinc/nginx-unprivileged:stable-alpine + ports: + - containerPort: 8080 +--- +apiVersion: v1 +kind: Service +metadata: + name: topology-test-service + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + selector: + app: topology-test + ports: + - protocol: TCP + port: 8080 + targetPort: 8080 +--- +apiVersion: route.openshift.io/v1 +kind: Route +metadata: + name: topology-test-route + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + to: + kind: Service + name: topology-test-service + port: + targetPort: 8080 + wildcardPolicy: None \ No newline at end of file diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index cae0016cc9..7fc47c8fdd 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -449,6 +449,9 @@ apply_yaml_files() { oc apply -f "$dir/resources/pipeline-run/hello-world-pipeline.yaml" oc apply -f "$dir/resources/pipeline-run/hello-world-pipeline-run.yaml" + # Create Deployment and Pipeline for Topology test. + oc apply -f "$dir/resources/topology_test/topology-test.yaml" + } deploy_test_backstage_provider() { diff --git a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts index b29ffd22ff..57b301a7b0 100644 --- a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts +++ b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts @@ -3,8 +3,7 @@ import { Common } from "../../../utils/common"; import { UIhelper } from "../../../utils/ui-helper"; import { Catalog } from "../../../support/pages/catalog"; -// Test disabled due to comments in JIRA ticket RHIDP-3437 -test.describe.skip("Test Topology Plugin", () => { +test.describe("Test Topology Plugin", () => { let common: Common; let uiHelper: UIhelper; let catalog: Catalog; @@ -17,18 +16,17 @@ test.describe.skip("Test Topology Plugin", () => { }); test("Verify pods visibility in the Topology tab", async ({ page }) => { - test.setTimeout(40000); await catalog.goToBackstageJanusProject(); await uiHelper.clickTab("Topology"); await uiHelper.verifyText("backstage-janus"); await page.getByRole("button", { name: "Fit to Screen" }).click(); await uiHelper.verifyText("rhdh"); await uiHelper.verifyText("rhdh-rbac"); - await uiHelper.verifyButtonURL( - "Open URL", - "https://rhdh-backstage-showcase", - ); - await page.locator("image").first().click(); + await uiHelper.verifyText("topology-test"); + await uiHelper.verifyButtonURL("Open URL", "topology-test-route", { + locator: `[data-test-id="topology-test"]`, + }); + await page.locator("[data-test-id=topology-test] image").first().click(); await page.getByLabel("Pod").click(); await page.getByLabel("Pod").getByText("1", { exact: true }).click(); await uiHelper.clickTab("Details"); @@ -39,7 +37,7 @@ test.describe.skip("Test Topology Plugin", () => { await uiHelper.verifyHeading("Services"); await uiHelper.verifyHeading("Routes"); await expect( - page.getByRole("link", { name: "https://rhdh-backstage-" }), + page.getByRole("link", { name: "topology-test-route" }), ).toBeVisible(); await expect(page.getByTitle("Deployment")).toBeVisible(); await uiHelper.verifyText("S"); @@ -51,6 +49,29 @@ test.describe.skip("Test Topology Plugin", () => { await page.getByLabel("Pod count").click(); await uiHelper.verifyText("1"); await uiHelper.verifyText("Pod"); - await page.getByLabel("Pod count").click(); + await uiHelper.hoverOnPodStatusIndicator(); + await uiHelper.verifyTextInTooltip("Running"); + await uiHelper.verifyText("1Running"); + await uiHelper.verifyButtonURL( + "Edit source code", + "https://github.com/janus-idp/backstage-showcase", + ); + await uiHelper.clickTab("Resources"); + await uiHelper.verifyText("P"); + expect(await page.getByTestId("icon-with-title-Running")).toBeVisible(); + expect( + await page.getByTestId("icon-with-title-Running").locator("svg"), + ).toBeVisible(); + expect( + await page + .getByTestId("icon-with-title-Running") + .getByTestId("status-text"), + ).toHaveText("Running"); + await uiHelper.verifyHeading("PipelineRuns"); + await uiHelper.verifyText("PL"); + await uiHelper.verifyText("PLR"); + await page.getByTestId("icon-only-Succeeded").hover(); + await uiHelper.verifyDivHasText("Pipeline SucceededTask"); + await uiHelper.verifyText("1 Succeeded"); }); }); diff --git a/e2e-tests/playwright/utils/ui-helper.ts b/e2e-tests/playwright/utils/ui-helper.ts index 9d2f5167f2..958f8779a4 100644 --- a/e2e-tests/playwright/utils/ui-helper.ts +++ b/e2e-tests/playwright/utils/ui-helper.ts @@ -298,13 +298,27 @@ export class UIhelper { }); } - async verifyButtonURL(label: string | RegExp, url: string | RegExp) { - const buttonUrl = await this.page - .getByRole("button", { name: label }) - .first() - .getAttribute("href"); + async verifyButtonURL( + label: string | RegExp, + url: string | RegExp, + options: { locator?: string } = { + locator: "", + }, + ) { + const buttonUrl = + options.locator == "" + ? await this.page + .getByRole("button", { name: label }) + .first() + .getAttribute("href") + : await this.page + .locator(options.locator) + .getByRole("button", { name: label }) + .first() + .getAttribute("href"); expect(buttonUrl).toContain(url); } + // locator('[data-test-id="topology-test"]').getByRole('button', { name: 'Open URL' }) /** * Verifies that a table row, identified by unique text, contains specific cell texts. @@ -539,4 +553,16 @@ export class UIhelper { await expect(enabledColumn).toHaveText(expectedEnabled); await expect(preinstalledColumn).toHaveText(expectedPreinstalled); } + + async hoverOnPodStatusIndicator() { + await this.page + .locator('[data-test-id="topology-test"]') + .getByText("Pod") + .hover({}); + } + + async verifyTextInTooltip(text: string | RegExp) { + const tooltip = await this.page.getByRole("tooltip").getByText(text); + expect(tooltip).toBeVisible(); + } } From a759ab890412bdbeb77d39c3d1f964ae2cd28ac4 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Sun, 15 Dec 2024 18:48:25 +0530 Subject: [PATCH 02/14] Namespace removed --- .ibm/pipelines/resources/topology_test/topology-test.yaml | 5 ----- 1 file changed, 5 deletions(-) diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml index cab688c2ac..d30e9b9f24 100644 --- a/.ibm/pipelines/resources/topology_test/topology-test.yaml +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -3,7 +3,6 @@ apiVersion: tekton.dev/v1beta1 kind: Pipeline metadata: name: topology-test - namespace: rhdh labels: app.kubernetes.io/instance: topology-test app.kubernetes.io/name: topology-test @@ -19,7 +18,6 @@ apiVersion: tekton.dev/v1beta1 kind: PipelineRun metadata: name: topology-test-run - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub @@ -31,7 +29,6 @@ apiVersion: apps/v1 kind: Deployment metadata: name: topology-test - namespace: rhdh labels: app.kubernetes.io/instance: topology-test app.kubernetes.io/name: topology-test @@ -59,7 +56,6 @@ apiVersion: v1 kind: Service metadata: name: topology-test-service - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub @@ -75,7 +71,6 @@ apiVersion: route.openshift.io/v1 kind: Route metadata: name: topology-test-route - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub From d8411a2519985e3c00558915b4eb3ee591b01614 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 13 Dec 2024 23:29:10 +0530 Subject: [PATCH 03/14] [Test automation] Verify Topology is a supported plugin and E2E scenario follow-up --- .../topology_test/topology-test.yaml | 88 +++++++++++++++++++ .ibm/pipelines/utils.sh | 3 + .../e2e/plugins/topology/topology.spec.ts | 41 ++++++--- e2e-tests/playwright/utils/ui-helper.ts | 36 ++++++-- 4 files changed, 153 insertions(+), 15 deletions(-) create mode 100644 .ibm/pipelines/resources/topology_test/topology-test.yaml diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml new file mode 100644 index 0000000000..cab688c2ac --- /dev/null +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -0,0 +1,88 @@ +--- +apiVersion: tekton.dev/v1beta1 +kind: Pipeline +metadata: + name: topology-test + namespace: rhdh + labels: + app.kubernetes.io/instance: topology-test + app.kubernetes.io/name: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + tasks: + - name: deploy + taskRef: + kind: ClusterTask + name: openshift-client +--- +apiVersion: tekton.dev/v1beta1 +kind: PipelineRun +metadata: + name: topology-test-run + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + pipelineRef: + name: topology-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: topology-test + namespace: rhdh + labels: + app.kubernetes.io/instance: topology-test + app.kubernetes.io/name: topology-test + backstage.io/kubernetes-id: developer-hub + annotations: + app.openshift.io/vcs-uri: "https://github.com/janus-idp/backstage-showcase" +spec: + replicas: 1 + selector: + matchLabels: + app: topology-test + template: + metadata: + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub + spec: + containers: + - name: topology + image: nginxinc/nginx-unprivileged:stable-alpine + ports: + - containerPort: 8080 +--- +apiVersion: v1 +kind: Service +metadata: + name: topology-test-service + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + selector: + app: topology-test + ports: + - protocol: TCP + port: 8080 + targetPort: 8080 +--- +apiVersion: route.openshift.io/v1 +kind: Route +metadata: + name: topology-test-route + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + to: + kind: Service + name: topology-test-service + port: + targetPort: 8080 + wildcardPolicy: None \ No newline at end of file diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index 23117fbbe9..4c71aebe03 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -449,6 +449,9 @@ apply_yaml_files() { oc apply -f "$dir/resources/pipeline-run/hello-world-pipeline.yaml" oc apply -f "$dir/resources/pipeline-run/hello-world-pipeline-run.yaml" + # Create Deployment and Pipeline for Topology test. + oc apply -f "$dir/resources/topology_test/topology-test.yaml" + } deploy_test_backstage_provider() { diff --git a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts index b29ffd22ff..57b301a7b0 100644 --- a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts +++ b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts @@ -3,8 +3,7 @@ import { Common } from "../../../utils/common"; import { UIhelper } from "../../../utils/ui-helper"; import { Catalog } from "../../../support/pages/catalog"; -// Test disabled due to comments in JIRA ticket RHIDP-3437 -test.describe.skip("Test Topology Plugin", () => { +test.describe("Test Topology Plugin", () => { let common: Common; let uiHelper: UIhelper; let catalog: Catalog; @@ -17,18 +16,17 @@ test.describe.skip("Test Topology Plugin", () => { }); test("Verify pods visibility in the Topology tab", async ({ page }) => { - test.setTimeout(40000); await catalog.goToBackstageJanusProject(); await uiHelper.clickTab("Topology"); await uiHelper.verifyText("backstage-janus"); await page.getByRole("button", { name: "Fit to Screen" }).click(); await uiHelper.verifyText("rhdh"); await uiHelper.verifyText("rhdh-rbac"); - await uiHelper.verifyButtonURL( - "Open URL", - "https://rhdh-backstage-showcase", - ); - await page.locator("image").first().click(); + await uiHelper.verifyText("topology-test"); + await uiHelper.verifyButtonURL("Open URL", "topology-test-route", { + locator: `[data-test-id="topology-test"]`, + }); + await page.locator("[data-test-id=topology-test] image").first().click(); await page.getByLabel("Pod").click(); await page.getByLabel("Pod").getByText("1", { exact: true }).click(); await uiHelper.clickTab("Details"); @@ -39,7 +37,7 @@ test.describe.skip("Test Topology Plugin", () => { await uiHelper.verifyHeading("Services"); await uiHelper.verifyHeading("Routes"); await expect( - page.getByRole("link", { name: "https://rhdh-backstage-" }), + page.getByRole("link", { name: "topology-test-route" }), ).toBeVisible(); await expect(page.getByTitle("Deployment")).toBeVisible(); await uiHelper.verifyText("S"); @@ -51,6 +49,29 @@ test.describe.skip("Test Topology Plugin", () => { await page.getByLabel("Pod count").click(); await uiHelper.verifyText("1"); await uiHelper.verifyText("Pod"); - await page.getByLabel("Pod count").click(); + await uiHelper.hoverOnPodStatusIndicator(); + await uiHelper.verifyTextInTooltip("Running"); + await uiHelper.verifyText("1Running"); + await uiHelper.verifyButtonURL( + "Edit source code", + "https://github.com/janus-idp/backstage-showcase", + ); + await uiHelper.clickTab("Resources"); + await uiHelper.verifyText("P"); + expect(await page.getByTestId("icon-with-title-Running")).toBeVisible(); + expect( + await page.getByTestId("icon-with-title-Running").locator("svg"), + ).toBeVisible(); + expect( + await page + .getByTestId("icon-with-title-Running") + .getByTestId("status-text"), + ).toHaveText("Running"); + await uiHelper.verifyHeading("PipelineRuns"); + await uiHelper.verifyText("PL"); + await uiHelper.verifyText("PLR"); + await page.getByTestId("icon-only-Succeeded").hover(); + await uiHelper.verifyDivHasText("Pipeline SucceededTask"); + await uiHelper.verifyText("1 Succeeded"); }); }); diff --git a/e2e-tests/playwright/utils/ui-helper.ts b/e2e-tests/playwright/utils/ui-helper.ts index 9d2f5167f2..958f8779a4 100644 --- a/e2e-tests/playwright/utils/ui-helper.ts +++ b/e2e-tests/playwright/utils/ui-helper.ts @@ -298,13 +298,27 @@ export class UIhelper { }); } - async verifyButtonURL(label: string | RegExp, url: string | RegExp) { - const buttonUrl = await this.page - .getByRole("button", { name: label }) - .first() - .getAttribute("href"); + async verifyButtonURL( + label: string | RegExp, + url: string | RegExp, + options: { locator?: string } = { + locator: "", + }, + ) { + const buttonUrl = + options.locator == "" + ? await this.page + .getByRole("button", { name: label }) + .first() + .getAttribute("href") + : await this.page + .locator(options.locator) + .getByRole("button", { name: label }) + .first() + .getAttribute("href"); expect(buttonUrl).toContain(url); } + // locator('[data-test-id="topology-test"]').getByRole('button', { name: 'Open URL' }) /** * Verifies that a table row, identified by unique text, contains specific cell texts. @@ -539,4 +553,16 @@ export class UIhelper { await expect(enabledColumn).toHaveText(expectedEnabled); await expect(preinstalledColumn).toHaveText(expectedPreinstalled); } + + async hoverOnPodStatusIndicator() { + await this.page + .locator('[data-test-id="topology-test"]') + .getByText("Pod") + .hover({}); + } + + async verifyTextInTooltip(text: string | RegExp) { + const tooltip = await this.page.getByRole("tooltip").getByText(text); + expect(tooltip).toBeVisible(); + } } From 58906fd5a8d066e014b4ee62f2e42737fd0dd6f8 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Sun, 15 Dec 2024 18:48:25 +0530 Subject: [PATCH 04/14] Namespace removed --- .ibm/pipelines/resources/topology_test/topology-test.yaml | 5 ----- 1 file changed, 5 deletions(-) diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml index cab688c2ac..d30e9b9f24 100644 --- a/.ibm/pipelines/resources/topology_test/topology-test.yaml +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -3,7 +3,6 @@ apiVersion: tekton.dev/v1beta1 kind: Pipeline metadata: name: topology-test - namespace: rhdh labels: app.kubernetes.io/instance: topology-test app.kubernetes.io/name: topology-test @@ -19,7 +18,6 @@ apiVersion: tekton.dev/v1beta1 kind: PipelineRun metadata: name: topology-test-run - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub @@ -31,7 +29,6 @@ apiVersion: apps/v1 kind: Deployment metadata: name: topology-test - namespace: rhdh labels: app.kubernetes.io/instance: topology-test app.kubernetes.io/name: topology-test @@ -59,7 +56,6 @@ apiVersion: v1 kind: Service metadata: name: topology-test-service - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub @@ -75,7 +71,6 @@ apiVersion: route.openshift.io/v1 kind: Route metadata: name: topology-test-route - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub From 2a9bba4559812c0250034fe6370eb126a1a72548 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 13 Dec 2024 23:29:10 +0530 Subject: [PATCH 05/14] [Test automation] Verify Topology is a supported plugin and E2E scenario follow-up --- .../topology_test/topology-test.yaml | 88 +++++++++++++++++++ .ibm/pipelines/utils.sh | 3 + .../e2e/plugins/topology/topology.spec.ts | 41 ++++++--- e2e-tests/playwright/utils/ui-helper.ts | 36 ++++++-- 4 files changed, 153 insertions(+), 15 deletions(-) create mode 100644 .ibm/pipelines/resources/topology_test/topology-test.yaml diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml new file mode 100644 index 0000000000..cab688c2ac --- /dev/null +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -0,0 +1,88 @@ +--- +apiVersion: tekton.dev/v1beta1 +kind: Pipeline +metadata: + name: topology-test + namespace: rhdh + labels: + app.kubernetes.io/instance: topology-test + app.kubernetes.io/name: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + tasks: + - name: deploy + taskRef: + kind: ClusterTask + name: openshift-client +--- +apiVersion: tekton.dev/v1beta1 +kind: PipelineRun +metadata: + name: topology-test-run + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + pipelineRef: + name: topology-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: topology-test + namespace: rhdh + labels: + app.kubernetes.io/instance: topology-test + app.kubernetes.io/name: topology-test + backstage.io/kubernetes-id: developer-hub + annotations: + app.openshift.io/vcs-uri: "https://github.com/janus-idp/backstage-showcase" +spec: + replicas: 1 + selector: + matchLabels: + app: topology-test + template: + metadata: + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub + spec: + containers: + - name: topology + image: nginxinc/nginx-unprivileged:stable-alpine + ports: + - containerPort: 8080 +--- +apiVersion: v1 +kind: Service +metadata: + name: topology-test-service + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + selector: + app: topology-test + ports: + - protocol: TCP + port: 8080 + targetPort: 8080 +--- +apiVersion: route.openshift.io/v1 +kind: Route +metadata: + name: topology-test-route + namespace: rhdh + labels: + app: topology-test + backstage.io/kubernetes-id: developer-hub +spec: + to: + kind: Service + name: topology-test-service + port: + targetPort: 8080 + wildcardPolicy: None \ No newline at end of file diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index 1d236b4a80..95885c7d70 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -450,6 +450,9 @@ apply_yaml_files() { oc apply -f "$dir/resources/pipeline-run/hello-world-pipeline.yaml" oc apply -f "$dir/resources/pipeline-run/hello-world-pipeline-run.yaml" + # Create Deployment and Pipeline for Topology test. + oc apply -f "$dir/resources/topology_test/topology-test.yaml" + } deploy_test_backstage_provider() { diff --git a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts index b29ffd22ff..57b301a7b0 100644 --- a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts +++ b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts @@ -3,8 +3,7 @@ import { Common } from "../../../utils/common"; import { UIhelper } from "../../../utils/ui-helper"; import { Catalog } from "../../../support/pages/catalog"; -// Test disabled due to comments in JIRA ticket RHIDP-3437 -test.describe.skip("Test Topology Plugin", () => { +test.describe("Test Topology Plugin", () => { let common: Common; let uiHelper: UIhelper; let catalog: Catalog; @@ -17,18 +16,17 @@ test.describe.skip("Test Topology Plugin", () => { }); test("Verify pods visibility in the Topology tab", async ({ page }) => { - test.setTimeout(40000); await catalog.goToBackstageJanusProject(); await uiHelper.clickTab("Topology"); await uiHelper.verifyText("backstage-janus"); await page.getByRole("button", { name: "Fit to Screen" }).click(); await uiHelper.verifyText("rhdh"); await uiHelper.verifyText("rhdh-rbac"); - await uiHelper.verifyButtonURL( - "Open URL", - "https://rhdh-backstage-showcase", - ); - await page.locator("image").first().click(); + await uiHelper.verifyText("topology-test"); + await uiHelper.verifyButtonURL("Open URL", "topology-test-route", { + locator: `[data-test-id="topology-test"]`, + }); + await page.locator("[data-test-id=topology-test] image").first().click(); await page.getByLabel("Pod").click(); await page.getByLabel("Pod").getByText("1", { exact: true }).click(); await uiHelper.clickTab("Details"); @@ -39,7 +37,7 @@ test.describe.skip("Test Topology Plugin", () => { await uiHelper.verifyHeading("Services"); await uiHelper.verifyHeading("Routes"); await expect( - page.getByRole("link", { name: "https://rhdh-backstage-" }), + page.getByRole("link", { name: "topology-test-route" }), ).toBeVisible(); await expect(page.getByTitle("Deployment")).toBeVisible(); await uiHelper.verifyText("S"); @@ -51,6 +49,29 @@ test.describe.skip("Test Topology Plugin", () => { await page.getByLabel("Pod count").click(); await uiHelper.verifyText("1"); await uiHelper.verifyText("Pod"); - await page.getByLabel("Pod count").click(); + await uiHelper.hoverOnPodStatusIndicator(); + await uiHelper.verifyTextInTooltip("Running"); + await uiHelper.verifyText("1Running"); + await uiHelper.verifyButtonURL( + "Edit source code", + "https://github.com/janus-idp/backstage-showcase", + ); + await uiHelper.clickTab("Resources"); + await uiHelper.verifyText("P"); + expect(await page.getByTestId("icon-with-title-Running")).toBeVisible(); + expect( + await page.getByTestId("icon-with-title-Running").locator("svg"), + ).toBeVisible(); + expect( + await page + .getByTestId("icon-with-title-Running") + .getByTestId("status-text"), + ).toHaveText("Running"); + await uiHelper.verifyHeading("PipelineRuns"); + await uiHelper.verifyText("PL"); + await uiHelper.verifyText("PLR"); + await page.getByTestId("icon-only-Succeeded").hover(); + await uiHelper.verifyDivHasText("Pipeline SucceededTask"); + await uiHelper.verifyText("1 Succeeded"); }); }); diff --git a/e2e-tests/playwright/utils/ui-helper.ts b/e2e-tests/playwright/utils/ui-helper.ts index 9f82004c11..a54f99f354 100644 --- a/e2e-tests/playwright/utils/ui-helper.ts +++ b/e2e-tests/playwright/utils/ui-helper.ts @@ -353,13 +353,27 @@ export class UIhelper { }); } - async verifyButtonURL(label: string | RegExp, url: string | RegExp) { - const buttonUrl = await this.page - .getByRole("button", { name: label }) - .first() - .getAttribute("href"); + async verifyButtonURL( + label: string | RegExp, + url: string | RegExp, + options: { locator?: string } = { + locator: "", + }, + ) { + const buttonUrl = + options.locator == "" + ? await this.page + .getByRole("button", { name: label }) + .first() + .getAttribute("href") + : await this.page + .locator(options.locator) + .getByRole("button", { name: label }) + .first() + .getAttribute("href"); expect(buttonUrl).toContain(url); } + // locator('[data-test-id="topology-test"]').getByRole('button', { name: 'Open URL' }) /** * Verifies that a table row, identified by unique text, contains specific cell texts. @@ -594,4 +608,16 @@ export class UIhelper { await expect(enabledColumn).toHaveText(expectedEnabled); await expect(preinstalledColumn).toHaveText(expectedPreinstalled); } + + async hoverOnPodStatusIndicator() { + await this.page + .locator('[data-test-id="topology-test"]') + .getByText("Pod") + .hover({}); + } + + async verifyTextInTooltip(text: string | RegExp) { + const tooltip = await this.page.getByRole("tooltip").getByText(text); + expect(tooltip).toBeVisible(); + } } From fa269714c22fd9a5637833634a03971fcb01cf65 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Sun, 15 Dec 2024 18:48:25 +0530 Subject: [PATCH 06/14] Namespace removed --- .ibm/pipelines/resources/topology_test/topology-test.yaml | 5 ----- 1 file changed, 5 deletions(-) diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml index cab688c2ac..d30e9b9f24 100644 --- a/.ibm/pipelines/resources/topology_test/topology-test.yaml +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -3,7 +3,6 @@ apiVersion: tekton.dev/v1beta1 kind: Pipeline metadata: name: topology-test - namespace: rhdh labels: app.kubernetes.io/instance: topology-test app.kubernetes.io/name: topology-test @@ -19,7 +18,6 @@ apiVersion: tekton.dev/v1beta1 kind: PipelineRun metadata: name: topology-test-run - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub @@ -31,7 +29,6 @@ apiVersion: apps/v1 kind: Deployment metadata: name: topology-test - namespace: rhdh labels: app.kubernetes.io/instance: topology-test app.kubernetes.io/name: topology-test @@ -59,7 +56,6 @@ apiVersion: v1 kind: Service metadata: name: topology-test-service - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub @@ -75,7 +71,6 @@ apiVersion: route.openshift.io/v1 kind: Route metadata: name: topology-test-route - namespace: rhdh labels: app: topology-test backstage.io/kubernetes-id: developer-hub From 7f84c2a108efb5fbe183b7b8ab898387948f69af Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Thu, 16 Jan 2025 11:46:08 +0530 Subject: [PATCH 07/14] Sleep test --- .ibm/pipelines/openshift-ci-tests.sh | 1 + .ibm/pipelines/utils.sh | 19 ++++++++----------- 2 files changed, 9 insertions(+), 11 deletions(-) diff --git a/.ibm/pipelines/openshift-ci-tests.sh b/.ibm/pipelines/openshift-ci-tests.sh index ca8610ccb4..f878db5e29 100755 --- a/.ibm/pipelines/openshift-ci-tests.sh +++ b/.ibm/pipelines/openshift-ci-tests.sh @@ -65,6 +65,7 @@ main() { esac echo "Main script completed with result: ${OVERALL_RESULT}" +sleep 60*60 exit "${OVERALL_RESULT}" } diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index 5a382d96e6..ad8a4951f8 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -60,7 +60,7 @@ droute_send() { ARTIFACTS_URL="https://gcsweb-ci.apps.ci.l2s4.p1.openshiftapps.com/gcs/test-platform-results/pr-logs/pull/${REPO_OWNER}_${REPO_NAME}/${PULL_NUMBER}/${JOB_NAME}/${BUILD_ID}/artifacts/e2e-tests/${REPO_OWNER}-${REPO_NAME}/artifacts/${project}" else JOB_URL="${JOB_BASE_URL}/logs/${JOB_NAME}/${BUILD_ID}" - ARTIFACTS_URL="https://gcsweb-ci.apps.ci.l2s4.p1.openshiftapps.com/gcs/test-platform-results/logs/${JOB_NAME}/${BUILD_ID}/artifacts/${JOB_NAME##periodic-ci-redhat-developer-rhdh-main-}/${REPO_OWNER}-${REPO_NAME}/artifacts/${project}" + ARTIFACTS_URL="https://gcsweb-ci.apps.ci.l2s4.p1.openshiftapps.com/gcs/test-platform-results/logs/${JOB_NAME}/${BUILD_ID}/artifacts/${JOB_NAME##periodic-ci-janus-idp-backstage-showcase-main-}/${REPO_OWNER}-${REPO_NAME}/artifacts/${project}" fi # Remove properties (only used for skipped test and invalidates the file if empty) @@ -543,9 +543,6 @@ run_tests() { local project=$2 project=${project} cd "${DIR}/../../e2e-tests" - local e2e_tests_dir - e2e_tests_dir=$(pwd) - yarn install yarn playwright install chromium @@ -564,20 +561,20 @@ run_tests() { mkdir -p "${ARTIFACT_DIR}/${project}/test-results" mkdir -p "${ARTIFACT_DIR}/${project}/attachments/screenshots" - cp -a "${e2e_tests_dir}/test-results/"* "${ARTIFACT_DIR}/${project}/test-results" - cp -a "${e2e_tests_dir}/${JUNIT_RESULTS}" "${ARTIFACT_DIR}/${project}/${JUNIT_RESULTS}" + cp -a /tmp/backstage-showcase/e2e-tests/test-results/* "${ARTIFACT_DIR}/${project}/test-results" + cp -a /tmp/backstage-showcase/e2e-tests/${JUNIT_RESULTS} "${ARTIFACT_DIR}/${project}/${JUNIT_RESULTS}" - if [ -d "${e2e_tests_dir}/screenshots" ]; then - cp -a "${e2e_tests_dir}/screenshots/"* "${ARTIFACT_DIR}/${project}/attachments/screenshots/" + if [ -d "/tmp/backstage-showcase/e2e-tests/screenshots" ]; then + cp -a /tmp/backstage-showcase/e2e-tests/screenshots/* "${ARTIFACT_DIR}/${project}/attachments/screenshots/" fi - if [ -d "${e2e_tests_dir}/auth-providers-logs" ]; then - cp -a "${e2e_tests_dir}/auth-providers-logs/"* "${ARTIFACT_DIR}/${project}/" + if [ -d "/tmp/backstage-showcase/e2e-tests/auth-providers-logs" ]; then + cp -a /tmp/backstage-showcase/e2e-tests/auth-providers-logs/* "${ARTIFACT_DIR}/${project}/" fi ansi2html <"/tmp/${LOGFILE}" >"/tmp/${LOGFILE}.html" cp -a "/tmp/${LOGFILE}.html" "${ARTIFACT_DIR}/${project}" - cp -a "${e2e_tests_dir}/playwright-report/"* "${ARTIFACT_DIR}/${project}" + cp -a /tmp/backstage-showcase/e2e-tests/playwright-report/* "${ARTIFACT_DIR}/${project}" droute_send "${release_name}" "${project}" From 05eadf8a1f9e4307fe000bb825e2ccae9b4b88ff Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 13:06:25 +0530 Subject: [PATCH 08/14] TLS issue --- .ibm/pipelines/openshift-ci-tests.sh | 1 - .ibm/pipelines/value_files/values_showcase.yaml | 2 ++ 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/.ibm/pipelines/openshift-ci-tests.sh b/.ibm/pipelines/openshift-ci-tests.sh index f878db5e29..ca8610ccb4 100755 --- a/.ibm/pipelines/openshift-ci-tests.sh +++ b/.ibm/pipelines/openshift-ci-tests.sh @@ -65,7 +65,6 @@ main() { esac echo "Main script completed with result: ${OVERALL_RESULT}" -sleep 60*60 exit "${OVERALL_RESULT}" } diff --git a/.ibm/pipelines/value_files/values_showcase.yaml b/.ibm/pipelines/value_files/values_showcase.yaml index c07fa4dca0..eb9d45a4a1 100644 --- a/.ibm/pipelines/value_files/values_showcase.yaml +++ b/.ibm/pipelines/value_files/values_showcase.yaml @@ -145,6 +145,8 @@ upstream: value: 'true' - name: NODE_OPTIONS value: '--no-node-snapshot' + - name: NODE_TLS_REJECT_UNAUTHORIZED + value: '0' extraAppConfig: - configMapRef: app-config-rhdh filename: app-config-rhdh.yaml From f4c1164ba4b25480e3cd1072053ee5e0e8dedca5 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 14:27:34 +0530 Subject: [PATCH 09/14] pipeline config change --- .../resources/topology_test/topology-test.yaml | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/.ibm/pipelines/resources/topology_test/topology-test.yaml b/.ibm/pipelines/resources/topology_test/topology-test.yaml index d30e9b9f24..95f978c42d 100644 --- a/.ibm/pipelines/resources/topology_test/topology-test.yaml +++ b/.ibm/pipelines/resources/topology_test/topology-test.yaml @@ -10,9 +10,13 @@ metadata: spec: tasks: - name: deploy - taskRef: - kind: ClusterTask - name: openshift-client + taskSpec: + steps: + - name: oc + image: 'quay.io/openshift/origin-cli:latest' + script: | + #!/bin/sh + oc "$@" --- apiVersion: tekton.dev/v1beta1 kind: PipelineRun From bb9e27eca4cb59ccc028a315698431d1e11569e7 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 14:47:29 +0530 Subject: [PATCH 10/14] cleanup --- .ibm/pipelines/utils.sh | 16 ++++++++-------- e2e-tests/playwright/utils/ui-helper.ts | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index ad8a4951f8..95ae216e14 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -60,7 +60,7 @@ droute_send() { ARTIFACTS_URL="https://gcsweb-ci.apps.ci.l2s4.p1.openshiftapps.com/gcs/test-platform-results/pr-logs/pull/${REPO_OWNER}_${REPO_NAME}/${PULL_NUMBER}/${JOB_NAME}/${BUILD_ID}/artifacts/e2e-tests/${REPO_OWNER}-${REPO_NAME}/artifacts/${project}" else JOB_URL="${JOB_BASE_URL}/logs/${JOB_NAME}/${BUILD_ID}" - ARTIFACTS_URL="https://gcsweb-ci.apps.ci.l2s4.p1.openshiftapps.com/gcs/test-platform-results/logs/${JOB_NAME}/${BUILD_ID}/artifacts/${JOB_NAME##periodic-ci-janus-idp-backstage-showcase-main-}/${REPO_OWNER}-${REPO_NAME}/artifacts/${project}" + ARTIFACTS_URL="https://gcsweb-ci.apps.ci.l2s4.p1.openshiftapps.com/gcs/test-platform-results/logs/${JOB_NAME}/${BUILD_ID}/artifacts/${JOB_NAME##periodic-ci-redhat-developer-rhdh-main-}/${REPO_OWNER}-${REPO_NAME}/artifacts/${project}" fi # Remove properties (only used for skipped test and invalidates the file if empty) @@ -561,20 +561,20 @@ run_tests() { mkdir -p "${ARTIFACT_DIR}/${project}/test-results" mkdir -p "${ARTIFACT_DIR}/${project}/attachments/screenshots" - cp -a /tmp/backstage-showcase/e2e-tests/test-results/* "${ARTIFACT_DIR}/${project}/test-results" - cp -a /tmp/backstage-showcase/e2e-tests/${JUNIT_RESULTS} "${ARTIFACT_DIR}/${project}/${JUNIT_RESULTS}" + cp -a "${e2e_tests_dir}/test-results/"* "${ARTIFACT_DIR}/${project}/test-results" + cp -a "${e2e_tests_dir}/${JUNIT_RESULTS}" "${ARTIFACT_DIR}/${project}/${JUNIT_RESULTS}" - if [ -d "/tmp/backstage-showcase/e2e-tests/screenshots" ]; then - cp -a /tmp/backstage-showcase/e2e-tests/screenshots/* "${ARTIFACT_DIR}/${project}/attachments/screenshots/" + if [ -d "${e2e_tests_dir}/screenshots" ]; then + cp -a "${e2e_tests_dir}/screenshots/"* "${ARTIFACT_DIR}/${project}/attachments/screenshots/" fi - if [ -d "/tmp/backstage-showcase/e2e-tests/auth-providers-logs" ]; then - cp -a /tmp/backstage-showcase/e2e-tests/auth-providers-logs/* "${ARTIFACT_DIR}/${project}/" + if [ -d "${e2e_tests_dir}/auth-providers-logs" ]; then + cp -a "${e2e_tests_dir}/auth-providers-logs/"* "${ARTIFACT_DIR}/${project}/" fi ansi2html <"/tmp/${LOGFILE}" >"/tmp/${LOGFILE}.html" cp -a "/tmp/${LOGFILE}.html" "${ARTIFACT_DIR}/${project}" - cp -a /tmp/backstage-showcase/e2e-tests/playwright-report/* "${ARTIFACT_DIR}/${project}" + cp -a "${e2e_tests_dir}/playwright-report/"* "${ARTIFACT_DIR}/${project}" droute_send "${release_name}" "${project}" diff --git a/e2e-tests/playwright/utils/ui-helper.ts b/e2e-tests/playwright/utils/ui-helper.ts index 3a0cdf67f5..23290c9b70 100644 --- a/e2e-tests/playwright/utils/ui-helper.ts +++ b/e2e-tests/playwright/utils/ui-helper.ts @@ -371,7 +371,6 @@ export class UIhelper { .getAttribute("href"); expect(buttonUrl).toContain(url); } - // locator('[data-test-id="topology-test"]').getByRole('button', { name: 'Open URL' }) /** * Verifies that a table row, identified by unique text, contains specific cell texts. @@ -622,6 +621,7 @@ export class UIhelper { await this.page .locator('[data-test-id="topology-test"]') .getByText("Pod") + .first() .hover({}); } From 25e9dc3b6455d5fd9c12d9025b6218967c8ac12d Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 15:13:04 +0530 Subject: [PATCH 11/14] cleanup --- .ibm/pipelines/utils.sh | 2 +- e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index 95ae216e14..9c50f9bae1 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -561,7 +561,7 @@ run_tests() { mkdir -p "${ARTIFACT_DIR}/${project}/test-results" mkdir -p "${ARTIFACT_DIR}/${project}/attachments/screenshots" - cp -a "${e2e_tests_dir}/test-results/"* "${ARTIFACT_DIR}/${project}/test-results" + cp -a "${e2e_tests_dir}/test-results/"* "${ARTIFACT_DIR}/${project}/test-results" cp -a "${e2e_tests_dir}/${JUNIT_RESULTS}" "${ARTIFACT_DIR}/${project}/${JUNIT_RESULTS}" if [ -d "${e2e_tests_dir}/screenshots" ]; then diff --git a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts index 57b301a7b0..37b9556254 100644 --- a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts +++ b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts @@ -70,7 +70,7 @@ test.describe("Test Topology Plugin", () => { await uiHelper.verifyHeading("PipelineRuns"); await uiHelper.verifyText("PL"); await uiHelper.verifyText("PLR"); - await page.getByTestId("icon-only-Succeeded").hover(); + await page.getByTestId("icon-only-Succeeded").click(); await uiHelper.verifyDivHasText("Pipeline SucceededTask"); await uiHelper.verifyText("1 Succeeded"); }); From d18a9a566dedf8bbe4622242ffce5413e260d934 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 17:10:45 +0530 Subject: [PATCH 12/14] cleanup --- e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts index 37b9556254..2c7a3aaef4 100644 --- a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts +++ b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts @@ -70,7 +70,8 @@ test.describe("Test Topology Plugin", () => { await uiHelper.verifyHeading("PipelineRuns"); await uiHelper.verifyText("PL"); await uiHelper.verifyText("PLR"); - await page.getByTestId("icon-only-Succeeded").click(); + await page.locator('[data-test-id="topology-test"] circle').first().click(); + // await page.getByTestId("icon-only-Succeeded").click(); await uiHelper.verifyDivHasText("Pipeline SucceededTask"); await uiHelper.verifyText("1 Succeeded"); }); From e851de10c1d478d53b4740d39c66e086a1d53be1 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 19:00:15 +0530 Subject: [PATCH 13/14] 1.4 changes --- e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts index 2c7a3aaef4..64696ce839 100644 --- a/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts +++ b/e2e-tests/playwright/e2e/plugins/topology/topology.spec.ts @@ -70,9 +70,8 @@ test.describe("Test Topology Plugin", () => { await uiHelper.verifyHeading("PipelineRuns"); await uiHelper.verifyText("PL"); await uiHelper.verifyText("PLR"); - await page.locator('[data-test-id="topology-test"] circle').first().click(); - // await page.getByTestId("icon-only-Succeeded").click(); + await page.getByTestId("status-ok").first().click(); await uiHelper.verifyDivHasText("Pipeline SucceededTask"); - await uiHelper.verifyText("1 Succeeded"); + await uiHelper.verifyText("2 Succeeded"); }); }); From 256413aeaed6f0d94e5e96d6398f9f1eff313911 Mon Sep 17 00:00:00 2001 From: teknaS47 Date: Fri, 17 Jan 2025 20:23:42 +0530 Subject: [PATCH 14/14] fix --- .ibm/pipelines/utils.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.ibm/pipelines/utils.sh b/.ibm/pipelines/utils.sh index 9c50f9bae1..deff00205a 100755 --- a/.ibm/pipelines/utils.sh +++ b/.ibm/pipelines/utils.sh @@ -543,6 +543,9 @@ run_tests() { local project=$2 project=${project} cd "${DIR}/../../e2e-tests" + local e2e_tests_dir + e2e_tests_dir=$(pwd) + yarn install yarn playwright install chromium