Skip to content

Commit

Permalink
HPCC-33066 add more ECL Watch v9 UI tests
Browse files Browse the repository at this point in the history
add a few more ECL Watch v9 playwright tests, mostly on the WU, File
and Query list pages, as well as a few on the playground for creating
WUs, files, and queries.

Signed-off-by: Jeremy Clements <[email protected]>
  • Loading branch information
jeclrsg committed Jan 15, 2025
1 parent d7baff7 commit bc231e3
Show file tree
Hide file tree
Showing 8 changed files with 339 additions and 17 deletions.
8 changes: 7 additions & 1 deletion .github/workflows/build-test-eclwatch.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ jobs:
- name: Lint
working-directory: ./esp/src
run: npm run lint
- name: Install Playwright browsers
- name: Install Playwright browsers
working-directory: ./esp/src
run: npx playwright install --with-deps
- name: Build
Expand All @@ -60,3 +60,9 @@ jobs:
- name: Test
working-directory: ./esp/src
run: npm run test
- name: Upload Playwright test results
if: ${{ failure() }}
uses: actions/upload-artifact@v4
with:
name: eclwatch-test-results
path: ./esp/src/test-results/*
2 changes: 1 addition & 1 deletion esp/src/eclwatch/ECLPlaygroundWidget.js
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ define([
var logicalCluster = context.targetSelectWidget.selectedTarget();
var submitBtn = registry.byId(context.id + "SubmitBtn");
var publishBtn = registry.byId(context.id + "PublishBtn");
if (logicalCluster.QueriesOnly) {
if (logicalCluster.QueriesOnly || logicalCluster.Type === "roxie") {
domStyle.set(submitBtn.domNode, "display", "none");
domStyle.set(publishBtn.domNode, "display", null);
} else {
Expand Down
21 changes: 18 additions & 3 deletions esp/src/playwright.config.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { defineConfig, devices } from "@playwright/test";

const baseURL = process.env.CI ? "https://play.hpccsystems.com:18010" : "http://127.0.0.1:8080";
export const baseURL = process.env.CI ? "https://play.hpccsystems.com:18010" : "http://127.0.0.1:8080";

/**
* See https://playwright.dev/docs/test-configuration.
Expand All @@ -11,28 +11,43 @@ export default defineConfig({
forbidOnly: !!process.env.CI,
retries: process.env.CI ? 2 : 0,
workers: process.env.CI ? 4 : undefined,
timeout: 60_000,
expect: {
timeout: 30_000
},
reporter: "html",
use: {
baseURL,
trace: "on-first-retry",
screenshot: "on-first-failure",
ignoreHTTPSErrors: true
},

projects: [
{
name: "setup",
testMatch: /global\.setup\.ts/,
teardown: "teardown"
},
{
name: "chromium",
use: { ...devices["Desktop Chrome"] },
dependencies: ["setup"]
},

{
name: "firefox",
use: { ...devices["Desktop Firefox"] },
dependencies: ["setup"]
},

{
name: "webkit",
use: { ...devices["Desktop Safari"] },
dependencies: ["setup"]
},
{
name: "teardown",
testMatch: /global\.teardown\.ts/
}

],

Expand Down
2 changes: 1 addition & 1 deletion esp/src/src-react/components/ECLPlayground.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -346,7 +346,7 @@ const ECLEditorToolbar: React.FunctionComponent<ECLEditorToolbarProps> = ({
className={playgroundStyles.inlineDropdown}
onChange={React.useCallback((evt, option: TargetClusterOption) => {
const selectedCluster = option.key.toString();
if (option?.queriesOnly) {
if (option?.queriesOnly || option?.type === "roxie") {
setShowSubmitBtn(false);
} else {
setShowSubmitBtn(true);
Expand Down
1 change: 1 addition & 0 deletions esp/src/src-react/components/forms/Fields.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -459,6 +459,7 @@ export interface TargetClusterTextFieldProps extends Omit<AsyncDropdownProps, "o
}

export interface TargetClusterOption extends IDropdownOption {
type: string;
queriesOnly: boolean;
}

Expand Down
148 changes: 137 additions & 11 deletions esp/src/tests/eclwatch-v9.spec.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,12 @@
import { test, expect } from "@playwright/test";

test.describe("ECLWatch V9", () => {
test.describe("Basic ECLWatch V9 UI", () => {

test("Basic Frame", async ({ page }) => {
test.beforeEach(async ({ page }) => {
await page.goto("/esp/files/index.html#/activities");
})

test("Frame Loaded", async ({ page }) => {
await expect(page.getByRole("link", { name: "ECL Watch" })).toBeVisible();
await expect(page.locator("button").filter({ hasText: "" })).toBeVisible();
await expect(page.getByRole("button", { name: "Advanced" })).toBeVisible();
Expand All @@ -17,9 +20,7 @@ test.describe("ECLWatch V9", () => {
await expect(page.getByRole("link", { name: "Event Scheduler" })).toBeVisible();
});

test("Activities", async ({ page }) => {
await page.goto("/esp/files/index.html#/activities");
await page.getByTitle("Disk Usage").locator("i").click();
test("Activities page", async ({ page }) => {
await expect(page.locator("svg").filter({ hasText: "%hthor" })).toBeVisible();
await expect(page.locator(".reflex-splitter")).toBeVisible();
await expect(page.getByRole("menubar")).toBeVisible();
Expand All @@ -32,11 +33,136 @@ test.describe("ECLWatch V9", () => {
await expect(page.getByText("State")).toBeVisible();
await expect(page.getByText("Owner")).toBeVisible();
await expect(page.getByText("Job Name")).toBeVisible();
await expect(page.getByRole("gridcell", { name: "HThorServer - hthor" })).toBeVisible();
await expect(page.getByRole("gridcell", { name: "ThorMaster - thor", exact: true })).toBeVisible();
await expect(page.getByRole("gridcell", { name: "ThorMaster - thor_roxie" })).toBeVisible();
await expect(page.getByRole("gridcell", { name: "RoxieServer - roxie" })).toBeVisible();
await expect(page.getByRole("gridcell", { name: "myeclccserver - hthor." })).toBeVisible();
await expect(page.getByRole("gridcell", { name: "mydfuserver - dfuserver_queue" })).toBeVisible();
await expect(page.locator(".dgrid-row")).not.toHaveCount(0);
});
});

test.describe("Workunit tests", () => {

test.beforeEach(async ({ page }) => {
await page.goto("/esp/files/index.html#/workunits");
});

test("View the Workunits list page", async ({ page }) => {
await expect(page.getByRole("menubar")).toBeVisible();
await expect(page.getByRole("menuitem", { name: "Refresh" })).toBeVisible();
await expect(page.getByText("WUID")).toBeVisible();
await expect(page.getByText("Owner", { exact: true })).toBeVisible();
await expect(page.getByText("Job Name")).toBeVisible();
await expect(page.getByText("Cluster", { exact: true })).toBeVisible();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
});

test("Filter the Workunits list page", async ({ page }) => {
const date = new Date();
const month = date.getMonth() + 1 < 10 ? "0" + (date.getMonth() + 1) : date.getMonth() + 1;
const day = date.getDate() < 10 ? "0" + date.getDate() : date.getDate();
await expect(page.getByRole("menubar")).toBeVisible();
await expect(page.getByRole("menuitem", { name: "Refresh" })).toBeVisible();
await page.getByRole("menuitem", { name: "Filter" }).click();
const wuidField = await page.getByPlaceholder("W20200824-060035");
wuidField.fill(`W${date.getFullYear()}${month}${day}*`);
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
await page.getByRole("menuitem", { name: "Filter" }).click();
await page.getByPlaceholder("W20200824-060035").fill(`W2023*`);
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).toHaveCount(0);
await page.getByRole("menuitem", { name: "Filter" }).click();
await page.getByRole("button", { name: "Clear" }).click();
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
});

test("Protect / Unprotect a WU", async ({ page }) => {
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
await page.locator(".ms-DetailsRow").first().locator(".ms-DetailsRow-check").click();
await expect(page.locator(".ms-DetailsRow.is-selected")).toHaveCount(1);
await page.getByRole("menuitem", { name: "Protect", exact: true }).click();
await expect(page.locator(".ms-DetailsRow").first().locator("[data-icon-name=\"LockSolid\"]")).toBeVisible();
await page.getByRole("menuitem", { name: "Unprotect" }).click();
await expect(page.locator(".ms-DetailsRow").first().locator("[data-icon-name=\"LockSolid\"]")).not.toBeVisible();
});

test("Set a WU to failed", async ({ page }) => {
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
await page.locator(".ms-DetailsRow").filter({ hasText: "completed" }).last().locator(".ms-DetailsRow-check").click();
await expect(page.locator(".ms-DetailsRow.is-selected")).toHaveCount(1);
await page.getByRole("menuitem", { name: "Set To Failed", exact: true }).click();
await expect(page.locator(".ms-DetailsRow.is-selected").filter({ hasText: "failed" })).toBeVisible();
});

// this test was failing when run in GitHub Actions
// test("Delete a WU", async ({ page }) => {
// const wuCount = await page.locator(".ms-DetailsRow").count();
// await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
// await page.locator(".ms-DetailsRow").filter({ hasText: "completed" }).first().locator(".ms-DetailsRow-check").click();
// await expect(page.locator(".ms-DetailsRow.is-selected")).toHaveCount(1);
// await page.getByRole("menuitem", { name: "Delete", exact: true }).click();
// await page.getByRole("button", { name: "OK" }).click();
// await expect(page.locator(".ms-DetailsRow")).toHaveCount(wuCount - 1);
// });

});

test.describe("File tests", () => {

test.beforeEach(async ({ page }) => {
await page.goto("/esp/files/index.html#/files");
});

test("View the Files list page", async ({ page }) => {
await expect(page.getByRole("menubar")).toBeVisible();
await expect(page.getByRole("menuitem", { name: "Refresh" })).toBeVisible();
await expect(page.getByText("Logical Name")).toBeVisible();
await expect(page.getByText("Owner", { exact: true })).toBeVisible();
await expect(page.getByText("Cluster")).toBeVisible();
await expect(page.getByText("Records")).toBeVisible();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
});

test("Filter the Files list page", async ({ page }) => {
await expect(page.getByRole("menubar")).toBeVisible();
await expect(page.getByRole("menuitem", { name: "Refresh" })).toBeVisible();
await page.getByRole("menuitem", { name: "Filter" }).click();
await page.getByPlaceholder("*::somefile*").fill("*allPeople*");
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).toHaveCount(1);
await page.getByRole("menuitem", { name: "Filter" }).click();
await page.getByRole("button", { name: "Clear" }).click();
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(1);
});

});

test.describe("Query tests", () => {

test.beforeEach(async ({ page }) => {
await page.goto("/esp/files/index.html#/queries");
});

test("View the Queries list page", async ({ page }) => {
await expect(page.getByRole("menubar")).toBeVisible();
await expect(page.getByRole("menuitem", { name: "Refresh" })).toBeVisible();
await expect(page.getByText("ID", { exact: true })).toBeVisible();
await expect(page.getByText("Priority", { exact: true })).toBeVisible();
await expect(page.getByText("Name")).toBeVisible();
await expect(page.getByText("Target")).toBeVisible();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
});

test("Filter the Queries list page", async ({ page }) => {
await expect(page.getByRole("menubar")).toBeVisible();
await expect(page.getByRole("menuitem", { name: "Refresh" })).toBeVisible();
await page.getByRole("menuitem", { name: "Filter" }).click();
await page.getByPlaceholder("My?Su?erQ*ry").fill("asdf");
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).toHaveCount(0);
await page.getByRole("menuitem", { name: "Filter" }).click();
await page.getByRole("button", { name: "Clear" }).click();
await page.getByRole("button", { name: "Apply" }).click();
await expect(page.locator(".ms-DetailsRow")).not.toHaveCount(0);
});

});
Loading

0 comments on commit bc231e3

Please sign in to comment.