Files
redash/client/cypress/integration/visualizations/pivot_spec.js
2020-08-25 14:24:15 -03:00

161 lines
5.3 KiB
JavaScript

/* global cy */
import { getWidgetTestId } from "../../support/dashboard";
const SQL = `
SELECT 'a' AS stage1, 'a1' AS stage2, 11 AS value UNION ALL
SELECT 'a' AS stage1, 'a2' AS stage2, 12 AS value UNION ALL
SELECT 'a' AS stage1, 'a3' AS stage2, 45 AS value UNION ALL
SELECT 'a' AS stage1, 'a4' AS stage2, 54 AS value UNION ALL
SELECT 'b' AS stage1, 'b1' AS stage2, 33 AS value UNION ALL
SELECT 'b' AS stage1, 'b2' AS stage2, 73 AS value UNION ALL
SELECT 'b' AS stage1, 'b3' AS stage2, 90 AS value UNION ALL
SELECT 'c' AS stage1, 'c1' AS stage2, 19 AS value UNION ALL
SELECT 'c' AS stage1, 'c2' AS stage2, 92 AS value UNION ALL
SELECT 'c' AS stage1, 'c3' AS stage2, 63 AS value UNION ALL
SELECT 'c' AS stage1, 'c4' AS stage2, 44 AS value\
`;
function createPivotThroughUI(visualizationName, options = {}) {
cy.getByTestId("NewVisualization").click();
cy.getByTestId("VisualizationType").click();
cy.getByTestId("VisualizationType.PIVOT").click();
cy.getByTestId("VisualizationName")
.clear()
.type(visualizationName);
if (options.hideControls) {
cy.getByTestId("PivotEditor.HideControls").click();
cy.getByTestId("VisualizationPreview")
.find("table")
.find(".pvtAxisContainer, .pvtRenderer, .pvtVals")
.should("be.not.visible");
}
cy.getByTestId("VisualizationPreview")
.find("table")
.should("exist");
cy.getByTestId("EditVisualizationDialog")
.contains("button", "Save")
.click();
}
describe("Pivot", () => {
beforeEach(() => {
cy.login();
cy.createQuery({ name: "Pivot Visualization", query: SQL })
.its("id")
.as("queryId");
});
it("creates Pivot with controls", function() {
cy.visit(`queries/${this.queryId}/source`);
cy.getByTestId("ExecuteButton").click();
const visualizationName = "Pivot";
createPivotThroughUI(visualizationName);
cy.getByTestId("QueryPageVisualizationTabs")
.contains("span", visualizationName)
.should("exist");
});
it("creates Pivot without controls", function() {
cy.visit(`queries/${this.queryId}/source`);
cy.getByTestId("ExecuteButton").click();
const visualizationName = "Pivot";
cy.server();
cy.route("POST", "**/api/visualizations").as("SaveVisualization");
createPivotThroughUI(visualizationName, { hideControls: true });
cy.wait("@SaveVisualization");
// Added visualization should also have hidden controls
cy.getByTestId("PivotTableVisualization")
.find("table")
.find(".pvtAxisContainer, .pvtRenderer, .pvtVals")
.should("be.not.visible");
});
it("updates the visualization when results change", function() {
const options = {
aggregatorName: "Count",
data: [], // force it to have a data object, although it shouldn't
controls: { enabled: false },
cols: ["stage1"],
rows: ["stage2"],
vals: ["value"],
};
cy.createVisualization(this.queryId, "PIVOT", "Pivot", options).then(visualization => {
cy.visit(`queries/${this.queryId}/source#${visualization.id}`);
cy.getByTestId("ExecuteButton").click();
// assert number of rows is 11
cy.getByTestId("PivotTableVisualization").contains(".pvtGrandTotal", "11");
cy.getByTestId("QueryEditor")
.get(".ace_text-input")
.first()
.focus()
.type(" UNION ALL {enter}SELECT 'c' AS stage1, 'c5' AS stage2, 55 AS value");
cy.getByTestId("SaveButton").click();
cy.getByTestId("ExecuteButton").click();
// assert number of rows is 12
cy.getByTestId("PivotTableVisualization").contains(".pvtGrandTotal", "12");
});
});
it("takes a snapshot with different configured Pivots", function() {
const options = {
aggregatorName: "Sum",
controls: { enabled: true },
cols: ["stage1"],
rows: ["stage2"],
vals: ["value"],
};
const pivotTables = [
{ name: "Pivot", options, position: { autoHeight: false, sizeY: 10, sizeX: 2 } },
{
name: "Pivot without Row Totals",
options: { ...options, rendererOptions: { table: { rowTotals: false } } },
position: { autoHeight: false, col: 2, sizeY: 10, sizeX: 2 },
},
{
name: "Pivot without Col Totals",
options: { ...options, rendererOptions: { table: { colTotals: false } } },
position: { autoHeight: false, col: 4, sizeY: 10, sizeX: 2 },
},
{
name: "Pivot with Controls",
options: { ...options, controls: { enabled: false } },
position: { autoHeight: false, row: 9, sizeY: 13 },
},
];
cy.createDashboard("Pivot Visualization")
.then(dashboard => {
this.dashboardUrl = `/dashboards/${dashboard.id}`;
return cy.all(
pivotTables.map(pivot => () =>
cy
.createVisualization(this.queryId, "PIVOT", pivot.name, pivot.options)
.then(visualization => cy.addWidget(dashboard.id, visualization.id, { position: pivot.position }))
)
);
})
.then(widgets => {
cy.visit(this.dashboardUrl);
widgets.forEach(widget => {
cy.getByTestId(getWidgetTestId(widget)).within(() =>
cy.getByTestId("PivotTableVisualization").should("exist")
);
});
cy.percySnapshot("Visualizations - Pivot Table");
});
});
});