2024-01-26 17:48:37 +01:00
|
|
|
import { BadRequestException } from '@nestjs/common';
|
2024-03-21 12:59:49 +01:00
|
|
|
import { IAssetRepository } from 'src/interfaces/asset.interface';
|
2024-03-22 23:24:02 +01:00
|
|
|
import { ClientEvent, IEventRepository } from 'src/interfaces/event.interface';
|
2024-03-21 12:59:49 +01:00
|
|
|
import { IJobRepository, JobName } from 'src/interfaces/job.interface';
|
2024-03-21 00:07:30 +01:00
|
|
|
import { TrashService } from 'src/services/trash.service';
|
2024-03-20 19:32:04 +01:00
|
|
|
import { assetStub } from 'test/fixtures/asset.stub';
|
|
|
|
import { authStub } from 'test/fixtures/auth.stub';
|
|
|
|
import { IAccessRepositoryMock, newAccessRepositoryMock } from 'test/repositories/access.repository.mock';
|
|
|
|
import { newAssetRepositoryMock } from 'test/repositories/asset.repository.mock';
|
2024-03-22 23:24:02 +01:00
|
|
|
import { newEventRepositoryMock } from 'test/repositories/event.repository.mock';
|
2024-03-20 19:32:04 +01:00
|
|
|
import { newJobRepositoryMock } from 'test/repositories/job.repository.mock';
|
2024-04-16 16:44:45 +02:00
|
|
|
import { Mocked } from 'vitest';
|
2024-01-26 17:48:37 +01:00
|
|
|
|
|
|
|
describe(TrashService.name, () => {
|
|
|
|
let sut: TrashService;
|
|
|
|
let accessMock: IAccessRepositoryMock;
|
2024-04-16 16:44:45 +02:00
|
|
|
let assetMock: Mocked<IAssetRepository>;
|
|
|
|
let jobMock: Mocked<IJobRepository>;
|
|
|
|
let eventMock: Mocked<IEventRepository>;
|
2024-01-26 17:48:37 +01:00
|
|
|
|
|
|
|
it('should work', () => {
|
|
|
|
expect(sut).toBeDefined();
|
|
|
|
});
|
|
|
|
|
2024-03-05 23:23:06 +01:00
|
|
|
beforeEach(() => {
|
2024-01-26 17:48:37 +01:00
|
|
|
accessMock = newAccessRepositoryMock();
|
|
|
|
assetMock = newAssetRepositoryMock();
|
2024-03-22 23:24:02 +01:00
|
|
|
eventMock = newEventRepositoryMock();
|
2024-01-26 17:48:37 +01:00
|
|
|
jobMock = newJobRepositoryMock();
|
|
|
|
|
2024-03-22 23:24:02 +01:00
|
|
|
sut = new TrashService(accessMock, assetMock, jobMock, eventMock);
|
2024-01-26 17:48:37 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('restoreAssets', () => {
|
|
|
|
it('should require asset restore access for all ids', async () => {
|
|
|
|
await expect(
|
|
|
|
sut.restoreAssets(authStub.user1, {
|
|
|
|
ids: ['asset-1'],
|
|
|
|
}),
|
|
|
|
).rejects.toBeInstanceOf(BadRequestException);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should restore a batch of assets', async () => {
|
|
|
|
accessMock.asset.checkOwnerAccess.mockResolvedValue(new Set(['asset1', 'asset2']));
|
|
|
|
|
|
|
|
await sut.restoreAssets(authStub.user1, { ids: ['asset1', 'asset2'] });
|
|
|
|
|
|
|
|
expect(assetMock.restoreAll).toHaveBeenCalledWith(['asset1', 'asset2']);
|
|
|
|
expect(jobMock.queue.mock.calls).toEqual([]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('restore', () => {
|
|
|
|
it('should handle an empty trash', async () => {
|
|
|
|
assetMock.getByUserId.mockResolvedValue({ items: [], hasNextPage: false });
|
|
|
|
await expect(sut.restore(authStub.user1)).resolves.toBeUndefined();
|
|
|
|
expect(assetMock.restoreAll).not.toHaveBeenCalled();
|
2024-03-22 23:24:02 +01:00
|
|
|
expect(eventMock.clientSend).not.toHaveBeenCalled();
|
2024-01-26 17:48:37 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should restore and notify', async () => {
|
|
|
|
assetMock.getByUserId.mockResolvedValue({ items: [assetStub.image], hasNextPage: false });
|
|
|
|
await expect(sut.restore(authStub.user1)).resolves.toBeUndefined();
|
|
|
|
expect(assetMock.restoreAll).toHaveBeenCalledWith([assetStub.image.id]);
|
2024-03-22 23:24:02 +01:00
|
|
|
expect(eventMock.clientSend).toHaveBeenCalledWith(ClientEvent.ASSET_RESTORE, authStub.user1.user.id, [
|
2024-01-26 17:48:37 +01:00
|
|
|
assetStub.image.id,
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('empty', () => {
|
|
|
|
it('should handle an empty trash', async () => {
|
|
|
|
assetMock.getByUserId.mockResolvedValue({ items: [], hasNextPage: false });
|
|
|
|
await expect(sut.empty(authStub.user1)).resolves.toBeUndefined();
|
|
|
|
expect(jobMock.queueAll).toHaveBeenCalledWith([]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should empty the trash', async () => {
|
|
|
|
assetMock.getByUserId.mockResolvedValue({ items: [assetStub.image], hasNextPage: false });
|
|
|
|
await expect(sut.empty(authStub.user1)).resolves.toBeUndefined();
|
|
|
|
expect(jobMock.queueAll).toHaveBeenCalledWith([
|
2024-06-10 19:04:34 +02:00
|
|
|
{ name: JobName.ASSET_DELETION, data: { id: assetStub.image.id, deleteOnDisk: true } },
|
2024-01-26 17:48:37 +01:00
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|