user deleted message handler
This commit is contained in:
parent
85746fde48
commit
ced57e35a6
|
@ -26,6 +26,7 @@ import { UpdatePasswordService } from './core/application/commands/update-passwo
|
||||||
import { ValidateAuthenticationGrpcController } from './interface/grpc-controllers/validate-authentication.grpc.controller';
|
import { ValidateAuthenticationGrpcController } from './interface/grpc-controllers/validate-authentication.grpc.controller';
|
||||||
import { ValidateAuthenticationQueryHandler } from './core/application/queries/validate-authentication/validate-authentication.query-handler';
|
import { ValidateAuthenticationQueryHandler } from './core/application/queries/validate-authentication/validate-authentication.query-handler';
|
||||||
import { UserUpdatedMessageHandler } from './interface/message-handlers/user-updated.message-handler';
|
import { UserUpdatedMessageHandler } from './interface/message-handlers/user-updated.message-handler';
|
||||||
|
import { UserDeletedMessageHandler } from './interface/message-handlers/user-deleted.message-handler';
|
||||||
|
|
||||||
const grpcControllers = [
|
const grpcControllers = [
|
||||||
CreateAuthenticationGrpcController,
|
CreateAuthenticationGrpcController,
|
||||||
|
@ -37,7 +38,7 @@ const grpcControllers = [
|
||||||
ValidateAuthenticationGrpcController,
|
ValidateAuthenticationGrpcController,
|
||||||
];
|
];
|
||||||
|
|
||||||
const messageHandlers = [UserUpdatedMessageHandler];
|
const messageHandlers = [UserUpdatedMessageHandler, UserDeletedMessageHandler];
|
||||||
|
|
||||||
const commandHandlers: Provider[] = [
|
const commandHandlers: Provider[] = [
|
||||||
CreateAuthenticationService,
|
CreateAuthenticationService,
|
||||||
|
|
|
@ -0,0 +1,24 @@
|
||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import { CommandBus } from '@nestjs/cqrs';
|
||||||
|
import { RabbitSubscribe } from '@mobicoop/message-broker-module';
|
||||||
|
import { DeleteAuthenticationCommand } from '@modules/authentication/core/application/commands/delete-authentication/delete-authentication.command';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class UserDeletedMessageHandler {
|
||||||
|
constructor(private readonly commandBus: CommandBus) {}
|
||||||
|
|
||||||
|
@RabbitSubscribe({
|
||||||
|
name: 'userDeleted',
|
||||||
|
})
|
||||||
|
public async userDeleted(message: string) {
|
||||||
|
const deletedUser = JSON.parse(message);
|
||||||
|
try {
|
||||||
|
if (!deletedUser.hasOwnProperty('userId')) throw new Error();
|
||||||
|
await this.commandBus.execute(
|
||||||
|
new DeleteAuthenticationCommand({
|
||||||
|
userId: deletedUser.userId,
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
} catch (e: any) {}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,54 @@
|
||||||
|
import { UserDeletedMessageHandler } from '@modules/authentication/interface/message-handlers/user-deleted.message-handler';
|
||||||
|
import { CommandBus } from '@nestjs/cqrs';
|
||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
|
||||||
|
const userDeletedMessage = '{"userId":"2436d413-b7c7-429e-9792-b78edc17b3ca"}';
|
||||||
|
|
||||||
|
const userIdNotProvidedDeletedMessage =
|
||||||
|
'{"user":"2436d413-b7c7-429e-9792-b78edc17b300"}';
|
||||||
|
|
||||||
|
const mockCommandBus = {
|
||||||
|
execute: jest.fn().mockImplementationOnce(() => 'john.doe@email.com'),
|
||||||
|
};
|
||||||
|
|
||||||
|
describe('User Deleted Message Handler', () => {
|
||||||
|
let userDeletedMessageHandler: UserDeletedMessageHandler;
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [
|
||||||
|
{
|
||||||
|
provide: CommandBus,
|
||||||
|
useValue: mockCommandBus,
|
||||||
|
},
|
||||||
|
UserDeletedMessageHandler,
|
||||||
|
],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
userDeletedMessageHandler = module.get<UserDeletedMessageHandler>(
|
||||||
|
UserDeletedMessageHandler,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(async () => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(userDeletedMessageHandler).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should delete an authentication', async () => {
|
||||||
|
jest.spyOn(mockCommandBus, 'execute');
|
||||||
|
await userDeletedMessageHandler.userDeleted(userDeletedMessage);
|
||||||
|
expect(mockCommandBus.execute).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not update an authentication if userId is not provided', async () => {
|
||||||
|
jest.spyOn(mockCommandBus, 'execute');
|
||||||
|
await userDeletedMessageHandler.userDeleted(
|
||||||
|
userIdNotProvidedDeletedMessage,
|
||||||
|
);
|
||||||
|
expect(mockCommandBus.execute).toHaveBeenCalledTimes(0);
|
||||||
|
});
|
||||||
|
});
|
|
@ -66,35 +66,11 @@ describe('User Updated Message Handler', () => {
|
||||||
expect(mockCommandBus.execute).toHaveBeenCalledTimes(0);
|
expect(mockCommandBus.execute).toHaveBeenCalledTimes(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not update a username if userId is unknown', async () => {
|
it('should not update a username if userId is not provided', async () => {
|
||||||
jest.spyOn(mockCommandBus, 'execute');
|
jest.spyOn(mockCommandBus, 'execute');
|
||||||
await userUpdatedMessageHandler.userUpdated(
|
await userUpdatedMessageHandler.userUpdated(
|
||||||
userIdNotProvidedUpdatedMessage,
|
userIdNotProvidedUpdatedMessage,
|
||||||
);
|
);
|
||||||
expect(mockCommandBus.execute).toHaveBeenCalledTimes(0);
|
expect(mockCommandBus.execute).toHaveBeenCalledTimes(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
// it('should throw a dedicated RpcException if username already exists', async () => {
|
|
||||||
// jest.spyOn(mockCommandBus, 'execute');
|
|
||||||
// expect.assertions(3);
|
|
||||||
// try {
|
|
||||||
// await updateUsernameGrpcController.updateUsername(updateUsernameRequest);
|
|
||||||
// } catch (e: any) {
|
|
||||||
// expect(e).toBeInstanceOf(RpcException);
|
|
||||||
// expect(e.error.code).toBe(RpcExceptionCode.ALREADY_EXISTS);
|
|
||||||
// }
|
|
||||||
// expect(mockCommandBus.execute).toHaveBeenCalledTimes(1);
|
|
||||||
// });
|
|
||||||
|
|
||||||
// it('should throw a generic RpcException', async () => {
|
|
||||||
// jest.spyOn(mockCommandBus, 'execute');
|
|
||||||
// expect.assertions(3);
|
|
||||||
// try {
|
|
||||||
// await updateUsernameGrpcController.updateUsername(updateUsernameRequest);
|
|
||||||
// } catch (e: any) {
|
|
||||||
// expect(e).toBeInstanceOf(RpcException);
|
|
||||||
// expect(e.error.code).toBe(RpcExceptionCode.UNKNOWN);
|
|
||||||
// }
|
|
||||||
// expect(mockCommandBus.execute).toHaveBeenCalledTimes(1);
|
|
||||||
// });
|
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue