多维表格
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

473 lines
14 KiB

import { mainPage, settingsPage } from "../../support/page_objects/mainPage";
import { loginPage, projectsPage } from "../../support/page_objects/navigation";
import {
isTestSuiteActive,
sakilaSqlViews,
sakilaTables,
} from "../../support/page_objects/projectConstants";
export const genTest = (apiType, dbType) => {
if (!isTestSuiteActive(apiType, dbType)) return;
describe(`${apiType.toUpperCase()} ERD`, () => {
// before(() => {
// loginPage.loginAndOpenProject(apiType, dbType);
// cy.openTableTab("Country", 25);
// cy.saveLocalStorage();
// });
beforeEach(() => {
cy.restoreLocalStorage();
});
afterEach(() => {
cy.saveLocalStorage();
});
after(() => {
cy.restoreLocalStorage();
cy.closeTableTab("Country");
cy.saveLocalStorage();
});
// Test cases
it(`Enable MM setting Open Table ERD`, () => {
cy.openTableTab("Country", 25);
mainPage.toggleShowMMSetting();
mainPage.openErdTab();
mainPage.closeMetaTab();
});
it(`Verify ERD Context menu in all table view`, () => {
mainPage.openErdTab();
cy.get(".nc-erd-context-menu").should("be.visible");
cy.get(".nc-erd-context-menu")
.get(".nc-erd-histogram")
.should("be.visible");
cy.get(".nc-erd-context-menu")
.find(".ant-checkbox")
.should("have.length", 3);
cy.get(".nc-erd-context-menu")
.find(".ant-checkbox")
.eq(0)
.should("have.class", "ant-checkbox-checked");
cy.get(".nc-erd-context-menu")
.find(".ant-checkbox")
.eq(1)
.should("have.class", "ant-checkbox-checked");
cy.get(".nc-erd-context-menu")
.find(".ant-checkbox")
.eq(2)
.should("not.have.class", "ant-checkbox-checked");
cy.get(".nc-erd-context-menu")
.find(".nc-erd-showColumns-label")
.dblclick();
cy.get(".nc-erd-context-menu")
.find(".ant-checkbox")
.should("have.length", 5);
});
it("Verify ERD of all tables view and verify columns of actor and payment with default config", () => {
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-table-node")
.should("have.length", 12);
cy.get(".nc-erd-vue-flow")
.find(".vue-flow__edge")
.should("have.length", 14);
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-edge-circle")
.should("have.length", 11);
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-edge-rect")
.should("have.length", 17);
for (const tableName of sakilaTables) {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-${tableName}`)
.should("exist");
}
// Actor table
[
"actor_id",
"first_name",
"last_name",
"last_update",
"film_list",
].forEach((colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-actor`)
.find(`.nc-erd-table-node-actor-column-${colTitle}`)
.should("exist");
});
// Payment table
[
"payment_id",
"customer_id",
"staff_id",
"rental_id",
"amount",
"payment_date",
"last_update",
"customer",
"rental",
"staff",
].forEach((colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-payment`)
.find(`.nc-erd-table-node-payment-column-${colTitle}`)
.should("exist");
});
});
it("Verify ERD of all tables view and verify columns of actor and payment with default config with showAllColumn disabled", () => {
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showColumns-checkbox")
.click();
cy.get(".nc-erd-showPkAndFk-checkbox-disabled").should("exist");
cy.get(".nc-erd-showPkAndFk-checkbox-unchecked").should("exist");
// Actor table
["film_list"].forEach((colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-actor`)
.find(`.nc-erd-table-node-actor-column-${colTitle}`)
.should("exist");
});
// Payment table
["customer", "rental", "staff"].forEach((colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-payment`)
.find(`.nc-erd-table-node-payment-column-${colTitle}`)
.should("exist");
});
});
it("Verify ERD of all tables view and verify columns of actor and payment with default config with showPkAndFk disabled", () => {
// enable showAllColumn
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showColumns-checkbox")
.click();
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showPkAndFk-checkbox")
.click();
// Actor table
["last_name", "last_update", "film_list"].forEach((colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-actor`)
.find(`.nc-erd-table-node-actor-column-${colTitle}`)
.should("exist");
});
// Payment table
[
"amount",
"payment_date",
"last_update",
"customer",
"rental",
"staff",
].forEach((colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-payment`)
.find(`.nc-erd-table-node-payment-column-${colTitle}`)
.should("exist");
});
});
it("Verify ERD of all tables view with sql grid on and verify columns of ActorInfo", () => {
cy.get(".nc-erd-context-menu").get(".nc-erd-showViews-checkbox").click();
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-table-node")
.should("have.length", 19);
cy.get(".nc-erd-vue-flow")
.find(".vue-flow__edge")
.should("have.length", 14);
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-edge-circle")
.should("have.length", 11);
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-edge-rect")
.should("have.length", 17);
for (const tableName of sakilaTables) {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-${tableName}`)
.should("exist");
}
for (const tableName of sakilaSqlViews) {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-${tableName}`)
.should("exist");
}
// ActorInfo SQL View
["actor_id", "first_name", "last_name", "film_info"].forEach(
(colTitle) => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-actor_info`)
.find(`.nc-erd-table-node-actor_info-column-${colTitle}`)
.should("exist");
}
);
});
it("Verify show MM tables", () => {
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-store`)
.should("not.exist");
// disable showViews
cy.get(".nc-erd-context-menu").get(".nc-erd-showViews-checkbox").click();
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showMMTables-checkbox")
.click();
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-table-node")
.should("have.length", 16);
cy.get(".nc-erd-vue-flow")
.find(".vue-flow__edge")
.should("have.length", 26);
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-edge-circle")
.should("have.length", 22);
cy.get(".nc-erd-vue-flow")
.find(".nc-erd-edge-rect")
.should("have.length", 30);
// Check if store table is present
cy.get(".nc-erd-vue-flow")
.find(`.nc-erd-table-node-store`)
.should("exist");
});
it("Verify show junction table names", () => {
// disable showViews
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showJunctionTableNames-checkbox")
.click();
cy.get(".nc-erd-vue-flow")
.get(".nc-erd-table-label-filmactor-film_actor")
.should("exist");
mainPage.closeMetaTab();
});
it("Verify table ERD view of country", () => {
mainPage.openTableErdView();
cy.get(".nc-erd-vue-flow-single-table")
.find(".nc-erd-table-node")
.should("have.length", 2);
cy.get(".nc-erd-vue-flow-single-table")
.find(".vue-flow__edge")
.should("have.length", 1);
cy.get(".nc-erd-vue-flow-single-table")
.find(".nc-erd-edge-circle")
.should("have.length", 1);
cy.get(".nc-erd-vue-flow-single-table")
.find(".nc-erd-edge-rect")
.should("have.length", 1);
const countryColumns = [
"country_id",
"country",
"last_update",
"city_list",
];
// Country table
countryColumns.forEach((colTitle) => {
cy.get(".nc-erd-vue-flow-single-table")
.find(`.nc-erd-table-node-country`)
.find(`.nc-erd-table-node-country-column-${colTitle}`)
.should("exist");
});
const cityColumns = [
"city_id",
"city",
"last_update",
"country",
"address_list",
];
// City table
cityColumns.forEach((colTitle) => {
cy.get(".nc-erd-vue-flow-single-table")
.find(`.nc-erd-table-node-city`)
.find(`.nc-erd-table-node-city-column-${colTitle}`)
.should("exist");
});
});
it("Verify table ERD view of country showAllColumn disabled", () => {
cy.get(".nc-erd-vue-flow-single-table").within(() => {
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showColumns-checkbox")
.click();
cy.get(".nc-erd-showPkAndFk-checkbox-disabled").should("exist");
cy.get(".nc-erd-showPkAndFk-checkbox-unchecked").should("exist");
const countryColumns = ["city_list"];
// Country table
countryColumns.forEach((colTitle) => {
cy.get(`.nc-erd-table-node-country`)
.find(`.nc-erd-table-node-country-column-${colTitle}`)
.should("exist");
});
const cityColumns = ["country", "address_list"];
// City table
cityColumns.forEach((colTitle) => {
cy.get(`.nc-erd-table-node-city`)
.find(`.nc-erd-table-node-city-column-${colTitle}`)
.should("exist");
});
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showColumns-checkbox")
.click();
});
});
it("Verify table ERD view of country show PK AND FK disabled", () => {
cy.get(".nc-erd-vue-flow-single-table").within(() => {
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showPkAndFk-checkbox")
.click();
const countryColumns = ["country", "last_update", "city_list"];
// Country table
countryColumns.forEach((colTitle) => {
cy.get(`.nc-erd-table-node-country`)
.find(`.nc-erd-table-node-country-column-${colTitle}`)
.should("exist");
});
const cityColumns = ["city", "last_update", "country", "address_list"];
// City table
cityColumns.forEach((colTitle) => {
cy.get(`.nc-erd-table-node-city`)
.find(`.nc-erd-table-node-city-column-${colTitle}`)
.should("exist");
});
cy.get(".nc-erd-context-menu")
.get(".nc-erd-showPkAndFk-checkbox")
.click();
});
cy.getActiveModal().find(".nc-modal-close").click({ force: true });
});
it("create column and check if the change is in the schema", () => {
mainPage.addColumn("test_column", "country");
// table view
mainPage.openTableErdView();
cy.get(".nc-erd-vue-flow-single-table").within(() => {
cy.get(".nc-erd-table-node-country")
.find(".nc-erd-table-node-country-column-test_column")
.should("exist");
});
cy.getActiveModal().find(".nc-modal-close").click({ force: true });
// All table view
mainPage.openErdTab();
cy.get(".nc-erd-vue-flow").within(() => {
cy.get(".nc-erd-table-node-country")
.find(".nc-erd-table-node-country-column-test_column")
.should("exist");
});
mainPage.closeMetaTab();
mainPage.deleteColumn("test_column");
// table view
mainPage.openTableErdView();
cy.get(".nc-erd-vue-flow-single-table").within(() => {
cy.get(".nc-erd-table-node-country")
.find(".nc-erd-table-node-country-column-test_column")
.should("not.exist");
});
cy.getActiveModal().find(".nc-modal-close").click({ force: true });
// All table view
mainPage.openErdTab();
cy.get(".nc-erd-vue-flow").within(() => {
cy.get(".nc-erd-table-node-country")
.find(".nc-erd-table-node-country-column-test_column")
.should("not.exist");
});
mainPage.closeMetaTab();
});
it("Create table should reflected in ERD", () => {
cy.createTable("new");
mainPage.openErdTab();
cy.get(".nc-erd-vue-flow").within(() => {
cy.get(".nc-erd-table-node-new").should("exist");
});
mainPage.closeMetaTab();
cy.deleteTable("new");
mainPage.openErdTab();
cy.get(".nc-erd-vue-flow").within(() => {
cy.get(".nc-erd-table-node-new").should("not.exist");
});
mainPage.closeMetaTab();
});
it(`Disable MM setting Open Table ERD and check easter egg should not work`, () => {
mainPage.toggleShowMMSetting();
mainPage.openErdTab();
cy.get(".nc-erd-vue-flow").within(() => {
cy.get(".nc-erd-context-menu")
.find(".nc-erd-showColumns-label")
.dblclick();
cy.get(".nc-erd-context-menu")
.find(".ant-checkbox")
.should("have.length", 3);
});
mainPage.closeMetaTab();
});
});
};
/**
* @copyright Copyright (c) 2021, Xgene Cloud Ltd
*
* @author Raju Udava <sivadstala@gmail.com>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/