2019-01-27 14:36:42 -05:00
|
|
|
import {Config} from '../../common/config/private/Config';
|
|
|
|
import {DatabaseType} from '../../common/config/private/IPrivateConfig';
|
|
|
|
import * as fs from 'fs';
|
|
|
|
import * as path from 'path';
|
|
|
|
import {SQLConnection} from '../../backend/model/sql/SQLConnection';
|
|
|
|
|
|
|
|
declare let describe: any;
|
|
|
|
const savedDescribe = describe;
|
|
|
|
|
|
|
|
export class SQLTestHelper {
|
|
|
|
|
|
|
|
static enable = {
|
|
|
|
sqlite: true,
|
|
|
|
mysql: true
|
|
|
|
};
|
|
|
|
public static readonly savedDescribe = savedDescribe;
|
|
|
|
tempDir: string;
|
|
|
|
dbPath: string;
|
|
|
|
|
|
|
|
constructor(public dbType: DatabaseType) {
|
2019-02-22 23:39:01 +01:00
|
|
|
this.tempDir = path.join(__dirname, './tmp');
|
|
|
|
this.dbPath = path.join(__dirname, './tmp', 'test.db');
|
2019-01-27 14:36:42 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static describe(name: string, tests: (helper?: SQLTestHelper) => void) {
|
|
|
|
savedDescribe(name, async () => {
|
|
|
|
if (SQLTestHelper.enable.sqlite) {
|
|
|
|
const helper = new SQLTestHelper(DatabaseType.sqlite);
|
|
|
|
savedDescribe('sqlite', () => {
|
|
|
|
return tests(helper);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if (SQLTestHelper.enable.mysql) {
|
|
|
|
const helper = new SQLTestHelper(DatabaseType.mysql);
|
|
|
|
savedDescribe('mysql', function () {
|
|
|
|
this.timeout(99999999);
|
|
|
|
// @ts-ignore
|
|
|
|
return tests(helper);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
public async initDB() {
|
|
|
|
if (this.dbType === DatabaseType.sqlite) {
|
|
|
|
await this.initSQLite();
|
|
|
|
} else {
|
|
|
|
await this.initMySQL();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public async clearDB() {
|
|
|
|
if (this.dbType === DatabaseType.sqlite) {
|
|
|
|
await this.clearUpSQLite();
|
|
|
|
} else {
|
|
|
|
await this.clearUpMysql();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private async initSQLite() {
|
|
|
|
await this.resetSQLite();
|
|
|
|
|
|
|
|
Config.Server.database.type = DatabaseType.sqlite;
|
|
|
|
Config.Server.database.sqlite.storage = this.dbPath;
|
|
|
|
}
|
|
|
|
|
|
|
|
private async initMySQL() {
|
|
|
|
Config.Server.database.type = DatabaseType.mysql;
|
|
|
|
Config.Server.database.mysql.database = 'pigallery2_test';
|
|
|
|
|
|
|
|
await this.resetMySQL();
|
|
|
|
}
|
|
|
|
|
|
|
|
private async resetSQLite() {
|
|
|
|
await SQLConnection.close();
|
|
|
|
|
|
|
|
if (fs.existsSync(this.dbPath)) {
|
|
|
|
fs.unlinkSync(this.dbPath);
|
|
|
|
}
|
|
|
|
if (fs.existsSync(this.tempDir)) {
|
|
|
|
fs.rmdirSync(this.tempDir);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private async resetMySQL() {
|
|
|
|
Config.Server.database.type = DatabaseType.mysql;
|
|
|
|
Config.Server.database.mysql.database = 'pigallery2_test';
|
|
|
|
const conn = await SQLConnection.getConnection();
|
|
|
|
await conn.query('DROP DATABASE IF EXISTS ' + conn.options.database);
|
|
|
|
await conn.query('CREATE DATABASE IF NOT EXISTS ' + conn.options.database);
|
|
|
|
await SQLConnection.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
private async clearUpMysql() {
|
|
|
|
Config.Server.database.type = DatabaseType.mysql;
|
|
|
|
Config.Server.database.mysql.database = 'pigallery2_test';
|
|
|
|
const conn = await SQLConnection.getConnection();
|
|
|
|
await conn.query('DROP DATABASE IF EXISTS ' + conn.options.database);
|
|
|
|
await SQLConnection.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
private async clearUpSQLite() {
|
|
|
|
return this.resetSQLite();
|
|
|
|
}
|
|
|
|
}
|