mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-06 10:27:28 -08:00
06fa6f1fb3
* 🔧 Adjust base ESLint config * 🔧 Adjust `lint` and `lintfix` in `nodes-base` * 🔧 Include `test` and `utils` in `nodes-base` * 📘 Convert JS tests to TS * 👕 Apply lintfixes
26 lines
966 B
TypeScript
26 lines
966 B
TypeScript
import 'tsconfig-paths/register';
|
|
import { DataSource as Connection } from 'typeorm';
|
|
import config from '@/config';
|
|
import { getBootstrapDBOptions } from './integration/shared/testDb';
|
|
|
|
export default async () => {
|
|
const dbType = config.getEnv('database.type').replace(/db$/, '');
|
|
if (dbType !== 'postgres' && dbType !== 'mysql') return;
|
|
|
|
const connection = new Connection(getBootstrapDBOptions(dbType));
|
|
await connection.initialize();
|
|
|
|
const query =
|
|
dbType === 'postgres' ? 'SELECT datname as "Database" FROM pg_database' : 'SHOW DATABASES';
|
|
const results: Array<{ Database: string }> = await connection.query(query);
|
|
const databases = results
|
|
.filter(
|
|
({ Database: dbName }) => dbName.startsWith(`${dbType}_`) && dbName.endsWith('_n8n_test'),
|
|
)
|
|
.map(({ Database: dbName }) => dbName);
|
|
|
|
const promises = databases.map(async (dbName) => connection.query(`DROP DATABASE ${dbName};`));
|
|
await Promise.all(promises);
|
|
await connection.destroy();
|
|
};
|