mirror of https://github.com/immich-app/immich.git
refactor(server): e2e (#6632)
parent
4424f3cb13
commit
852effa998
@ -0,0 +1,2 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
NODE_OPTIONS='--experimental-vm-modules' node /usr/src/app/node_modules/.bin/jest --config e2e/$1/jest-e2e.json --runInBand
|
||||||
@ -1,79 +0,0 @@
|
|||||||
import { AssetResponseDto } from '@app/domain';
|
|
||||||
import { CreateAssetDto } from '@app/immich/api-v1/asset/dto/create-asset.dto';
|
|
||||||
import { AssetFileUploadResponseDto } from '@app/immich/api-v1/asset/response-dto/asset-file-upload-response.dto';
|
|
||||||
import { randomBytes } from 'crypto';
|
|
||||||
import request from 'supertest';
|
|
||||||
|
|
||||||
type UploadDto = Partial<CreateAssetDto> & { content?: Buffer };
|
|
||||||
|
|
||||||
const asset = {
|
|
||||||
deviceAssetId: 'test-1',
|
|
||||||
deviceId: 'test',
|
|
||||||
fileCreatedAt: new Date(),
|
|
||||||
fileModifiedAt: new Date(),
|
|
||||||
};
|
|
||||||
|
|
||||||
export const assetApi = {
|
|
||||||
create: async (
|
|
||||||
server: any,
|
|
||||||
accessToken: string,
|
|
||||||
dto?: Omit<CreateAssetDto, 'assetData'>,
|
|
||||||
): Promise<AssetResponseDto> => {
|
|
||||||
dto = dto || asset;
|
|
||||||
const { status, body } = await request(server)
|
|
||||||
.post(`/asset/upload`)
|
|
||||||
.field('deviceAssetId', dto.deviceAssetId)
|
|
||||||
.field('deviceId', dto.deviceId)
|
|
||||||
.field('fileCreatedAt', dto.fileCreatedAt.toISOString())
|
|
||||||
.field('fileModifiedAt', dto.fileModifiedAt.toISOString())
|
|
||||||
.attach('assetData', randomBytes(32), 'example.jpg')
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
|
|
||||||
expect([200, 201].includes(status)).toBe(true);
|
|
||||||
|
|
||||||
return body as AssetResponseDto;
|
|
||||||
},
|
|
||||||
get: async (server: any, accessToken: string, id: string): Promise<AssetResponseDto> => {
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.get(`/asset/assetById/${id}`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body as AssetResponseDto;
|
|
||||||
},
|
|
||||||
getAllAssets: async (server: any, accessToken: string) => {
|
|
||||||
const { body, status } = await request(server).get(`/asset/`).set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body as AssetResponseDto[];
|
|
||||||
},
|
|
||||||
upload: async (server: any, accessToken: string, id: string, dto: UploadDto = {}) => {
|
|
||||||
const { content, isFavorite = false, isArchived = false } = dto;
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.post('/asset/upload')
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`)
|
|
||||||
.field('deviceAssetId', id)
|
|
||||||
.field('deviceId', 'TEST')
|
|
||||||
.field('fileCreatedAt', new Date().toISOString())
|
|
||||||
.field('fileModifiedAt', new Date().toISOString())
|
|
||||||
.field('isFavorite', isFavorite)
|
|
||||||
.field('isArchived', isArchived)
|
|
||||||
.field('duration', '0:00:00.000000')
|
|
||||||
.attach('assetData', content || randomBytes(32), 'example.jpg');
|
|
||||||
|
|
||||||
expect(status).toBe(201);
|
|
||||||
return body as AssetFileUploadResponseDto;
|
|
||||||
},
|
|
||||||
getWebpThumbnail: async (server: any, accessToken: string, assetId: string) => {
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.get(`/asset/thumbnail/${assetId}`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body;
|
|
||||||
},
|
|
||||||
getJpegThumbnail: async (server: any, accessToken: string, assetId: string) => {
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.get(`/asset/thumbnail/${assetId}?format=JPEG`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
@ -1,45 +0,0 @@
|
|||||||
import { AuthDeviceResponseDto, LoginCredentialDto, LoginResponseDto, UserResponseDto } from '@app/domain';
|
|
||||||
import { adminSignupStub, loginResponseStub, loginStub } from '@test';
|
|
||||||
import request from 'supertest';
|
|
||||||
|
|
||||||
export const authApi = {
|
|
||||||
adminSignUp: async (server: any) => {
|
|
||||||
const { status, body } = await request(server).post('/auth/admin-sign-up').send(adminSignupStub);
|
|
||||||
|
|
||||||
expect(status).toBe(201);
|
|
||||||
|
|
||||||
return body as UserResponseDto;
|
|
||||||
},
|
|
||||||
adminLogin: async (server: any) => {
|
|
||||||
const { status, body } = await request(server).post('/auth/login').send(loginStub.admin);
|
|
||||||
|
|
||||||
expect(body).toEqual(loginResponseStub.admin.response);
|
|
||||||
expect(body).toMatchObject({ accessToken: expect.any(String) });
|
|
||||||
expect(status).toBe(201);
|
|
||||||
|
|
||||||
return body as LoginResponseDto;
|
|
||||||
},
|
|
||||||
login: async (server: any, dto: LoginCredentialDto) => {
|
|
||||||
const { status, body } = await request(server).post('/auth/login').send(dto);
|
|
||||||
|
|
||||||
expect(status).toEqual(201);
|
|
||||||
expect(body).toMatchObject({ accessToken: expect.any(String) });
|
|
||||||
|
|
||||||
return body as LoginResponseDto;
|
|
||||||
},
|
|
||||||
getAuthDevices: async (server: any, accessToken: string) => {
|
|
||||||
const { status, body } = await request(server).get('/auth/devices').set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
|
|
||||||
expect(body).toEqual(expect.any(Array));
|
|
||||||
expect(status).toBe(200);
|
|
||||||
|
|
||||||
return body as AuthDeviceResponseDto[];
|
|
||||||
},
|
|
||||||
validateToken: async (server: any, accessToken: string) => {
|
|
||||||
const { status, body } = await request(server)
|
|
||||||
.post('/auth/validateToken')
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(body).toEqual({ authStatus: true });
|
|
||||||
expect(status).toBe(200);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
@ -1,11 +0,0 @@
|
|||||||
import { assetApi } from './asset-api';
|
|
||||||
import { authApi } from './auth-api';
|
|
||||||
import { libraryApi } from './library-api';
|
|
||||||
import { userApi } from './user-api';
|
|
||||||
|
|
||||||
export const api = {
|
|
||||||
authApi,
|
|
||||||
assetApi,
|
|
||||||
libraryApi,
|
|
||||||
userApi,
|
|
||||||
};
|
|
||||||
@ -1,47 +0,0 @@
|
|||||||
import { CreateLibraryDto, LibraryResponseDto, LibraryStatsResponseDto, ScanLibraryDto } from '@app/domain';
|
|
||||||
import request from 'supertest';
|
|
||||||
|
|
||||||
export const libraryApi = {
|
|
||||||
getAll: async (server: any, accessToken: string) => {
|
|
||||||
const { body, status } = await request(server).get(`/library/`).set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body as LibraryResponseDto[];
|
|
||||||
},
|
|
||||||
create: async (server: any, accessToken: string, dto: CreateLibraryDto) => {
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.post(`/library/`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`)
|
|
||||||
.send(dto);
|
|
||||||
expect(status).toBe(201);
|
|
||||||
return body as LibraryResponseDto;
|
|
||||||
},
|
|
||||||
setImportPaths: async (server: any, accessToken: string, id: string, importPaths: string[]) => {
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.put(`/library/${id}`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`)
|
|
||||||
.send({ importPaths });
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body as LibraryResponseDto;
|
|
||||||
},
|
|
||||||
scanLibrary: async (server: any, accessToken: string, id: string, dto: ScanLibraryDto = {}) => {
|
|
||||||
const { status } = await request(server)
|
|
||||||
.post(`/library/${id}/scan`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`)
|
|
||||||
.send(dto);
|
|
||||||
expect(status).toBe(201);
|
|
||||||
},
|
|
||||||
removeOfflineFiles: async (server: any, accessToken: string, id: string) => {
|
|
||||||
const { status } = await request(server)
|
|
||||||
.post(`/library/${id}/removeOffline`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`)
|
|
||||||
.send();
|
|
||||||
expect(status).toBe(201);
|
|
||||||
},
|
|
||||||
getLibraryStatistics: async (server: any, accessToken: string, id: string): Promise<LibraryStatsResponseDto> => {
|
|
||||||
const { body, status } = await request(server)
|
|
||||||
.get(`/library/${id}/statistics`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
expect(status).toBe(200);
|
|
||||||
return body;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
@ -1,50 +0,0 @@
|
|||||||
import { CreateUserDto, UpdateUserDto, UserResponseDto } from '@app/domain';
|
|
||||||
import request from 'supertest';
|
|
||||||
|
|
||||||
export const userApi = {
|
|
||||||
create: async (server: any, accessToken: string, dto: CreateUserDto) => {
|
|
||||||
const { status, body } = await request(server)
|
|
||||||
.post('/user')
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`)
|
|
||||||
.send(dto);
|
|
||||||
|
|
||||||
expect(status).toBe(201);
|
|
||||||
expect(body).toMatchObject({
|
|
||||||
id: expect.any(String),
|
|
||||||
createdAt: expect.any(String),
|
|
||||||
updatedAt: expect.any(String),
|
|
||||||
email: dto.email,
|
|
||||||
});
|
|
||||||
|
|
||||||
return body as UserResponseDto;
|
|
||||||
},
|
|
||||||
get: async (server: any, accessToken: string, id: string) => {
|
|
||||||
const { status, body } = await request(server)
|
|
||||||
.get(`/user/info/${id}`)
|
|
||||||
.set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
|
|
||||||
expect(status).toBe(200);
|
|
||||||
expect(body).toMatchObject({ id });
|
|
||||||
|
|
||||||
return body as UserResponseDto;
|
|
||||||
},
|
|
||||||
update: async (server: any, accessToken: string, dto: UpdateUserDto) => {
|
|
||||||
const { status, body } = await request(server).put('/user').set('Authorization', `Bearer ${accessToken}`).send(dto);
|
|
||||||
|
|
||||||
expect(status).toBe(200);
|
|
||||||
expect(body).toMatchObject({ id: dto.id });
|
|
||||||
|
|
||||||
return body as UserResponseDto;
|
|
||||||
},
|
|
||||||
setExternalPath: async (server: any, accessToken: string, id: string, externalPath: string) => {
|
|
||||||
return await userApi.update(server, accessToken, { id, externalPath });
|
|
||||||
},
|
|
||||||
delete: async (server: any, accessToken: string, id: string) => {
|
|
||||||
const { status, body } = await request(server).delete(`/user/${id}`).set('Authorization', `Bearer ${accessToken}`);
|
|
||||||
|
|
||||||
expect(status).toBe(200);
|
|
||||||
expect(body).toMatchObject({ id, deletedAt: expect.any(String) });
|
|
||||||
|
|
||||||
return body as UserResponseDto;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
Loading…
Reference in New Issue