2019-12-15 00:27:01 +08:00
|
|
|
import {SQLConnection} from '../src/backend/model/database/sql/SQLConnection';
|
2019-12-10 17:44:35 +08:00
|
|
|
import {Config} from '../src/common/config/private/Config';
|
|
|
|
import {ObjectManagers} from '../src/backend/model/ObjectManagers';
|
|
|
|
import {DiskMangerWorker} from '../src/backend/model/threading/DiskMangerWorker';
|
2019-12-15 00:27:01 +08:00
|
|
|
import {IndexingManager} from '../src/backend/model/database/sql/IndexingManager';
|
|
|
|
import {SearchManager} from '../src/backend/model/database/sql/SearchManager';
|
2019-12-29 16:34:08 +08:00
|
|
|
import * as util from 'util';
|
|
|
|
import * as rimraf from 'rimraf';
|
2019-12-10 17:44:35 +08:00
|
|
|
import {SearchTypes} from '../src/common/entities/AutoCompleteItem';
|
|
|
|
import {Utils} from '../src/common/Utils';
|
2019-12-15 00:27:01 +08:00
|
|
|
import {GalleryManager} from '../src/backend/model/database/sql/GalleryManager';
|
2019-12-10 17:44:35 +08:00
|
|
|
import {DirectoryDTO} from '../src/common/entities/DirectoryDTO';
|
|
|
|
import {ServerConfig} from '../src/common/config/private/IPrivateConfig';
|
2019-01-27 07:03:40 +08:00
|
|
|
|
2019-12-29 16:34:08 +08:00
|
|
|
const rimrafPR = util.promisify(rimraf);
|
|
|
|
|
2019-01-27 07:03:40 +08:00
|
|
|
export interface BenchmarkResult {
|
|
|
|
duration: number;
|
|
|
|
directories?: number;
|
|
|
|
media?: number;
|
|
|
|
items?: number;
|
|
|
|
}
|
|
|
|
|
|
|
|
export class BMIndexingManager extends IndexingManager {
|
|
|
|
|
|
|
|
public async saveToDB(scannedDirectory: DirectoryDTO): Promise<void> {
|
|
|
|
return super.saveToDB(scannedDirectory);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export class Benchmarks {
|
|
|
|
|
2019-12-29 16:34:08 +08:00
|
|
|
constructor(public RUNS: number, public dbFolder: string) {
|
2019-01-27 07:03:40 +08:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
async bmSaveDirectory(): Promise<BenchmarkResult> {
|
|
|
|
await this.resetDB();
|
|
|
|
const dir = await DiskMangerWorker.scanDirectory('./');
|
|
|
|
const im = new BMIndexingManager();
|
|
|
|
return await this.benchmark(() => im.saveToDB(dir), () => this.resetDB());
|
|
|
|
}
|
|
|
|
|
|
|
|
async bmScanDirectory(): Promise<BenchmarkResult> {
|
|
|
|
return await this.benchmark(() => DiskMangerWorker.scanDirectory('./'));
|
|
|
|
}
|
|
|
|
|
|
|
|
async bmListDirectory(): Promise<BenchmarkResult> {
|
|
|
|
const gm = new GalleryManager();
|
|
|
|
await this.setupDB();
|
2019-12-10 16:36:14 +08:00
|
|
|
Config.Server.Indexing.reIndexingSensitivity = ServerConfig.ReIndexingSensitivity.low;
|
2019-01-27 07:03:40 +08:00
|
|
|
return await this.benchmark(() => gm.listDirectory('./'));
|
|
|
|
}
|
|
|
|
|
|
|
|
async bmAllSearch(text: string): Promise<{ result: BenchmarkResult, searchType: SearchTypes }[]> {
|
|
|
|
await this.setupDB();
|
|
|
|
const types = Utils.enumToArray(SearchTypes).map(a => a.key).concat([null]);
|
|
|
|
const results: { result: BenchmarkResult, searchType: SearchTypes }[] = [];
|
|
|
|
const sm = new SearchManager();
|
|
|
|
for (let i = 0; i < types.length; i++) {
|
|
|
|
results.push({result: await this.benchmark(() => sm.search(text, types[i])), searchType: types[i]});
|
|
|
|
}
|
|
|
|
return results;
|
|
|
|
}
|
|
|
|
|
|
|
|
async bmInstantSearch(text: string): Promise<BenchmarkResult> {
|
|
|
|
await this.setupDB();
|
|
|
|
const sm = new SearchManager();
|
|
|
|
return await this.benchmark(() => sm.instantSearch(text));
|
|
|
|
}
|
|
|
|
|
|
|
|
async bmAutocomplete(text: string): Promise<BenchmarkResult> {
|
|
|
|
await this.setupDB();
|
|
|
|
const sm = new SearchManager();
|
|
|
|
return await this.benchmark(() => sm.autocomplete(text));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private async benchmark(fn: () => Promise<{ media: any[], directories: any[] } | any[] | void>,
|
|
|
|
beforeEach: () => Promise<any> = null,
|
|
|
|
afterEach: () => Promise<any> = null) {
|
|
|
|
const scanned = await fn();
|
|
|
|
const start = process.hrtime();
|
|
|
|
let skip = 0;
|
|
|
|
for (let i = 0; i < this.RUNS; i++) {
|
|
|
|
if (beforeEach) {
|
|
|
|
const startSkip = process.hrtime();
|
|
|
|
await beforeEach();
|
|
|
|
const endSkip = process.hrtime(startSkip);
|
2019-01-27 07:28:04 +08:00
|
|
|
skip += (endSkip[0] * 1000 + endSkip[1] / 1000000);
|
2019-01-27 07:03:40 +08:00
|
|
|
}
|
|
|
|
await fn();
|
|
|
|
if (afterEach) {
|
|
|
|
const startSkip = process.hrtime();
|
|
|
|
await afterEach();
|
|
|
|
const endSkip = process.hrtime(startSkip);
|
2019-01-27 07:28:04 +08:00
|
|
|
skip += (endSkip[0] * 1000 + endSkip[1] / 1000000);
|
2019-01-27 07:03:40 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
const end = process.hrtime(start);
|
2019-01-27 07:28:04 +08:00
|
|
|
const duration = (end[0] * 1000 + end[1] / 1000000) / this.RUNS;
|
2019-01-27 07:03:40 +08:00
|
|
|
|
|
|
|
if (!scanned) {
|
|
|
|
return {
|
|
|
|
duration: duration
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Array.isArray(scanned)) {
|
|
|
|
return {
|
|
|
|
duration: duration,
|
|
|
|
items: scanned.length
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
duration: duration,
|
|
|
|
media: scanned.media.length,
|
|
|
|
directories: scanned.directories.length
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
private resetDB = async () => {
|
|
|
|
await SQLConnection.close();
|
2019-12-29 16:34:08 +08:00
|
|
|
await rimrafPR(this.dbFolder);
|
2019-12-10 16:36:14 +08:00
|
|
|
Config.Server.Database.type = ServerConfig.DatabaseType.sqlite;
|
2019-12-29 16:34:08 +08:00
|
|
|
Config.Server.Database.dbFolder = this.dbFolder;
|
2019-02-16 00:47:09 +08:00
|
|
|
await ObjectManagers.InitSQLManagers();
|
2019-01-27 07:03:40 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
private async setupDB() {
|
|
|
|
const im = new BMIndexingManager();
|
|
|
|
await this.resetDB();
|
|
|
|
const dir = await DiskMangerWorker.scanDirectory('./');
|
|
|
|
await im.saveToDB(dir);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|