mirror of https://github.com/nocodb/nocodb
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.
284 lines
12 KiB
284 lines
12 KiB
// Cypress test suite: project pre-configurations |
|
// |
|
|
|
import { loginPage, projectsPage } from "../../support/page_objects/navigation"; |
|
import { mainPage } from "../../support/page_objects/mainPage"; |
|
import { |
|
staticProjects, |
|
roles, |
|
isTestSuiteActive, |
|
getCurrentMode, |
|
isXcdb, |
|
setProjectString, |
|
} from "../../support/page_objects/projectConstants"; |
|
|
|
function prepareSqliteQuery(projId) { |
|
let sqliteQuery = [ |
|
`ALTER TABLE "actor" RENAME TO "${projId}actor"`, |
|
`ALTER TABLE "address" RENAME TO "${projId}address"`, |
|
`ALTER TABLE "category" RENAME TO "${projId}category"`, |
|
`ALTER TABLE "city" RENAME TO "${projId}city"`, |
|
`ALTER TABLE "country" RENAME TO "${projId}country"`, |
|
`ALTER TABLE "customer" RENAME TO "${projId}customer"`, |
|
`ALTER TABLE "film" RENAME TO "${projId}film"`, |
|
`ALTER TABLE "film_actor" RENAME TO "${projId}film_actor"`, |
|
`ALTER TABLE "film_category" RENAME TO "${projId}film_category"`, |
|
`ALTER TABLE "film_text" RENAME TO "${projId}film_text"`, |
|
`ALTER TABLE "inventory" RENAME TO "${projId}inventory"`, |
|
`ALTER TABLE "language" RENAME TO "${projId}language"`, |
|
`ALTER TABLE "payment" RENAME TO "${projId}payment"`, |
|
`ALTER TABLE "rental" RENAME TO "${projId}rental"`, |
|
`ALTER TABLE "staff" RENAME TO "${projId}staff"`, |
|
`ALTER TABLE "store" RENAME TO "${projId}store"`, |
|
`CREATE VIEW ${projId}customer_list |
|
AS |
|
SELECT cu.customer_id AS ID, |
|
cu.first_name||' '||cu.last_name AS name, |
|
a.address AS address, |
|
a.postal_code AS zip_code, |
|
a.phone AS phone, |
|
"${projId}city".city AS city, |
|
"${projId}country".country AS country, |
|
case when cu.active=1 then 'active' else '' end AS notes, |
|
cu.store_id AS SID |
|
FROM "${projId}customer" AS cu JOIN "${projId}address" AS a ON cu.address_id = a.address_id JOIN "${projId}city" ON a.city_id = "${projId}city".city_id |
|
JOIN "${projId}country" ON "${projId}city".country_id = "${projId}country".country_id`, |
|
`CREATE VIEW ${projId}film_list |
|
AS |
|
SELECT "${projId}film".film_id AS FID, |
|
"${projId}film".title AS title, |
|
"${projId}film".description AS description, |
|
"${projId}category".name AS category, |
|
"${projId}film".rental_rate AS price, |
|
"${projId}film".length AS length, |
|
"${projId}film".rating AS rating, |
|
"${projId}actor".first_name||' '||"${projId}actor".last_name AS actors |
|
FROM "${projId}category" LEFT JOIN "${projId}film_category" ON "${projId}category".category_id = "${projId}film_category".category_id LEFT JOIN "${projId}film" ON "${projId}Film_category".film_id = "${projId}film".film_id |
|
JOIN "${projId}film_actor" ON "${projId}film".film_id = "${projId}film_actor".film_id |
|
JOIN "${projId}actor" ON "${projId}film_actor".actor_id = "${projId}actor".actor_id`, |
|
`CREATE VIEW ${projId}sales_by_film_category |
|
AS |
|
SELECT |
|
c.name AS category |
|
, SUM(p.amount) AS total_sales |
|
FROM "${projId}payment" AS p |
|
INNER JOIN "${projId}rental" AS r ON p.rental_id = r.rental_id |
|
INNER JOIN "${projId}inventory" AS i ON r.inventory_id = i.inventory_id |
|
INNER JOIN "${projId}film" AS f ON i.film_id = f.film_id |
|
INNER JOIN "${projId}film_category" AS fc ON f.film_id = fc.film_id |
|
INNER JOIN "${projId}category" AS c ON fc.category_id = c.category_id |
|
GROUP BY c.name`, |
|
`CREATE VIEW ${projId}sales_by_store |
|
AS |
|
SELECT |
|
s.store_id |
|
,c.city||','||cy.country AS store |
|
,m.first_name||' '||m.last_name AS manager |
|
,SUM(p.amount) AS total_sales |
|
FROM "${projId}payment" AS p |
|
INNER JOIN "${projId}rental" AS r ON p.rental_id = r.rental_id |
|
INNER JOIN "${projId}inventory" AS i ON r.inventory_id = i.inventory_id |
|
INNER JOIN "${projId}store" AS s ON i.store_id = s.store_id |
|
INNER JOIN "${projId}address" AS a ON s.address_id = a.address_id |
|
INNER JOIN "${projId}city" AS c ON a.city_id = c.city_id |
|
INNER JOIN "${projId}country" AS cy ON c.country_id = cy.country_id |
|
INNER JOIN "${projId}staff" AS m ON s.manager_staff_id = m.staff_id |
|
GROUP BY |
|
s.store_id |
|
, c.city||','||cy.country |
|
, m.first_name||' '||m.last_name`, |
|
`CREATE VIEW ${projId}staff_list |
|
AS |
|
SELECT s.staff_id AS ID, |
|
s.first_name||' '||s.last_name AS name, |
|
a.address AS address, |
|
a.postal_code AS zip_code, |
|
a.phone AS phone, |
|
"${projId}city".city AS city, |
|
"${projId}country".country AS country, |
|
s.store_id AS SID |
|
FROM "${projId}staff" AS s JOIN "${projId}address" AS a ON s.address_id = a.address_id JOIN "${projId}city" ON a.city_id = "${projId}city".city_id |
|
JOIN "${projId}country" ON "${projId}city".country_id = "${projId}country".country_id`, |
|
// below two are dummy entries to ensure view record exists |
|
`CREATE VIEW ${projId}actor_info |
|
AS |
|
SELECT s.staff_id AS ID, |
|
s.first_name||' '||s.last_name AS name, |
|
a.address AS address, |
|
a.postal_code AS zip_code, |
|
a.phone AS phone, |
|
"${projId}city".city AS city, |
|
"${projId}country".country AS country, |
|
s.store_id AS SID |
|
FROM "${projId}staff" AS s JOIN "${projId}address" AS a ON s.address_id = a.address_id JOIN "${projId}city" ON a.city_id = "${projId}city".city_id |
|
JOIN "${projId}country" ON "${projId}city".country_id = "${projId}country".country_id`, |
|
`CREATE VIEW ${projId}nice_but_slower_film_list |
|
AS |
|
SELECT s.staff_id AS ID, |
|
s.first_name||' '||s.last_name AS name, |
|
a.address AS address, |
|
a.postal_code AS zip_code, |
|
a.phone AS phone, |
|
"${projId}city".city AS city, |
|
"${projId}country".country AS country, |
|
s.store_id AS SID |
|
FROM "${projId}staff" AS s JOIN "${projId}address" AS a ON s.address_id = a.address_id JOIN "${projId}city" ON a.city_id = "${projId}city".city_id |
|
JOIN "${projId}country" ON "${projId}city".country_id = "${projId}country".country_id`, |
|
// `CREATE VIEW ${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 |
|
// ((${projId}film f |
|
// JOIN ${projId}film_category fc ON ((f.film_id = fc.film_id))) |
|
// JOIN ${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 ${projId}film_info |
|
// FROM |
|
// (((actor a |
|
// LEFT JOIN ${projId}film_actor fa ON ((a.actor_id = fa.actor_id))) |
|
// LEFT JOIN ${projId}film_category fc ON ((fa.film_id = fc.film_id))) |
|
// LEFT JOIN ${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 = (apiType, dbType) => { |
|
if (!isTestSuiteActive(apiType, dbType)) return; |
|
describe(`Project pre-configurations`, () => { |
|
before(() => { |
|
cy.fileHook(); |
|
}); |
|
|
|
it("Admin SignUp", () => { |
|
cy.task("log", "This will be output to the terminal"); |
|
loginPage.signUp(roles.owner.credentials); |
|
}); |
|
|
|
function cy_createProjectBlock(proj, apiType, dbType) { |
|
// click home button |
|
cy.get(".nc-noco-brand-icon").click(); |
|
cy.get(".ant-table-content").then((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); |
|
let projId; |
|
if (dbType === "xcdb") { |
|
let query = `SELECT prefix from nc_projects_v2 where title = "sampleREST"; `; |
|
cy.task("sqliteExecReturnValue", query).then((resolve) => { |
|
cy.log(resolve); |
|
projId = resolve.prefix; |
|
setProjectString(projId); |
|
cy.log(projId); |
|
}); |
|
} |
|
} else { |
|
projectsPage.createProject(proj.basic, proj.config); |
|
cy.wait(5000); |
|
if (dbType === "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); |
|
|
|
let query = `SELECT prefix from nc_projects_v2 where title = "sampleREST"; `; |
|
cy.task("sqliteExecReturnValue", query) |
|
.then((resolve) => { |
|
cy.log(resolve); |
|
projId = resolve.prefix; |
|
cy.log(projId); |
|
setProjectString(projId); |
|
}) |
|
.then(() => { |
|
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( |
|
`${projId}actor`, |
|
`New table, New relation added` |
|
); |
|
mainPage.closeMetaTab(); |
|
}); |
|
} |
|
} |
|
}); |
|
} |
|
|
|
const createProject = (proj) => { |
|
it(`Create ${proj.basic.name} project`, () => { |
|
if (dbType === "postgres") { |
|
// wait for docker compose to start |
|
cy.task("pgExecTest", `SELECT 1+1`, { timeout: 120000 }).then(() => |
|
cy_createProjectBlock(proj, apiType, dbType) |
|
); |
|
} else { |
|
cy_createProjectBlock(proj, apiType, dbType); |
|
} |
|
|
|
// kludge: wait for page load to finish |
|
cy.wait(2000); |
|
// close team & auth tab |
|
cy.get("button.ant-tabs-tab-remove").should("exist").click(); |
|
cy.wait(1000); |
|
|
|
// first instance of updating local storage information |
|
cy.saveLocalStorage(); |
|
}); |
|
}; |
|
|
|
if ("xcdb" === dbType) { |
|
createProject(staticProjects.sampleREST); |
|
} else if (dbType === "mysql") { |
|
createProject(staticProjects.externalREST); |
|
} else if (dbType === "postgres") { |
|
createProject(staticProjects.pgExternalREST); |
|
} |
|
}); |
|
}; |
|
|
|
/** |
|
* @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/>. |
|
* |
|
*/
|
|
|