context("Create a View", () => { before(() => { cy.visit("localhost:4001/_builder") cy.createApp("View App", "View App Description") cy.createTable("data") cy.addColumn("data", "group", "Text") cy.addColumn("data", "age", "Number") cy.addColumn("data", "rating", "Number") // 6 Rows cy.addRow(["Students", 25, 1]) cy.addRow(["Students", 20, 3]) cy.addRow(["Students", 18, 6]) cy.addRow(["Students", 25, 2]) cy.addRow(["Teachers", 49, 5]) cy.addRow(["Teachers", 36, 3]) }) it("creates a view", () => { cy.contains("Create New View").click() cy.get(".menu-container").within(() => { cy.get("input").type("Test View") cy.contains("Save View").click() }) cy.get(".table-title h1").contains("Test View") cy.get("[data-cy=table-header]").then($headers => { expect($headers).to.have.length(3) const headers = Array.from($headers).map(header => header.textContent.trim() ) expect(headers).to.deep.eq([ 'rating', 'age', 'group' ]) }) }) it("filters the view by age over 10", () => { cy.contains("Filter").click() cy.contains("Add Filter").click() cy.get(".menu-container").find("select").first().select("age") cy.get(".menu-container").find("select").eq(1).select("More Than") cy.get(".menu-container").find("input").type(18) cy.contains("Save").click() cy.get("[role=rowgroup] .ag-row").get($values => { expect($values).to.have.length(5) }) }) it("creates a stats calculation view based on age", () => { // Required due to responsive bug with ag grid in cypress cy.viewport("macbook-15") cy.contains("Calculate").click() cy.get(".menu-container").find("select").eq(0).select("Statistics") cy.wait(50) cy.get(".menu-container").find("select").eq(1).select("age") cy.contains("Save").click() cy.wait(100) cy.get(".ag-center-cols-viewport").scrollTo("100%") cy.get("[data-cy=table-header]").then($headers => { expect($headers).to.have.length(7) const headers = Array.from($headers).map(header => header.textContent.trim() ) expect(headers).to.deep.eq([ 'avg', 'sumsqr', 'count', 'max', 'min', 'sum', 'field' ]) }) cy.get(".ag-cell").then($values => { let values = Array.from($values).map(header => header.textContent.trim() ) expect(values).to.deep.eq([ '31', '5347', '5', '49', '20', '155', 'age' ]) }) }) it("groups the view by group", () => { // Required due to responsive bug with ag grid in cypress cy.viewport("macbook-15") cy.contains("Group By").click() cy.get("select").select("group") cy.contains("Save").click() cy.get(".ag-center-cols-viewport").scrollTo("100%") cy.contains("Students").should("be.visible") cy.contains("Teachers").should("be.visible") cy.get(".ag-row[row-index=0]") .find(".ag-cell") .then($values => { const values = Array.from($values).map(value => value.textContent) expect(values).to.deep.eq([ 'Students', '23.333333333333332', '1650', '3', '25', '20', '70' ]) }) }) it("renames a view", () => { cy.contains(".nav-item", "Test View") .find(".ri-more-line") .click({ force: true }) cy.get("[data-cy=edit-view]").click() cy.get(".menu-container").within(() => { cy.get("input").type(" Updated") cy.contains("Save").click() }) cy.contains("Test View Updated").should("be.visible") }) it("deletes a view", () => { cy.contains(".nav-item", "Test View Updated") .find(".ri-more-line") .click({ force: true }) cy.get("[data-cy=delete-view]").click() cy.contains("Delete View").click() cy.contains("TestView Updated").should("not.be.visible") }) })