2021-05-28 19:21:18 +02:00
|
|
|
import {DBTestHelper} from '../../../DBTestHelper';
|
2023-01-05 23:11:58 +01:00
|
|
|
import {ParentDirectoryDTO} from '../../../../../src/common/entities/DirectoryDTO';
|
2021-05-28 19:21:18 +02:00
|
|
|
import {ObjectManagers} from '../../../../../src/backend/model/ObjectManagers';
|
2023-01-05 23:11:58 +01:00
|
|
|
import {AlbumManager} from '../../../../../src/backend/model/database/AlbumManager';
|
2021-05-28 19:21:18 +02:00
|
|
|
import {SearchQueryTypes, TextSearch} from '../../../../../src/common/entities/SearchQueryDTO';
|
2023-01-05 23:11:58 +01:00
|
|
|
import {SQLConnection} from '../../../../../src/backend/model/database/SQLConnection';
|
|
|
|
import {AlbumBaseEntity} from '../../../../../src/backend/model/database/enitites/album/AlbumBaseEntity';
|
2021-05-28 19:21:18 +02:00
|
|
|
import {Utils} from '../../../../../src/common/Utils';
|
|
|
|
import {MediaDTO} from '../../../../../src/common/entities/MediaDTO';
|
2021-05-29 23:27:52 +02:00
|
|
|
import {SavedSearchDTO} from '../../../../../src/common/entities/album/SavedSearchDTO';
|
2021-05-28 19:21:18 +02:00
|
|
|
|
|
|
|
|
2022-12-04 22:23:51 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
2021-05-28 19:21:18 +02:00
|
|
|
const deepEqualInAnyOrder = require('deep-equal-in-any-order');
|
2022-12-04 22:23:51 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
2021-05-28 19:21:18 +02:00
|
|
|
const chai = require('chai');
|
|
|
|
|
|
|
|
chai.use(deepEqualInAnyOrder);
|
|
|
|
const {expect} = chai;
|
|
|
|
|
|
|
|
// to help WebStorm to handle the test cases
|
|
|
|
declare let describe: any;
|
|
|
|
declare const after: any;
|
|
|
|
declare const before: any;
|
|
|
|
const tmpDescribe = describe;
|
|
|
|
describe = DBTestHelper.describe(); // fake it os IDE plays nicely (recognize the test)
|
|
|
|
|
|
|
|
|
|
|
|
describe('AlbumManager', (sqlHelper: DBTestHelper) => {
|
|
|
|
describe = tmpDescribe;
|
2022-01-14 20:57:20 +01:00
|
|
|
|
|
|
|
|
2021-05-28 19:21:18 +02:00
|
|
|
const setUpSqlDB = async () => {
|
|
|
|
await sqlHelper.initDB();
|
2022-01-14 20:57:20 +01:00
|
|
|
await sqlHelper.setUpTestGallery();
|
2021-05-28 19:21:18 +02:00
|
|
|
await ObjectManagers.InitSQLManagers();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2023-08-25 21:24:05 +02:00
|
|
|
const toAlbumCover = (m: MediaDTO): MediaDTO => {
|
2021-06-27 19:33:37 +02:00
|
|
|
// generated dirs for test contain everything, not like return values from the server.
|
|
|
|
const tmpDir: ParentDirectoryDTO = m.directory as ParentDirectoryDTO;
|
|
|
|
const tmpM = tmpDir.media;
|
|
|
|
const tmpD = tmpDir.directories;
|
2023-08-25 21:24:05 +02:00
|
|
|
const tmpP = tmpDir.cover;
|
2021-06-27 19:33:37 +02:00
|
|
|
const tmpMT = tmpDir.metaFile;
|
|
|
|
delete tmpDir.directories;
|
|
|
|
delete tmpDir.media;
|
2023-08-25 21:24:05 +02:00
|
|
|
delete tmpDir.cover;
|
2021-06-27 19:33:37 +02:00
|
|
|
delete tmpDir.metaFile;
|
2021-05-28 19:21:18 +02:00
|
|
|
const ret = Utils.clone(m);
|
2021-07-06 21:37:19 +02:00
|
|
|
delete ret.id;
|
|
|
|
ret.directory = {path: ret.directory.path, name: ret.directory.name};
|
|
|
|
delete ret.metadata;
|
2021-06-27 19:33:37 +02:00
|
|
|
tmpDir.directories = tmpD;
|
|
|
|
tmpDir.media = tmpM;
|
2023-08-25 21:24:05 +02:00
|
|
|
tmpDir.cover = tmpP;
|
2021-06-27 19:33:37 +02:00
|
|
|
tmpDir.metaFile = tmpMT;
|
2021-05-28 19:21:18 +02:00
|
|
|
return ret;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
before(setUpSqlDB);
|
|
|
|
after(sqlHelper.clearDB);
|
|
|
|
|
|
|
|
describe('Saved search', () => {
|
|
|
|
|
|
|
|
|
|
|
|
beforeEach(setUpSqlDB);
|
|
|
|
afterEach(sqlHelper.clearDB);
|
|
|
|
|
|
|
|
it('should add album', async () => {
|
|
|
|
const am = new AlbumManager();
|
|
|
|
const connection = await SQLConnection.getConnection();
|
|
|
|
|
|
|
|
const query: TextSearch = {text: 'test', type: SearchQueryTypes.any_text};
|
|
|
|
|
|
|
|
expect(await connection.getRepository(AlbumBaseEntity).find()).to.deep.equalInAnyOrder([]);
|
|
|
|
|
|
|
|
await am.addSavedSearch('Test Album', Utils.clone(query));
|
|
|
|
|
|
|
|
expect(await connection.getRepository(AlbumBaseEntity).find()).to.deep.equalInAnyOrder([{
|
|
|
|
id: 1,
|
|
|
|
name: 'Test Album',
|
2021-05-29 23:27:52 +02:00
|
|
|
locked: false,
|
2021-05-31 19:55:27 +02:00
|
|
|
count: 0,
|
2021-05-28 19:21:18 +02:00
|
|
|
searchQuery: query
|
2021-05-29 23:27:52 +02:00
|
|
|
} as SavedSearchDTO]);
|
2021-05-28 19:21:18 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should delete album', async () => {
|
|
|
|
const am = new AlbumManager();
|
|
|
|
const connection = await SQLConnection.getConnection();
|
|
|
|
|
|
|
|
const query: TextSearch = {text: 'test', type: SearchQueryTypes.any_text};
|
|
|
|
|
|
|
|
|
|
|
|
await am.addSavedSearch('Test Album', Utils.clone(query));
|
2021-05-29 23:27:52 +02:00
|
|
|
await am.addSavedSearch('Test Album2', Utils.clone(query), true);
|
2021-05-28 19:21:18 +02:00
|
|
|
|
|
|
|
expect(await connection.getRepository(AlbumBaseEntity).find()).to.deep.equalInAnyOrder([
|
|
|
|
{
|
|
|
|
id: 1,
|
|
|
|
name: 'Test Album',
|
2021-05-29 23:27:52 +02:00
|
|
|
locked: false,
|
2021-05-31 19:55:27 +02:00
|
|
|
count: 0,
|
2021-05-28 19:21:18 +02:00
|
|
|
searchQuery: query
|
2021-05-29 23:27:52 +02:00
|
|
|
} as SavedSearchDTO,
|
2021-05-28 19:21:18 +02:00
|
|
|
{
|
|
|
|
id: 2,
|
|
|
|
name: 'Test Album2',
|
2021-05-29 23:27:52 +02:00
|
|
|
locked: true,
|
2021-05-31 19:55:27 +02:00
|
|
|
count: 0,
|
2021-05-28 19:21:18 +02:00
|
|
|
searchQuery: query
|
2021-05-29 23:27:52 +02:00
|
|
|
} as SavedSearchDTO]);
|
2021-05-28 19:21:18 +02:00
|
|
|
|
|
|
|
await am.deleteAlbum(1);
|
|
|
|
expect(await connection.getRepository(AlbumBaseEntity).find()).to.deep.equalInAnyOrder([{
|
|
|
|
id: 2,
|
|
|
|
name: 'Test Album2',
|
2021-05-29 23:27:52 +02:00
|
|
|
locked: true,
|
2021-05-31 19:55:27 +02:00
|
|
|
count: 0,
|
2021-05-28 19:21:18 +02:00
|
|
|
searchQuery: query
|
2021-05-29 23:27:52 +02:00
|
|
|
} as SavedSearchDTO]);
|
|
|
|
|
|
|
|
try {
|
|
|
|
await am.deleteAlbum(2);
|
|
|
|
expect(false).to.be.equal(true); // should not reach
|
|
|
|
} catch (e) {
|
|
|
|
expect(e.message).to.equal('Could not delete album, id:2');
|
|
|
|
}
|
|
|
|
expect(await connection.getRepository(AlbumBaseEntity).find()).to.deep.equalInAnyOrder([{
|
|
|
|
id: 2,
|
|
|
|
name: 'Test Album2',
|
|
|
|
locked: true,
|
2021-05-31 19:55:27 +02:00
|
|
|
count: 0,
|
2021-05-29 23:27:52 +02:00
|
|
|
searchQuery: query
|
|
|
|
} as SavedSearchDTO]);
|
2021-05-28 19:21:18 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should list album', async () => {
|
|
|
|
const am = new AlbumManager();
|
|
|
|
|
|
|
|
const query: TextSearch = {text: 'photo1', type: SearchQueryTypes.any_text};
|
|
|
|
|
|
|
|
await am.addSavedSearch('Test Album', Utils.clone(query));
|
|
|
|
|
|
|
|
expect(await am.getAlbums()).to.deep.equalInAnyOrder(([{
|
|
|
|
id: 1,
|
|
|
|
name: 'Test Album',
|
|
|
|
searchQuery: query,
|
2021-05-29 23:27:52 +02:00
|
|
|
locked: false,
|
2021-05-31 19:55:27 +02:00
|
|
|
count: 1,
|
2023-08-25 21:24:05 +02:00
|
|
|
cover: toAlbumCover(sqlHelper.testGalleyEntities.p)
|
2021-05-29 23:27:52 +02:00
|
|
|
} as SavedSearchDTO]));
|
2021-05-28 19:21:18 +02:00
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
});
|