test(user): write test for sendInvitationEmail
This commit is contained in:
@@ -743,4 +743,49 @@ describe('User model', () => {
|
|||||||
vi.useRealTimers();
|
vi.useRealTimers();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('sendInvitationEmail should generate invitation token and queue to send invitation email', async () => {
|
||||||
|
vi.useFakeTimers();
|
||||||
|
|
||||||
|
const date = new Date(2024, 10, 12, 17, 10, 0, 0);
|
||||||
|
vi.setSystemTime(date);
|
||||||
|
|
||||||
|
const user = await createUser();
|
||||||
|
|
||||||
|
const generateInvitationTokenSpy = vi
|
||||||
|
.spyOn(user, 'generateInvitationToken')
|
||||||
|
.mockReturnValue();
|
||||||
|
|
||||||
|
const emailQueueAddSpy = vi.spyOn(emailQueue, 'add').mockResolvedValue();
|
||||||
|
|
||||||
|
await user.sendInvitationEmail();
|
||||||
|
|
||||||
|
const refetchedUser = await user.$query();
|
||||||
|
const jobName = `Invitation Email - ${refetchedUser.id}`;
|
||||||
|
|
||||||
|
const jobPayload = {
|
||||||
|
email: refetchedUser.email,
|
||||||
|
subject: 'You are invited!',
|
||||||
|
template: 'invitation-instructions',
|
||||||
|
params: {
|
||||||
|
fullName: refetchedUser.fullName,
|
||||||
|
acceptInvitationUrl: refetchedUser.acceptInvitationUrl,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const jobOptions = {
|
||||||
|
removeOnComplete: REMOVE_AFTER_7_DAYS_OR_50_JOBS,
|
||||||
|
removeOnFail: REMOVE_AFTER_30_DAYS_OR_150_JOBS,
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(generateInvitationTokenSpy).toHaveBeenCalledOnce();
|
||||||
|
|
||||||
|
expect(emailQueueAddSpy).toHaveBeenCalledWith(
|
||||||
|
jobName,
|
||||||
|
jobPayload,
|
||||||
|
jobOptions
|
||||||
|
);
|
||||||
|
|
||||||
|
vi.useRealTimers();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user