mirror of
https://github.com/nocodb/nocodb.git
synced 2026-05-02 15:06:51 +00:00
test(cypress): additional delay between sqlite query
Signed-off-by: Raju Udava <86527202+dstala@users.noreply.github.com>
This commit is contained in:
@@ -4,35 +4,35 @@
|
||||
import { loginPage, projectsPage } from "../../support/page_objects/navigation";
|
||||
import { mainPage } from "../../support/page_objects/mainPage";
|
||||
import {
|
||||
staticProjects,
|
||||
roles,
|
||||
isTestSuiteActive,
|
||||
getPrimarySuite,
|
||||
isSecondarySuite,
|
||||
getCurrentMode,
|
||||
isXcdb,
|
||||
setProjectString,
|
||||
staticProjects,
|
||||
roles,
|
||||
isTestSuiteActive,
|
||||
getPrimarySuite,
|
||||
isSecondarySuite,
|
||||
getCurrentMode,
|
||||
isXcdb,
|
||||
setProjectString,
|
||||
} from "../../support/page_objects/projectConstants";
|
||||
|
||||
function prepareSqliteQuery(projId) {
|
||||
let sqliteQuery = [
|
||||
`ALTER TABLE "actor" RENAME TO "nc_${projId}__actor"`,
|
||||
`ALTER TABLE "address" RENAME TO "nc_${projId}__address"`,
|
||||
`ALTER TABLE "category" RENAME TO "nc_${projId}__category"`,
|
||||
`ALTER TABLE "city" RENAME TO "nc_${projId}__city"`,
|
||||
`ALTER TABLE "country" RENAME TO "nc_${projId}__country"`,
|
||||
`ALTER TABLE "customer" RENAME TO "nc_${projId}__customer"`,
|
||||
`ALTER TABLE "film" RENAME TO "nc_${projId}__film"`,
|
||||
`ALTER TABLE "film_actor" RENAME TO "nc_${projId}__film_actor"`,
|
||||
`ALTER TABLE "film_category" RENAME TO "nc_${projId}__film_category"`,
|
||||
`ALTER TABLE "film_text" RENAME TO "nc_${projId}__film_text"`,
|
||||
`ALTER TABLE "inventory" RENAME TO "nc_${projId}__inventory"`,
|
||||
`ALTER TABLE "language" RENAME TO "nc_${projId}__language"`,
|
||||
`ALTER TABLE "payment" RENAME TO "nc_${projId}__payment"`,
|
||||
`ALTER TABLE "rental" RENAME TO "nc_${projId}__rental"`,
|
||||
`ALTER TABLE "staff" RENAME TO "nc_${projId}__staff"`,
|
||||
`ALTER TABLE "store" RENAME TO "nc_${projId}__store"`,
|
||||
`CREATE VIEW nc_${projId}__customer_list
|
||||
let sqliteQuery = [
|
||||
`ALTER TABLE "actor" RENAME TO "nc_${projId}__actor"`,
|
||||
`ALTER TABLE "address" RENAME TO "nc_${projId}__address"`,
|
||||
`ALTER TABLE "category" RENAME TO "nc_${projId}__category"`,
|
||||
`ALTER TABLE "city" RENAME TO "nc_${projId}__city"`,
|
||||
`ALTER TABLE "country" RENAME TO "nc_${projId}__country"`,
|
||||
`ALTER TABLE "customer" RENAME TO "nc_${projId}__customer"`,
|
||||
`ALTER TABLE "film" RENAME TO "nc_${projId}__film"`,
|
||||
`ALTER TABLE "film_actor" RENAME TO "nc_${projId}__film_actor"`,
|
||||
`ALTER TABLE "film_category" RENAME TO "nc_${projId}__film_category"`,
|
||||
`ALTER TABLE "film_text" RENAME TO "nc_${projId}__film_text"`,
|
||||
`ALTER TABLE "inventory" RENAME TO "nc_${projId}__inventory"`,
|
||||
`ALTER TABLE "language" RENAME TO "nc_${projId}__language"`,
|
||||
`ALTER TABLE "payment" RENAME TO "nc_${projId}__payment"`,
|
||||
`ALTER TABLE "rental" RENAME TO "nc_${projId}__rental"`,
|
||||
`ALTER TABLE "staff" RENAME TO "nc_${projId}__staff"`,
|
||||
`ALTER TABLE "store" RENAME TO "nc_${projId}__store"`,
|
||||
`CREATE VIEW nc_${projId}__customer_list
|
||||
AS
|
||||
SELECT cu.customer_id AS ID,
|
||||
cu.first_name||' '||cu.last_name AS name,
|
||||
@@ -45,7 +45,7 @@ function prepareSqliteQuery(projId) {
|
||||
cu.store_id AS SID
|
||||
FROM "nc_${projId}__customer" AS cu JOIN "nc_${projId}__address" AS a ON cu.address_id = a.address_id JOIN "nc_${projId}__city" ON a.city_id = "nc_${projId}__city".city_id
|
||||
JOIN "nc_${projId}__country" ON "nc_${projId}__city".country_id = "nc_${projId}__country".country_id`,
|
||||
`CREATE VIEW nc_${projId}__film_list
|
||||
`CREATE VIEW nc_${projId}__film_list
|
||||
AS
|
||||
SELECT "nc_${projId}__film".film_id AS FID,
|
||||
"nc_${projId}__film".title AS title,
|
||||
@@ -58,7 +58,7 @@ function prepareSqliteQuery(projId) {
|
||||
FROM "nc_${projId}__category" LEFT JOIN "nc_${projId}__film_category" ON "nc_${projId}__category".category_id = "nc_${projId}__film_category".category_id LEFT JOIN "nc_${projId}__film" ON "nc_${projId}__Film_category".film_id = "nc_${projId}__film".film_id
|
||||
JOIN "nc_${projId}__film_actor" ON "nc_${projId}__film".film_id = "nc_${projId}__film_actor".film_id
|
||||
JOIN "nc_${projId}__actor" ON "nc_${projId}__film_actor".actor_id = "nc_${projId}__actor".actor_id`,
|
||||
`CREATE VIEW nc_${projId}__sales_by_film_category
|
||||
`CREATE VIEW nc_${projId}__sales_by_film_category
|
||||
AS
|
||||
SELECT
|
||||
c.name AS category
|
||||
@@ -70,7 +70,7 @@ function prepareSqliteQuery(projId) {
|
||||
INNER JOIN "nc_${projId}__film_category" AS fc ON f.film_id = fc.film_id
|
||||
INNER JOIN "nc_${projId}__category" AS c ON fc.category_id = c.category_id
|
||||
GROUP BY c.name`,
|
||||
`CREATE VIEW nc_${projId}__sales_by_store
|
||||
`CREATE VIEW nc_${projId}__sales_by_store
|
||||
AS
|
||||
SELECT
|
||||
s.store_id
|
||||
@@ -89,7 +89,7 @@ function prepareSqliteQuery(projId) {
|
||||
s.store_id
|
||||
, c.city||','||cy.country
|
||||
, m.first_name||' '||m.last_name`,
|
||||
`CREATE VIEW nc_${projId}__staff_list
|
||||
`CREATE VIEW nc_${projId}__staff_list
|
||||
AS
|
||||
SELECT s.staff_id AS ID,
|
||||
s.first_name||' '||s.last_name AS name,
|
||||
@@ -101,8 +101,8 @@ function prepareSqliteQuery(projId) {
|
||||
s.store_id AS SID
|
||||
FROM "nc_${projId}__staff" AS s JOIN "nc_${projId}__address" AS a ON s.address_id = a.address_id JOIN "nc_${projId}__city" ON a.city_id = "nc_${projId}__city".city_id
|
||||
JOIN "nc_${projId}__country" ON "nc_${projId}__city".country_id = "nc_${projId}__country".country_id`,
|
||||
// below two are dummy entries to ensure view record exists
|
||||
`CREATE VIEW nc_${projId}__actor_info
|
||||
// below two are dummy entries to ensure view record exists
|
||||
`CREATE VIEW nc_${projId}__actor_info
|
||||
AS
|
||||
SELECT s.staff_id AS ID,
|
||||
s.first_name||' '||s.last_name AS name,
|
||||
@@ -114,7 +114,7 @@ function prepareSqliteQuery(projId) {
|
||||
s.store_id AS SID
|
||||
FROM "nc_${projId}__staff" AS s JOIN "nc_${projId}__address" AS a ON s.address_id = a.address_id JOIN "nc_${projId}__city" ON a.city_id = "nc_${projId}__city".city_id
|
||||
JOIN "nc_${projId}__country" ON "nc_${projId}__city".country_id = "nc_${projId}__country".country_id`,
|
||||
`CREATE VIEW nc_${projId}__nice_but_slower_film_list
|
||||
`CREATE VIEW nc_${projId}__nice_but_slower_film_list
|
||||
AS
|
||||
SELECT s.staff_id AS ID,
|
||||
s.first_name||' '||s.last_name AS name,
|
||||
@@ -126,155 +126,156 @@ function prepareSqliteQuery(projId) {
|
||||
s.store_id AS SID
|
||||
FROM "nc_${projId}__staff" AS s JOIN "nc_${projId}__address" AS a ON s.address_id = a.address_id JOIN "nc_${projId}__city" ON a.city_id = "nc_${projId}__city".city_id
|
||||
JOIN "nc_${projId}__country" ON "nc_${projId}__city".country_id = "nc_${projId}__country".country_id`,
|
||||
// `CREATE VIEW nc_${projId}__actor_info
|
||||
// AS
|
||||
// SELECT
|
||||
// a.actor_id AS actor_id,
|
||||
// a.first_name AS first_name,
|
||||
// a.last_name AS last_name,
|
||||
// GROUP_CONCAT(DISTINCT CONCAT(c.name,
|
||||
// ': ',
|
||||
// (SELECT
|
||||
// GROUP_CONCAT(f.title
|
||||
// ORDER BY f.title ASC
|
||||
// SEPARATOR ', ')
|
||||
// FROM
|
||||
// ((nc_${projId}__film f
|
||||
// JOIN nc_${projId}__film_category fc ON ((f.film_id = fc.film_id)))
|
||||
// JOIN nc_${projId}__film_actor fa ON ((f.film_id = fa.film_id)))
|
||||
// WHERE
|
||||
// ((fc.category_id = c.category_id)
|
||||
// AND (fa.actor_id = a.actor_id))))
|
||||
// ORDER BY c.name ASC
|
||||
// SEPARATOR '; ') AS nc_${projId}__film_info
|
||||
// FROM
|
||||
// (((actor a
|
||||
// LEFT JOIN nc_${projId}__film_actor fa ON ((a.actor_id = fa.actor_id)))
|
||||
// LEFT JOIN nc_${projId}__film_category fc ON ((fa.film_id = fc.film_id)))
|
||||
// LEFT JOIN nc_${projId}__category c ON ((fc.category_id = c.category_id)))
|
||||
// GROUP BY a.actor_id , a.first_name , a.last_name`,
|
||||
];
|
||||
return sqliteQuery;
|
||||
// `CREATE VIEW nc_${projId}__actor_info
|
||||
// AS
|
||||
// SELECT
|
||||
// a.actor_id AS actor_id,
|
||||
// a.first_name AS first_name,
|
||||
// a.last_name AS last_name,
|
||||
// GROUP_CONCAT(DISTINCT CONCAT(c.name,
|
||||
// ': ',
|
||||
// (SELECT
|
||||
// GROUP_CONCAT(f.title
|
||||
// ORDER BY f.title ASC
|
||||
// SEPARATOR ', ')
|
||||
// FROM
|
||||
// ((nc_${projId}__film f
|
||||
// JOIN nc_${projId}__film_category fc ON ((f.film_id = fc.film_id)))
|
||||
// JOIN nc_${projId}__film_actor fa ON ((f.film_id = fa.film_id)))
|
||||
// WHERE
|
||||
// ((fc.category_id = c.category_id)
|
||||
// AND (fa.actor_id = a.actor_id))))
|
||||
// ORDER BY c.name ASC
|
||||
// SEPARATOR '; ') AS nc_${projId}__film_info
|
||||
// FROM
|
||||
// (((actor a
|
||||
// LEFT JOIN nc_${projId}__film_actor fa ON ((a.actor_id = fa.actor_id)))
|
||||
// LEFT JOIN nc_${projId}__film_category fc ON ((fa.film_id = fc.film_id)))
|
||||
// LEFT JOIN nc_${projId}__category c ON ((fc.category_id = c.category_id)))
|
||||
// GROUP BY a.actor_id , a.first_name , a.last_name`,
|
||||
];
|
||||
return sqliteQuery;
|
||||
}
|
||||
|
||||
export const genTest = (type, xcdb) => {
|
||||
if (!isTestSuiteActive(type, xcdb)) return;
|
||||
describe(`Project pre-configurations`, () => {
|
||||
it("Admin SignUp", () => {
|
||||
cy.task("log", "This will be output to the terminal");
|
||||
cy.waitForSpinners();
|
||||
cy.signinOrSignup(roles.owner.credentials);
|
||||
if (!isTestSuiteActive(type, xcdb)) return;
|
||||
describe(`Project pre-configurations`, () => {
|
||||
it("Admin SignUp", () => {
|
||||
cy.task("log", "This will be output to the terminal");
|
||||
cy.waitForSpinners();
|
||||
cy.signinOrSignup(roles.owner.credentials);
|
||||
});
|
||||
|
||||
const createProject = (proj) => {
|
||||
it(`Create ${proj.basic.name} project`, () => {
|
||||
// click home button
|
||||
cy.get(".nc-noco-brand-icon").click();
|
||||
|
||||
cy.get(".nc-container").then((obj) => {
|
||||
cy.log(obj);
|
||||
|
||||
// if project already created, open
|
||||
// else, create a new one
|
||||
if (true == obj[0].innerHTML.includes(proj.basic.name)) {
|
||||
projectsPage.openProject(proj.basic.name);
|
||||
} else {
|
||||
projectsPage.createProject(proj.basic, proj.config);
|
||||
}
|
||||
|
||||
if (xcdb) {
|
||||
// store base URL- to re-visit and delete form view later
|
||||
let projId;
|
||||
cy.url()
|
||||
.then((url) => {
|
||||
// project prefix code can include "_"
|
||||
// projId = url.split("_")[1].split("?")[0];
|
||||
let startIdx = url.indexOf("_");
|
||||
let endIdx = url.indexOf("?");
|
||||
projId = url.slice(startIdx + 1, endIdx);
|
||||
cy.log(url, projId);
|
||||
setProjectString(projId);
|
||||
|
||||
let query = prepareSqliteQuery(projId);
|
||||
for (let i = 0; i < query.length; i++) {
|
||||
cy.task("sqliteExec", query[i]);
|
||||
cy.wait(1000);
|
||||
}
|
||||
})
|
||||
.then(() => {
|
||||
cy.log(projId);
|
||||
mainPage.openMetaTab();
|
||||
mainPage.metaSyncValidate(
|
||||
`nc_${projId}__actor`,
|
||||
`New table, New relation added`
|
||||
);
|
||||
mainPage.closeMetaTab();
|
||||
});
|
||||
}
|
||||
|
||||
// create requested project
|
||||
// projectsPage.createProject(proj.basic, proj.config)
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
// if (isTestSuiteActive('rest', true)) createProject(staticProjects.sampleREST)
|
||||
// if (isTestSuiteActive('graphql', true)) createProject(staticProjects.sampleGQL)
|
||||
// if (isTestSuiteActive('rest', false)) createProject(staticProjects.externalREST)
|
||||
// if (isTestSuiteActive('graphql', false)) createProject(staticProjects.externalGQL)
|
||||
|
||||
if ("rest" == type) {
|
||||
if (true == xcdb) {
|
||||
createProject(staticProjects.sampleREST);
|
||||
} else {
|
||||
createProject(staticProjects.externalREST);
|
||||
}
|
||||
} else if ("graphql" == type) {
|
||||
if (true == xcdb) {
|
||||
createProject(staticProjects.sampleGQL);
|
||||
} else {
|
||||
createProject(staticProjects.externalGQL);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
const createProject = (proj) => {
|
||||
it(`Create ${proj.basic.name} project`, () => {
|
||||
// click home button
|
||||
cy.get(".nc-noco-brand-icon").click();
|
||||
// describe('Static user creations (different roles)', () => {
|
||||
|
||||
cy.get(".nc-container").then((obj) => {
|
||||
cy.log(obj);
|
||||
// beforeEach(() => {
|
||||
// loginPage.signIn(roles.owner.credentials)
|
||||
// projectsPage.openProject(getPrimarySuite().basic.name)
|
||||
// })
|
||||
|
||||
// if project already created, open
|
||||
// else, create a new one
|
||||
if (true == obj[0].innerHTML.includes(proj.basic.name)) {
|
||||
projectsPage.openProject(proj.basic.name);
|
||||
} else {
|
||||
projectsPage.createProject(proj.basic, proj.config);
|
||||
}
|
||||
// const addUser = (user) => {
|
||||
// it(`RoleType: ${user.name}`, () => {
|
||||
// mainPage.addNewUserToProject(user.credentials, user.name)
|
||||
// })
|
||||
// }
|
||||
|
||||
if (xcdb) {
|
||||
// store base URL- to re-visit and delete form view later
|
||||
let projId;
|
||||
cy.url()
|
||||
.then((url) => {
|
||||
// project prefix code can include "_"
|
||||
// projId = url.split("_")[1].split("?")[0];
|
||||
let startIdx = url.indexOf("_");
|
||||
let endIdx = url.indexOf("?");
|
||||
projId = url.slice(startIdx + 1, endIdx);
|
||||
cy.log(url, projId);
|
||||
setProjectString(projId);
|
||||
// addUser(roles.creator)
|
||||
// addUser(roles.editor)
|
||||
// addUser(roles.commenter)
|
||||
// addUser(roles.viewer)
|
||||
// })
|
||||
|
||||
let query = prepareSqliteQuery(projId);
|
||||
for (let i = 0; i < query.length; i++) {
|
||||
cy.task("sqliteExec", query[i]);
|
||||
}
|
||||
})
|
||||
.then(() => {
|
||||
cy.log(projId);
|
||||
mainPage.openMetaTab();
|
||||
mainPage.metaSyncValidate(
|
||||
`nc_${projId}__actor`,
|
||||
`New table, New relation added`
|
||||
);
|
||||
mainPage.closeMetaTab();
|
||||
});
|
||||
}
|
||||
// describe('Static users- add to other static projects', () => {
|
||||
|
||||
// create requested project
|
||||
// projectsPage.createProject(proj.basic, proj.config)
|
||||
});
|
||||
});
|
||||
};
|
||||
// const addUserToProject = (proj) => {
|
||||
// it(`Add users to ${proj.basic.name}`, () => {
|
||||
// loginPage.signIn(roles.owner.credentials)
|
||||
// projectsPage.openProject(proj.basic.name)
|
||||
|
||||
// if (isTestSuiteActive('rest', true)) createProject(staticProjects.sampleREST)
|
||||
// if (isTestSuiteActive('graphql', true)) createProject(staticProjects.sampleGQL)
|
||||
// if (isTestSuiteActive('rest', false)) createProject(staticProjects.externalREST)
|
||||
// if (isTestSuiteActive('graphql', false)) createProject(staticProjects.externalGQL)
|
||||
// mainPage.addExistingUserToProject(roles.creator.credentials.username, roles.creator.name)
|
||||
// mainPage.addExistingUserToProject(roles.editor.credentials.username, roles.editor.name)
|
||||
// mainPage.addExistingUserToProject(roles.commenter.credentials.username, roles.commenter.name)
|
||||
// mainPage.addExistingUserToProject(roles.viewer.credentials.username, roles.viewer.name)
|
||||
// })
|
||||
// }
|
||||
|
||||
if ("rest" == type) {
|
||||
if (true == xcdb) {
|
||||
createProject(staticProjects.sampleREST);
|
||||
} else {
|
||||
createProject(staticProjects.externalREST);
|
||||
}
|
||||
} else if ("graphql" == type) {
|
||||
if (true == xcdb) {
|
||||
createProject(staticProjects.sampleGQL);
|
||||
} else {
|
||||
createProject(staticProjects.externalGQL);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
// describe('Static user creations (different roles)', () => {
|
||||
|
||||
// beforeEach(() => {
|
||||
// loginPage.signIn(roles.owner.credentials)
|
||||
// projectsPage.openProject(getPrimarySuite().basic.name)
|
||||
// })
|
||||
|
||||
// const addUser = (user) => {
|
||||
// it(`RoleType: ${user.name}`, () => {
|
||||
// mainPage.addNewUserToProject(user.credentials, user.name)
|
||||
// })
|
||||
// }
|
||||
|
||||
// addUser(roles.creator)
|
||||
// addUser(roles.editor)
|
||||
// addUser(roles.commenter)
|
||||
// addUser(roles.viewer)
|
||||
// })
|
||||
|
||||
// describe('Static users- add to other static projects', () => {
|
||||
|
||||
// const addUserToProject = (proj) => {
|
||||
// it(`Add users to ${proj.basic.name}`, () => {
|
||||
// loginPage.signIn(roles.owner.credentials)
|
||||
// projectsPage.openProject(proj.basic.name)
|
||||
|
||||
// mainPage.addExistingUserToProject(roles.creator.credentials.username, roles.creator.name)
|
||||
// mainPage.addExistingUserToProject(roles.editor.credentials.username, roles.editor.name)
|
||||
// mainPage.addExistingUserToProject(roles.commenter.credentials.username, roles.commenter.name)
|
||||
// mainPage.addExistingUserToProject(roles.viewer.credentials.username, roles.viewer.name)
|
||||
// })
|
||||
// }
|
||||
|
||||
// if (isSecondarySuite('rest', true)) addUserToProject(staticProjects.sampleREST)
|
||||
// if (isSecondarySuite('graphql', true)) addUserToProject(staticProjects.sampleGQL)
|
||||
// if (isSecondarySuite('rest', false)) addUserToProject(staticProjects.externalREST)
|
||||
// if (isSecondarySuite('graphql', false)) addUserToProject(staticProjects.externalGQL)
|
||||
// })
|
||||
// if (isSecondarySuite('rest', true)) addUserToProject(staticProjects.sampleREST)
|
||||
// if (isSecondarySuite('graphql', true)) addUserToProject(staticProjects.sampleGQL)
|
||||
// if (isSecondarySuite('rest', false)) addUserToProject(staticProjects.externalREST)
|
||||
// if (isSecondarySuite('graphql', false)) addUserToProject(staticProjects.externalGQL)
|
||||
// })
|
||||
};
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user