Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SLVUU-50: Add E2E tests for Layout Management #136

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
76 changes: 76 additions & 0 deletions vuu-ui/cypress/e2e/layout-management/layout-management.cy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
import "cypress-iframe";
import { ShellWithNewTheme } from "../../pages/ShellWithNewTheme";
import { SaveLayoutDialog } from "../../pages/SaveLayoutDialog";

const page = new ShellWithNewTheme();
const dialog = new SaveLayoutDialog();

context("Layout Management", () => {
beforeEach(() => {
page.visit();
});

it("Saves and reloads layout", () => {
const savedLayoutName = "Saved Layout";
const updatedLayoutName = "Updated Layout";
const layoutGroup = "Layout Group";
const layoutSaveName = "My Layout";

// Update open layout
page.getTab(0).dblclick();
// eslint-disable-next-line cypress/unsafe-to-chain-command
cy.focused().type(`${savedLayoutName}{enter}`);

// Save the updated layout
page.getContextMenuButton().click();
page.getSaveLayoutButton().click();

dialog.getGroupField().type(layoutGroup);
dialog.getNameField().clear().type(layoutSaveName);
dialog.getSaveButton().click();

// Verify success notification
page.getToasts().should("have.length", 1);
page.getToastText("Layout Saved Successfully").should("be.visible");
page
.getToastText(`${layoutSaveName} saved successfully`)
.should("be.visible");

// Update open layout again
page.getTab(0).dblclick();
// eslint-disable-next-line cypress/unsafe-to-chain-command
cy.focused().type(`${updatedLayoutName}{enter}`);

// Load saved layout
page.getMyLayoutsButton().click();
page
.getLayoutTile(layoutSaveName, layoutGroup, "test-user", new Date())
.should("be.visible")
.click();

// Verify saved layout is loaded
page.getTabs().should("have.length", 2);
page.getTab(0).should("contain.text", updatedLayoutName);
page.getTab(1).should("contain.text", savedLayoutName);
});

it("Does not save when cancel button is clicked", () => {
const layoutGroup = "Layout Group";
const layoutSaveName = "My Layout";

// Go to save a layout, but cancel
page.getContextMenuButton().click();
page.getSaveLayoutButton().click();

dialog.getGroupField().type(layoutGroup);
dialog.getNameField().clear().type(layoutSaveName);
dialog.getCancelButton().click();

// Verify no notification
page.getToasts().should("have.length", 0);

// Verify no saved layouts show in drawer
page.getMyLayoutsButton().click();
page.getLayoutGroup(layoutGroup).should("not.exist");
});
});
55 changes: 45 additions & 10 deletions vuu-ui/cypress/pages/ShellWithNewTheme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,22 +6,49 @@ export class ShellWithNewTheme {
cy.visit(SHELL_WITH_NEW_THEME_URL);
};

getTabs: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy.findByRole("tablist", { name: "data tabs" }).findAllByRole("tab");
};

getTab: (n: number) => Cypress.Chainable<JQuery<HTMLElement>> = (
n: number
) => {
return this.getTabs().eq(n);
};

getContextMenuButton: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy
.findByRole("tablist", { name: "data tabs" })
.findAllByRole("tab")
.first()
.findByRole("button", { name: "context menu" });
return this.getTab(0).findByRole("button", { name: "context menu" });
};

getSaveLayoutButton: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy.findByRole("menuitem", { name: "Save Layout" });
};

getRenameLayoutButton: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy.findByRole("menuitem", { name: "Rename" });
};

getMyLayoutsButton: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy.findByRole("tab", { name: "MY LAYOUTS" });
};

getVuuTablesButton: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy.findByRole("tab", { name: "VUU TABLES" });
};

getFirstAvailableVuuTable: () => Cypress.Chainable<JQuery<HTMLElement>> =
() => {
return cy.findAllByRole("option").first();
};

getLayoutGroup: (group: string) => Cypress.Chainable<JQuery<HTMLElement>> = (
group: string
) => {
return cy
.findByRole("listbox", { name: "my layouts" })
.findByRole("list", { name: group });
};

getLayoutTile: (
layoutName: string,
group: string,
Expand All @@ -36,10 +63,18 @@ export class ShellWithNewTheme {
const formattedDate = formatDate({ date: "dd.mm.yyyy" })(date);
const layoutTileName = `${layoutName} ${creator}, ${formattedDate}`;

return cy
.findByRole("listbox", { name: "my layouts" })
.findByRole("list", { name: group })
.findByRole("listitem", { name: layoutTileName })
.findByRole("button");
return this.getLayoutGroup(group).findByRole("button", {
name: layoutTileName,
});
};

getToasts: () => Cypress.Chainable<JQuery<HTMLElement>> = () => {
return cy.findAllByRole("status");
};

getToastText: (text: string) => Cypress.Chainable<JQuery<HTMLElement>> = (
text: string
) => {
return cy.findByRole("status").findByText(text);
};
}
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,7 @@ export const ToastNotification = (props: ToastNotificationProps) => {
<Portal>
<div
className={classNames(`${classBase}-toast`, notification.type)}
role="status"
style={{
height: toastHeight,
right,
Expand Down
3 changes: 2 additions & 1 deletion vuu-ui/scripts/build.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -132,9 +132,10 @@ export default async function main(customConfig) {
} = packageJson;

let files = getDefaultFilesToPublish(options);

let defaultStyle = undefined;

if (filesFromPackageJson) {
if (filesFromPackageJson || isTypeLib) {
const filesToPublish = isTypeLib
? [indexDTS]
: filesFromPackageJson.filter(
Expand Down
Loading