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.
117 lines
2.7 KiB
117 lines
2.7 KiB
2 years ago
|
|
||
|
import { Audit, Project } from '../../../src/models'
|
||
|
import TestDbMngr from '../TestDbMngr';
|
||
|
|
||
|
const dropTablesOfSakila = async () => {
|
||
|
await TestDbMngr.disableForeignKeyChecks(TestDbMngr.sakilaKnex);
|
||
|
|
||
|
for (const tableName of sakilaTableNames) {
|
||
|
try {
|
||
|
if (TestDbMngr.isPg()) {
|
||
|
await TestDbMngr.sakilaKnex.raw(
|
||
|
`DROP TABLE IF EXISTS "${tableName}" CASCADE`
|
||
|
);
|
||
|
} else {
|
||
|
await TestDbMngr.sakilaKnex.raw(`DROP TABLE ${tableName}`);
|
||
|
}
|
||
|
} catch (e) {}
|
||
|
}
|
||
|
await TestDbMngr.enableForeignKeyChecks(TestDbMngr.sakilaKnex);
|
||
|
};
|
||
|
|
||
|
const dropSchemaAndSeedSakila = async () => {
|
||
|
try {
|
||
|
await TestDbMngr.sakilaKnex.raw(`DROP SCHEMA "public" CASCADE`);
|
||
|
await TestDbMngr.sakilaKnex.raw(`CREATE SCHEMA "public"`);
|
||
|
await TestDbMngr.seedSakila();
|
||
|
} catch (e) {
|
||
|
console.error('dropSchemaAndSeedSakila', e);
|
||
|
throw e;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
const resetAndSeedSakila = async () => {
|
||
|
try {
|
||
|
await dropTablesOfSakila();
|
||
|
await TestDbMngr.seedSakila();
|
||
|
} catch (e) {
|
||
|
console.error('resetSakila', e);
|
||
|
throw e;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
const cleanUpSakila = async () => {
|
||
|
try {
|
||
|
const sakilaProject = await Project.getByTitle('sakila');
|
||
|
|
||
|
const audits =
|
||
|
sakilaProject && (await Audit.projectAuditList(sakilaProject.id, {}));
|
||
|
|
||
|
if (audits?.length > 0) {
|
||
|
// if PG, drop schema
|
||
|
if (TestDbMngr.isPg()) {
|
||
|
return await dropSchemaAndSeedSakila();
|
||
|
}
|
||
|
// if mysql, drop tables
|
||
|
return await resetAndSeedSakila();
|
||
|
}
|
||
|
|
||
|
const tablesInSakila = await TestDbMngr.showAllTables(
|
||
|
TestDbMngr.sakilaKnex
|
||
|
);
|
||
|
|
||
|
await Promise.all(
|
||
|
tablesInSakila
|
||
|
.filter((tableName) => !sakilaTableNames.includes(tableName))
|
||
|
.map(async (tableName) => {
|
||
|
try {
|
||
|
if (TestDbMngr.isPg()) {
|
||
|
await TestDbMngr.sakilaKnex.raw(
|
||
|
`DROP TABLE "${tableName}" CASCADE`
|
||
|
);
|
||
|
} else {
|
||
|
await TestDbMngr.sakilaKnex.raw(`DROP TABLE ${tableName}`);
|
||
|
}
|
||
|
} catch (e) {
|
||
|
console.error(e);
|
||
|
}
|
||
|
})
|
||
|
);
|
||
|
} catch (e) {
|
||
|
console.error('cleanUpSakila', e);
|
||
|
}
|
||
|
};
|
||
|
|
||
|
const sakilaTableNames = [
|
||
|
'actor',
|
||
|
'address',
|
||
|
'category',
|
||
|
'city',
|
||
|
'country',
|
||
|
'customer',
|
||
|
'film',
|
||
|
'film_actor',
|
||
|
'film_category',
|
||
|
'inventory',
|
||
|
'language',
|
||
|
'payment',
|
||
|
'payment_p2007_01',
|
||
|
'payment_p2007_02',
|
||
|
'payment_p2007_03',
|
||
|
'payment_p2007_04',
|
||
|
'payment_p2007_05',
|
||
|
'payment_p2007_06',
|
||
|
'rental',
|
||
|
'staff',
|
||
|
'store',
|
||
|
'actor_info',
|
||
|
'customer_list',
|
||
|
'film_list',
|
||
|
'nicer_but_slower_film_list',
|
||
|
'sales_by_film_category',
|
||
|
'sales_by_store',
|
||
|
'staff_list',
|
||
|
];
|
||
|
|
||
|
export { cleanUpSakila, resetAndSeedSakila };
|