mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
🧪 Add DB init timeout
This commit is contained in:
parent
de55fdb625
commit
e6347e34ca
|
@ -76,6 +76,11 @@ export const BOOTSTRAP_MYSQL_CONNECTION_NAME: Readonly<string> = 'n8n_bs_mysql';
|
||||||
*/
|
*/
|
||||||
export const SMTP_TEST_TIMEOUT = 30_000;
|
export const SMTP_TEST_TIMEOUT = 30_000;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timeout (in milliseconds) to account for DB being slow to initialize.
|
||||||
|
*/
|
||||||
|
export const DB_INITIALIZATION_TIMEOUT = 30_000;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mapping tables having no entity representation.
|
* Mapping tables having no entity representation.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -8,6 +8,7 @@ import config from '../../../config';
|
||||||
import {
|
import {
|
||||||
BOOTSTRAP_MYSQL_CONNECTION_NAME,
|
BOOTSTRAP_MYSQL_CONNECTION_NAME,
|
||||||
BOOTSTRAP_POSTGRES_CONNECTION_NAME,
|
BOOTSTRAP_POSTGRES_CONNECTION_NAME,
|
||||||
|
DB_INITIALIZATION_TIMEOUT,
|
||||||
MAPPING_TABLES,
|
MAPPING_TABLES,
|
||||||
MAPPING_TABLES_TO_CLEAR,
|
MAPPING_TABLES_TO_CLEAR,
|
||||||
} from './constants';
|
} from './constants';
|
||||||
|
@ -38,6 +39,8 @@ export async function init() {
|
||||||
const dbType = config.getEnv('database.type');
|
const dbType = config.getEnv('database.type');
|
||||||
|
|
||||||
if (dbType === 'sqlite') {
|
if (dbType === 'sqlite') {
|
||||||
|
jest.setTimeout(DB_INITIALIZATION_TIMEOUT);
|
||||||
|
|
||||||
// no bootstrap connection required
|
// no bootstrap connection required
|
||||||
const testDbName = `n8n_test_sqlite_${randomString(6, 10)}_${Date.now()}`;
|
const testDbName = `n8n_test_sqlite_${randomString(6, 10)}_${Date.now()}`;
|
||||||
await Db.init(getSqliteOptions({ name: testDbName }));
|
await Db.init(getSqliteOptions({ name: testDbName }));
|
||||||
|
@ -47,6 +50,8 @@ export async function init() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbType === 'postgresdb') {
|
if (dbType === 'postgresdb') {
|
||||||
|
jest.setTimeout(DB_INITIALIZATION_TIMEOUT);
|
||||||
|
|
||||||
let bootstrapPostgres;
|
let bootstrapPostgres;
|
||||||
const pgOptions = getBootstrapPostgresOptions();
|
const pgOptions = getBootstrapPostgresOptions();
|
||||||
|
|
||||||
|
@ -92,6 +97,8 @@ export async function init() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbType === 'mysqldb') {
|
if (dbType === 'mysqldb') {
|
||||||
|
// initialization timeout in test/setup.ts
|
||||||
|
|
||||||
const bootstrapMysql = await createConnection(getBootstrapMySqlOptions());
|
const bootstrapMysql = await createConnection(getBootstrapMySqlOptions());
|
||||||
|
|
||||||
const testDbName = `mysql_${randomString(6, 10)}_${Date.now()}_n8n_test`;
|
const testDbName = `mysql_${randomString(6, 10)}_${Date.now()}_n8n_test`;
|
||||||
|
@ -147,7 +154,9 @@ async function truncateMappingTables(
|
||||||
|
|
||||||
if (dbType === 'sqlite') {
|
if (dbType === 'sqlite') {
|
||||||
const promises = mappingTables.map((tableName) =>
|
const promises = mappingTables.map((tableName) =>
|
||||||
testDb.query(`DELETE FROM ${tableName}; DELETE FROM sqlite_sequence WHERE name=${tableName};`),
|
testDb.query(
|
||||||
|
`DELETE FROM ${tableName}; DELETE FROM sqlite_sequence WHERE name=${tableName};`,
|
||||||
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
return Promise.all(promises);
|
return Promise.all(promises);
|
||||||
|
|
|
@ -2,7 +2,10 @@ import { exec as callbackExec } from 'child_process';
|
||||||
import { promisify } from 'util';
|
import { promisify } from 'util';
|
||||||
|
|
||||||
import config from '../config';
|
import config from '../config';
|
||||||
import { BOOTSTRAP_MYSQL_CONNECTION_NAME } from './integration/shared/constants';
|
import {
|
||||||
|
BOOTSTRAP_MYSQL_CONNECTION_NAME,
|
||||||
|
DB_INITIALIZATION_TIMEOUT,
|
||||||
|
} from './integration/shared/constants';
|
||||||
|
|
||||||
const exec = promisify(callbackExec);
|
const exec = promisify(callbackExec);
|
||||||
|
|
||||||
|
@ -17,7 +20,7 @@ if (dbType === 'mysqldb') {
|
||||||
|
|
||||||
(async () => {
|
(async () => {
|
||||||
try {
|
try {
|
||||||
jest.setTimeout(30000); // 30 seconds for DB initialization
|
jest.setTimeout(DB_INITIALIZATION_TIMEOUT);
|
||||||
await exec(
|
await exec(
|
||||||
`echo "CREATE DATABASE IF NOT EXISTS ${BOOTSTRAP_MYSQL_CONNECTION_NAME}" | mysql -h ${host} -u ${username} ${passwordSegment}; USE ${BOOTSTRAP_MYSQL_CONNECTION_NAME};`,
|
`echo "CREATE DATABASE IF NOT EXISTS ${BOOTSTRAP_MYSQL_CONNECTION_NAME}" | mysql -h ${host} -u ${username} ${passwordSegment}; USE ${BOOTSTRAP_MYSQL_CONNECTION_NAME};`,
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in a new issue