114 lines
3.4 KiB
TypeScript
114 lines
3.4 KiB
TypeScript
|
|
/// <reference types="cypress" />
|
||
|
|
|
||
|
|
import { setupCommonPageTestHooks } from "../support/testHooks";
|
||
|
|
|
||
|
|
describe("/dashboard - mobile sidebar", () => {
|
||
|
|
const apiBase = "**/api/v1";
|
||
|
|
|
||
|
|
setupCommonPageTestHooks(apiBase);
|
||
|
|
|
||
|
|
function stubDashboardApis() {
|
||
|
|
cy.intercept("GET", `${apiBase}/metrics/dashboard*`, {
|
||
|
|
statusCode: 200,
|
||
|
|
body: {
|
||
|
|
total_boards: 0,
|
||
|
|
total_tasks: 0,
|
||
|
|
tasks_by_status: {},
|
||
|
|
active_agents: 0,
|
||
|
|
pending_approvals: 0,
|
||
|
|
},
|
||
|
|
}).as("dashboardMetrics");
|
||
|
|
}
|
||
|
|
|
||
|
|
function visitDashboardAuthenticated() {
|
||
|
|
stubDashboardApis();
|
||
|
|
cy.loginWithLocalAuth();
|
||
|
|
cy.visit("/dashboard");
|
||
|
|
cy.waitForAppLoaded();
|
||
|
|
}
|
||
|
|
|
||
|
|
it("auth negative: signed-out user does not see hamburger button", () => {
|
||
|
|
cy.visit("/dashboard");
|
||
|
|
cy.contains("h1", /local authentication/i, { timeout: 30_000 }).should(
|
||
|
|
"be.visible",
|
||
|
|
);
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').should("not.exist");
|
||
|
|
});
|
||
|
|
|
||
|
|
it("mobile: hamburger button visible and sidebar hidden by default", () => {
|
||
|
|
cy.viewport(375, 812);
|
||
|
|
visitDashboardAuthenticated();
|
||
|
|
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').should("be.visible");
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "closed");
|
||
|
|
cy.get("aside").should("not.be.visible");
|
||
|
|
});
|
||
|
|
|
||
|
|
it("desktop: hamburger button hidden and sidebar always visible", () => {
|
||
|
|
cy.viewport(1280, 800);
|
||
|
|
visitDashboardAuthenticated();
|
||
|
|
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').should("not.be.visible");
|
||
|
|
cy.get("aside").should("be.visible");
|
||
|
|
});
|
||
|
|
|
||
|
|
it("mobile: click hamburger opens sidebar and shows backdrop", () => {
|
||
|
|
cy.viewport(375, 812);
|
||
|
|
visitDashboardAuthenticated();
|
||
|
|
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').click();
|
||
|
|
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "open");
|
||
|
|
cy.get("aside").should("be.visible");
|
||
|
|
cy.get('[aria-hidden="true"]').should("exist");
|
||
|
|
});
|
||
|
|
|
||
|
|
it("mobile: click backdrop closes sidebar", () => {
|
||
|
|
cy.viewport(375, 812);
|
||
|
|
visitDashboardAuthenticated();
|
||
|
|
|
||
|
|
// Open sidebar first
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').click();
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "open");
|
||
|
|
|
||
|
|
// Click the backdrop overlay
|
||
|
|
cy.get('[aria-hidden="true"]').click({ force: true });
|
||
|
|
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "closed");
|
||
|
|
cy.get("aside").should("not.be.visible");
|
||
|
|
});
|
||
|
|
|
||
|
|
it("mobile: clicking a nav link closes sidebar", () => {
|
||
|
|
cy.viewport(375, 812);
|
||
|
|
visitDashboardAuthenticated();
|
||
|
|
|
||
|
|
// Open sidebar
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').click();
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "open");
|
||
|
|
cy.get("aside").should("be.visible");
|
||
|
|
|
||
|
|
// Click a navigation link inside the sidebar
|
||
|
|
cy.get("aside").within(() => {
|
||
|
|
cy.contains("a", "Boards").click();
|
||
|
|
});
|
||
|
|
|
||
|
|
// Sidebar should close after navigation
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "closed");
|
||
|
|
});
|
||
|
|
|
||
|
|
it("mobile: pressing Escape closes sidebar", () => {
|
||
|
|
cy.viewport(375, 812);
|
||
|
|
visitDashboardAuthenticated();
|
||
|
|
|
||
|
|
// Open sidebar
|
||
|
|
cy.get('[aria-label="Toggle navigation"]').click();
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "open");
|
||
|
|
|
||
|
|
// Press Escape
|
||
|
|
cy.get("body").type("{esc}");
|
||
|
|
|
||
|
|
cy.get("[data-sidebar]").should("have.attr", "data-sidebar", "closed");
|
||
|
|
cy.get("aside").should("not.be.visible");
|
||
|
|
});
|
||
|
|
});
|