mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 08:12:33 -04:00 
			
		
		
		
	* fix user icons in album view * revert updateUsersV1 change * fix: UserDto merge issues * fix: update user entity * revert what I thought were merge issues turns out drift cant figure out when it needs to gen a file... * fix removed line * handle defaults for older servers * feat: checkpoint migrations * fix: use parenthesis instead of brackets * Update 1753800911775-ProfileImageCheckpointRemoval.ts * fix: sync stream updateUsersV1
		
			
				
	
	
		
			138 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { Kysely } from 'kysely';
 | |
| import { SyncEntityType, SyncRequestType } from 'src/enum';
 | |
| import { UserRepository } from 'src/repositories/user.repository';
 | |
| import { DB } from 'src/schema';
 | |
| import { SyncTestContext } from 'test/medium.factory';
 | |
| import { getKyselyDB } from 'test/utils';
 | |
| 
 | |
| let defaultDatabase: Kysely<DB>;
 | |
| 
 | |
| const setup = async (db?: Kysely<DB>) => {
 | |
|   const ctx = new SyncTestContext(db || defaultDatabase);
 | |
|   const { auth, user, session } = await ctx.newSyncAuthUser();
 | |
|   return { auth, user, session, ctx };
 | |
| };
 | |
| 
 | |
| beforeAll(async () => {
 | |
|   defaultDatabase = await getKyselyDB();
 | |
| });
 | |
| 
 | |
| describe(SyncEntityType.UserV1, () => {
 | |
|   it('should detect and sync the first user', async () => {
 | |
|     const { auth, ctx } = await setup(await getKyselyDB());
 | |
| 
 | |
|     const userRepo = ctx.get(UserRepository);
 | |
|     const user = await userRepo.get(auth.user.id, { withDeleted: false });
 | |
|     if (!user) {
 | |
|       expect.fail('First user should exist');
 | |
|     }
 | |
| 
 | |
|     const response = await ctx.syncStream(auth, [SyncRequestType.UsersV1]);
 | |
|     expect(response).toHaveLength(1);
 | |
|     expect(response).toEqual([
 | |
|       {
 | |
|         ack: expect.any(String),
 | |
|         data: {
 | |
|           deletedAt: user.deletedAt,
 | |
|           email: user.email,
 | |
|           hasProfileImage: user.profileImagePath !== '',
 | |
|           id: user.id,
 | |
|           name: user.name,
 | |
|           avatarColor: user.avatarColor,
 | |
|           profileChangedAt: user.profileChangedAt.toISOString(),
 | |
|         },
 | |
|         type: 'UserV1',
 | |
|       },
 | |
|     ]);
 | |
| 
 | |
|     await ctx.syncAckAll(auth, response);
 | |
|     await expect(ctx.syncStream(auth, [SyncRequestType.UsersV1])).resolves.toEqual([]);
 | |
|   });
 | |
| 
 | |
|   it('should detect and sync a soft deleted user', async () => {
 | |
|     const { auth, ctx } = await setup(await getKyselyDB());
 | |
| 
 | |
|     const { user: deleted } = await ctx.newUser({ deletedAt: new Date().toISOString() });
 | |
| 
 | |
|     const response = await ctx.syncStream(auth, [SyncRequestType.UsersV1]);
 | |
| 
 | |
|     expect(response).toHaveLength(2);
 | |
|     expect(response).toEqual(
 | |
|       expect.arrayContaining([
 | |
|         {
 | |
|           ack: expect.any(String),
 | |
|           data: expect.objectContaining({ id: auth.user.id }),
 | |
|           type: 'UserV1',
 | |
|         },
 | |
|         {
 | |
|           ack: expect.any(String),
 | |
|           data: expect.objectContaining({ id: deleted.id }),
 | |
|           type: 'UserV1',
 | |
|         },
 | |
|       ]),
 | |
|     );
 | |
| 
 | |
|     await ctx.syncAckAll(auth, response);
 | |
|     await expect(ctx.syncStream(auth, [SyncRequestType.UsersV1])).resolves.toEqual([]);
 | |
|   });
 | |
| 
 | |
|   it('should detect and sync a deleted user', async () => {
 | |
|     const { auth, user: authUser, ctx } = await setup(await getKyselyDB());
 | |
| 
 | |
|     const userRepo = ctx.get(UserRepository);
 | |
| 
 | |
|     const { user } = await ctx.newUser();
 | |
|     await userRepo.delete({ id: user.id }, true);
 | |
| 
 | |
|     const response = await ctx.syncStream(auth, [SyncRequestType.UsersV1]);
 | |
|     expect(response).toHaveLength(2);
 | |
|     expect(response).toEqual([
 | |
|       {
 | |
|         ack: expect.any(String),
 | |
|         data: {
 | |
|           userId: user.id,
 | |
|         },
 | |
|         type: 'UserDeleteV1',
 | |
|       },
 | |
|       {
 | |
|         ack: expect.any(String),
 | |
|         data: expect.objectContaining({ id: authUser.id }),
 | |
|         type: 'UserV1',
 | |
|       },
 | |
|     ]);
 | |
| 
 | |
|     await ctx.syncAckAll(auth, response);
 | |
|     await expect(ctx.syncStream(auth, [SyncRequestType.UsersV1])).resolves.toEqual([]);
 | |
|   });
 | |
| 
 | |
|   it('should sync a user and then an update to that same user', async () => {
 | |
|     const { auth, user, ctx } = await setup(await getKyselyDB());
 | |
| 
 | |
|     const userRepo = ctx.get(UserRepository);
 | |
| 
 | |
|     const response = await ctx.syncStream(auth, [SyncRequestType.UsersV1]);
 | |
|     expect(response).toHaveLength(1);
 | |
|     expect(response).toEqual([
 | |
|       {
 | |
|         ack: expect.any(String),
 | |
|         data: expect.objectContaining({ id: user.id }),
 | |
|         type: 'UserV1',
 | |
|       },
 | |
|     ]);
 | |
| 
 | |
|     await ctx.syncAckAll(auth, response);
 | |
| 
 | |
|     const updated = await userRepo.update(auth.user.id, { name: 'new name' });
 | |
| 
 | |
|     const newResponse = await ctx.syncStream(auth, [SyncRequestType.UsersV1]);
 | |
|     expect(newResponse).toHaveLength(1);
 | |
|     expect(newResponse).toEqual([
 | |
|       {
 | |
|         ack: expect.any(String),
 | |
|         data: expect.objectContaining({ id: user.id, name: updated.name }),
 | |
|         type: 'UserV1',
 | |
|       },
 | |
|     ]);
 | |
|   });
 | |
| });
 |