mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-24 20:24:05 -08:00
27 lines
1,009 B
TypeScript
27 lines
1,009 B
TypeScript
import 'tsconfig-paths/register';
|
|
import { Container } from 'typedi';
|
|
import { GlobalConfig } from '@n8n/config';
|
|
import { DataSource as Connection } from '@n8n/typeorm';
|
|
import { getBootstrapDBOptions, testDbPrefix } from './integration/shared/testDb';
|
|
|
|
export default async () => {
|
|
const { type: dbType } = Container.get(GlobalConfig).database;
|
|
if (dbType !== 'postgresdb' && dbType !== 'mysqldb') return;
|
|
|
|
const connection = new Connection(getBootstrapDBOptions(dbType));
|
|
await connection.initialize();
|
|
|
|
const query =
|
|
dbType === 'postgresdb' ? '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(testDbPrefix))
|
|
.map(({ Database: dbName }) => dbName);
|
|
|
|
const promises = databases.map(
|
|
async (dbName) => await connection.query(`DROP DATABASE ${dbName};`),
|
|
);
|
|
await Promise.all(promises);
|
|
await connection.destroy();
|
|
};
|