forked from Cutlery/immich
fix test
This commit is contained in:
parent
649358cbc3
commit
5905fce428
@ -31,7 +31,9 @@ export const libraryApi = {
|
|||||||
expect(status).toBe(204);
|
expect(status).toBe(204);
|
||||||
},
|
},
|
||||||
scanDeletedFiles: async (server: any, accessToken: string, id: string, dto: ScanLibraryDto = {}) => {
|
scanDeletedFiles: async (server: any, accessToken: string, id: string, dto: ScanLibraryDto = {}) => {
|
||||||
const { status } = await request(server).post(`/library/${id}/scan`).set('Authorization', `Bearer ${accessToken}`);
|
const { status } = await request(server)
|
||||||
|
.post(`/library/${id}/scanDeleted`)
|
||||||
|
.set('Authorization', `Bearer ${accessToken}`);
|
||||||
expect(status).toBe(204);
|
expect(status).toBe(204);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -35,41 +35,6 @@ describe(`${LibraryController.name} (e2e)`, () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('POST /library/:id/scan', () => {
|
describe('POST /library/:id/scan', () => {
|
||||||
it('should offline a missing file when called with checkForOffline', async () => {
|
|
||||||
await fs.promises.cp(`${IMMICH_TEST_ASSET_PATH}/albums/nature`, `${IMMICH_TEST_ASSET_TEMP_PATH}/albums/nature`, {
|
|
||||||
recursive: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
const library = await api.libraryApi.create(server, admin.accessToken, {
|
|
||||||
type: LibraryType.EXTERNAL,
|
|
||||||
importPaths: [`${IMMICH_TEST_ASSET_TEMP_PATH}`],
|
|
||||||
});
|
|
||||||
|
|
||||||
await api.libraryApi.scanLibrary(server, admin.accessToken, library.id);
|
|
||||||
|
|
||||||
const onlineAssets = await api.assetApi.getAllAssets(server, admin.accessToken);
|
|
||||||
expect(onlineAssets.length).toBeGreaterThan(1);
|
|
||||||
|
|
||||||
await fs.promises.rm(`${IMMICH_TEST_ASSET_TEMP_PATH}/albums/nature/silver_fir.jpg`);
|
|
||||||
|
|
||||||
await api.libraryApi.scanDeletedFiles(server, admin.accessToken, library.id);
|
|
||||||
|
|
||||||
const assets = await api.assetApi.getAllAssets(server, admin.accessToken);
|
|
||||||
|
|
||||||
expect(assets).toEqual(
|
|
||||||
expect.arrayContaining([
|
|
||||||
expect.objectContaining({
|
|
||||||
isOffline: true,
|
|
||||||
originalFileName: 'silver_fir',
|
|
||||||
}),
|
|
||||||
expect.objectContaining({
|
|
||||||
isOffline: false,
|
|
||||||
originalFileName: 'tanners_ridge',
|
|
||||||
}),
|
|
||||||
]),
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should mark a rediscovered file as back online', async () => {
|
it('should mark a rediscovered file as back online', async () => {
|
||||||
await fs.promises.cp(`${IMMICH_TEST_ASSET_PATH}/albums/nature`, `${IMMICH_TEST_ASSET_TEMP_PATH}/albums/nature`, {
|
await fs.promises.cp(`${IMMICH_TEST_ASSET_PATH}/albums/nature`, `${IMMICH_TEST_ASSET_TEMP_PATH}/albums/nature`, {
|
||||||
recursive: true,
|
recursive: true,
|
||||||
@ -278,6 +243,43 @@ describe(`${LibraryController.name} (e2e)`, () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('POST /library/:id/scanDeleted', () => {
|
||||||
|
it('should offline a missing file', async () => {
|
||||||
|
await fs.promises.cp(`${IMMICH_TEST_ASSET_PATH}/albums/nature`, `${IMMICH_TEST_ASSET_TEMP_PATH}/albums/nature`, {
|
||||||
|
recursive: true,
|
||||||
|
});
|
||||||
|
|
||||||
|
const library = await api.libraryApi.create(server, admin.accessToken, {
|
||||||
|
type: LibraryType.EXTERNAL,
|
||||||
|
importPaths: [`${IMMICH_TEST_ASSET_TEMP_PATH}`],
|
||||||
|
});
|
||||||
|
|
||||||
|
await api.libraryApi.scanLibrary(server, admin.accessToken, library.id);
|
||||||
|
|
||||||
|
const onlineAssets = await api.assetApi.getAllAssets(server, admin.accessToken);
|
||||||
|
expect(onlineAssets.length).toBeGreaterThan(1);
|
||||||
|
|
||||||
|
await fs.promises.rm(`${IMMICH_TEST_ASSET_TEMP_PATH}/albums/nature/silver_fir.jpg`);
|
||||||
|
|
||||||
|
await api.libraryApi.scanDeletedFiles(server, admin.accessToken, library.id);
|
||||||
|
|
||||||
|
const assets = await api.assetApi.getAllAssets(server, admin.accessToken);
|
||||||
|
|
||||||
|
expect(assets).toEqual(
|
||||||
|
expect.arrayContaining([
|
||||||
|
expect.objectContaining({
|
||||||
|
isOffline: true,
|
||||||
|
originalFileName: 'silver_fir',
|
||||||
|
}),
|
||||||
|
expect.objectContaining({
|
||||||
|
isOffline: false,
|
||||||
|
originalFileName: 'tanners_ridge',
|
||||||
|
}),
|
||||||
|
]),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('POST /library/:id/removeOffline', () => {
|
describe('POST /library/:id/removeOffline', () => {
|
||||||
it('should require authentication', async () => {
|
it('should require authentication', async () => {
|
||||||
const { status, body } = await request(server).post(`/library/${uuidStub.notFound}/removeOffline`).send({});
|
const { status, body } = await request(server).post(`/library/${uuidStub.notFound}/removeOffline`).send({});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user