1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-04 02:46:47 +01:00

Fix e2e tests (#1321)

* Fix e2e tests

* Enable e2e tests in CI

* Remove unnecessary TypeOrmModule from e2e tests
This commit is contained in:
Jaime Baez 2023-01-15 20:08:24 +01:00 committed by GitHub
parent e9fda40b2b
commit 036d0556a4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 55 additions and 46 deletions

View file

@ -6,17 +6,17 @@ on:
branches: [main] branches: [main]
jobs: jobs:
# e2e-tests: e2e-tests:
# name: Run end-to-end test suites name: Run end-to-end test suites
# runs-on: ubuntu-latest runs-on: ubuntu-latest
# steps: steps:
# - name: Checkout code - name: Checkout code
# uses: actions/checkout@v3 uses: actions/checkout@v3
# - name: Run Immich Server E2E Test - name: Run Immich Server E2E Test
# run: docker-compose -f ./docker/docker-compose.test.yml --env-file ./docker/.env.test up --abort-on-container-exit --exit-code-from immich-server-test run: docker-compose -f ./docker/docker-compose.test.yml --env-file ./docker/.env.test up --abort-on-container-exit --exit-code-from immich-server-test
server-unit-tests: server-unit-tests:
name: Run server unit test suites and checks name: Run server unit test suites and checks

View file

@ -26,7 +26,6 @@ const ASSET_REPOSITORY_PROVIDER = {
CommunicationModule, CommunicationModule,
BackgroundTaskModule, BackgroundTaskModule,
DownloadModule, DownloadModule,
AlbumModule,
TagModule, TagModule,
StorageModule, StorageModule,
forwardRef(() => AlbumModule), forwardRef(() => AlbumModule),

View file

@ -1,15 +1,16 @@
import { Test, TestingModule } from '@nestjs/testing'; import { Test, TestingModule } from '@nestjs/testing';
import { INestApplication } from '@nestjs/common'; import { INestApplication } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';
import request from 'supertest'; import request from 'supertest';
import { clearDb, getAuthUser, authCustom } from './test-utils'; import { clearDb, getAuthUser, authCustom } from './test-utils';
import { databaseConfig } from '@app/infra'; import { InfraModule } from '@app/infra';
import { AlbumModule } from '../src/api-v1/album/album.module'; import { AlbumModule } from '../src/api-v1/album/album.module';
import { CreateAlbumDto } from '../src/api-v1/album/dto/create-album.dto'; import { CreateAlbumDto } from '../src/api-v1/album/dto/create-album.dto';
import { ImmichJwtModule } from '../src/modules/immich-jwt/immich-jwt.module'; import { ImmichJwtModule } from '../src/modules/immich-jwt/immich-jwt.module';
import { AuthUserDto } from '../src/decorators/auth-user.decorator'; import { AuthUserDto } from '../src/decorators/auth-user.decorator';
import { UserService } from '@app/domain'; import { DomainModule, UserService } from '@app/domain';
import { DataSource } from 'typeorm'; import { DataSource } from 'typeorm';
import { AuthService } from '../src/api-v1/auth/auth.service';
import { AuthModule } from '../src/api-v1/auth/auth.module';
function _createAlbum(app: INestApplication, data: CreateAlbumDto) { function _createAlbum(app: INestApplication, data: CreateAlbumDto) {
return request(app.getHttpServer()).post('/album').send(data); return request(app.getHttpServer()).post('/album').send(data);
@ -19,15 +20,10 @@ describe('Album', () => {
let app: INestApplication; let app: INestApplication;
let database: DataSource; let database: DataSource;
afterAll(async () => {
await clearDb(database);
await app.close();
});
describe('without auth', () => { describe('without auth', () => {
beforeAll(async () => { beforeAll(async () => {
const moduleFixture: TestingModule = await Test.createTestingModule({ const moduleFixture: TestingModule = await Test.createTestingModule({
imports: [AlbumModule, ImmichJwtModule, TypeOrmModule.forRoot(databaseConfig)], imports: [DomainModule.register({ imports: [InfraModule] }), AlbumModule, ImmichJwtModule],
}).compile(); }).compile();
app = moduleFixture.createNestApplication(); app = moduleFixture.createNestApplication();
@ -36,6 +32,7 @@ describe('Album', () => {
}); });
afterAll(async () => { afterAll(async () => {
await clearDb(database);
await app.close(); await app.close();
}); });
@ -48,21 +45,27 @@ describe('Album', () => {
describe('with auth', () => { describe('with auth', () => {
let authUser: AuthUserDto; let authUser: AuthUserDto;
let userService: UserService; let userService: UserService;
let authService: AuthService;
beforeAll(async () => { beforeAll(async () => {
const builder = Test.createTestingModule({ const builder = Test.createTestingModule({
imports: [AlbumModule, TypeOrmModule.forRoot(databaseConfig)], imports: [DomainModule.register({ imports: [InfraModule] }), AuthModule, AlbumModule],
}); });
authUser = getAuthUser(); // set default auth user authUser = getAuthUser(); // set default auth user
const moduleFixture: TestingModule = await authCustom(builder, () => authUser).compile(); const moduleFixture: TestingModule = await authCustom(builder, () => authUser).compile();
app = moduleFixture.createNestApplication(); app = moduleFixture.createNestApplication();
userService = app.get(UserService); userService = app.get(UserService);
authService = app.get(AuthService);
database = app.get(DataSource); database = app.get(DataSource);
await app.init(); await app.init();
}); });
afterAll(async () => {
await app.close();
});
describe('with empty DB', () => { describe('with empty DB', () => {
afterEach(async () => { afterEach(async () => {
await clearDb(database); await clearDb(database);
@ -93,22 +96,21 @@ describe('Album', () => {
beforeAll(async () => { beforeAll(async () => {
// setup users // setup users
const result = await Promise.all([ const adminSignUpDto = await authService.adminSignUp({
userService.createUser({
email: 'one@test.com', email: 'one@test.com',
password: '1234', password: '1234',
firstName: 'one', firstName: 'one',
lastName: 'test', lastName: 'test',
}), });
userService.createUser({ userOne = { ...adminSignUpDto, isAdmin: true }; // TODO: find out why adminSignUp doesn't have isAdmin (maybe can just return UserResponseDto)
userTwo = await userService.createUser({
email: 'two@test.com', email: 'two@test.com',
password: '1234', password: '1234',
firstName: 'two', firstName: 'two',
lastName: 'test', lastName: 'test',
}), });
]);
userOne = result[0];
userTwo = result[1];
// add user one albums // add user one albums
authUser = userOne; authUser = userOne;
await Promise.all([ await Promise.all([
@ -125,6 +127,10 @@ describe('Album', () => {
authUser = userOne; authUser = userOne;
}); });
afterAll(async () => {
await clearDb(database);
});
it('returns the album collection including owned and shared', async () => { it('returns the album collection including owned and shared', async () => {
const { status, body } = await request(app.getHttpServer()).get('/album'); const { status, body } = await request(app.getHttpServer()).get('/album');
expect(status).toEqual(200); expect(status).toEqual(200);

View file

@ -1,14 +1,16 @@
import { Test, TestingModule } from '@nestjs/testing'; import { Test, TestingModule } from '@nestjs/testing';
import { INestApplication } from '@nestjs/common'; import { INestApplication } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';
import request from 'supertest'; import request from 'supertest';
import { clearDb, authCustom } from './test-utils'; import { clearDb, authCustom } from './test-utils';
import { databaseConfig } from '@app/infra'; import { InfraModule } from '@app/infra';
import { ImmichJwtModule } from '../src/modules/immich-jwt/immich-jwt.module'; import { ImmichJwtModule } from '../src/modules/immich-jwt/immich-jwt.module';
import { CreateAdminDto, CreateUserDto, UserResponseDto, UserService } from '@app/domain'; import { DomainModule, CreateUserDto, UserService, AuthUserDto } from '@app/domain';
import { DataSource } from 'typeorm'; import { DataSource } from 'typeorm';
import { UserController } from '../src/controllers';
import { AuthModule } from '../src/api-v1/auth/auth.module';
import { AuthService } from '../src/api-v1/auth/auth.service';
function _createUser(userService: UserService, data: CreateUserDto | CreateAdminDto) { function _createUser(userService: UserService, data: CreateUserDto) {
return userService.createUser(data); return userService.createUser(data);
} }
@ -24,7 +26,8 @@ describe('User', () => {
describe('without auth', () => { describe('without auth', () => {
beforeAll(async () => { beforeAll(async () => {
const moduleFixture: TestingModule = await Test.createTestingModule({ const moduleFixture: TestingModule = await Test.createTestingModule({
imports: [ImmichJwtModule, TypeOrmModule.forRoot(databaseConfig)], imports: [DomainModule.register({ imports: [InfraModule] }), ImmichJwtModule],
controllers: [UserController],
}).compile(); }).compile();
app = moduleFixture.createNestApplication(); app = moduleFixture.createNestApplication();
@ -44,16 +47,19 @@ describe('User', () => {
describe('with auth', () => { describe('with auth', () => {
let userService: UserService; let userService: UserService;
let authUser: UserResponseDto; let authService: AuthService;
let authUser: AuthUserDto;
beforeAll(async () => { beforeAll(async () => {
const builder = Test.createTestingModule({ const builder = Test.createTestingModule({
imports: [TypeOrmModule.forRoot(databaseConfig)], imports: [DomainModule.register({ imports: [InfraModule] }), AuthModule],
controllers: [UserController],
}); });
const moduleFixture: TestingModule = await authCustom(builder, () => authUser).compile(); const moduleFixture: TestingModule = await authCustom(builder, () => authUser).compile();
app = moduleFixture.createNestApplication(); app = moduleFixture.createNestApplication();
userService = app.get(UserService); userService = app.get(UserService);
authService = app.get(AuthService);
database = app.get(DataSource); database = app.get(DataSource);
await app.init(); await app.init();
}); });
@ -65,13 +71,13 @@ describe('User', () => {
beforeAll(async () => { beforeAll(async () => {
// first user must be admin // first user must be admin
authUser = await _createUser(userService, { const adminSignupResponseDto = await authService.adminSignUp({
firstName: 'auth-user', firstName: 'auth-user',
lastName: 'test', lastName: 'test',
email: authUserEmail, email: authUserEmail,
password: '1234', password: '1234',
isAdmin: true,
}); });
authUser = { ...adminSignupResponseDto, isAdmin: true }; // TODO: find out why adminSignUp doesn't have isAdmin (maybe can just return UserResponseDto)
await Promise.allSettled([ await Promise.allSettled([
_createUser(userService, { _createUser(userService, {
firstName: 'one', firstName: 'one',

View file

@ -18,8 +18,6 @@
"paths": { "paths": {
"@app/common": ["libs/common/src"], "@app/common": ["libs/common/src"],
"@app/common/*": ["libs/common/src/*"], "@app/common/*": ["libs/common/src/*"],
"@app/infra": ["libs/database/src"],
"@app/infra/*": ["libs/database/src/*"],
"@app/job": ["libs/job/src"], "@app/job": ["libs/job/src"],
"@app/job/*": ["libs/job/src/*"], "@app/job/*": ["libs/job/src/*"],
"@app/immich-config": ["libs/immich-config/src"], "@app/immich-config": ["libs/immich-config/src"],