2023-09-15 10:34:14 +03:00
|
|
|
/// <reference types="../src/global.d.ts" />
|
2023-09-02 21:13:59 +03:00
|
|
|
// This test case is for testing the mailer service.
|
|
|
|
// Please use local SMTP server for testing.
|
|
|
|
// See: https://github.com/mailhog/MailHog
|
2023-09-13 08:11:19 +03:00
|
|
|
import {
|
|
|
|
getCurrentMailMessageCount,
|
|
|
|
getLatestMailMessage,
|
|
|
|
} from '@affine-test/kit/utils/cloud';
|
2023-09-02 21:13:59 +03:00
|
|
|
import { Test, TestingModule } from '@nestjs/testing';
|
|
|
|
import { PrismaClient } from '@prisma/client';
|
2023-09-29 06:02:26 +03:00
|
|
|
import ava, { type TestFn } from 'ava';
|
2023-09-02 21:13:59 +03:00
|
|
|
|
2023-09-15 10:34:14 +03:00
|
|
|
import { ConfigModule } from '../src/config';
|
2023-12-14 12:50:41 +03:00
|
|
|
import { RevertCommand, RunCommand } from '../src/data/commands/run';
|
2023-09-15 10:34:14 +03:00
|
|
|
import { GqlModule } from '../src/graphql.module';
|
|
|
|
import { AuthModule } from '../src/modules/auth';
|
|
|
|
import { AuthService } from '../src/modules/auth/service';
|
|
|
|
import { PrismaModule } from '../src/prisma';
|
|
|
|
import { RateLimiterModule } from '../src/throttler';
|
2023-12-14 12:50:41 +03:00
|
|
|
import { initFeatureConfigs } from './utils';
|
2023-09-02 21:13:59 +03:00
|
|
|
|
2023-09-15 10:34:14 +03:00
|
|
|
const test = ava as TestFn<{
|
|
|
|
auth: AuthService;
|
|
|
|
module: TestingModule;
|
|
|
|
skip: boolean;
|
|
|
|
}>;
|
2023-09-02 21:13:59 +03:00
|
|
|
|
|
|
|
// cleanup database before each test
|
|
|
|
test.beforeEach(async () => {
|
|
|
|
const client = new PrismaClient();
|
|
|
|
await client.$connect();
|
|
|
|
await client.user.deleteMany({});
|
|
|
|
});
|
|
|
|
|
2023-09-15 10:34:14 +03:00
|
|
|
test.beforeEach(async t => {
|
|
|
|
t.context.module = await Test.createTestingModule({
|
2023-09-02 21:13:59 +03:00
|
|
|
imports: [
|
|
|
|
ConfigModule.forRoot({
|
|
|
|
auth: {
|
|
|
|
accessTokenExpiresIn: 1,
|
|
|
|
refreshTokenExpiresIn: 1,
|
|
|
|
leeway: 1,
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
PrismaModule,
|
|
|
|
GqlModule,
|
|
|
|
AuthModule,
|
|
|
|
RateLimiterModule,
|
|
|
|
],
|
2023-12-14 12:50:36 +03:00
|
|
|
providers: [RevertCommand, RunCommand],
|
2023-09-02 21:13:59 +03:00
|
|
|
}).compile();
|
2023-09-15 10:34:14 +03:00
|
|
|
t.context.auth = t.context.module.get(AuthService);
|
2023-12-14 12:50:36 +03:00
|
|
|
|
|
|
|
// init features
|
2023-12-14 12:50:41 +03:00
|
|
|
await initFeatureConfigs(t.context.module);
|
2023-09-02 21:13:59 +03:00
|
|
|
});
|
|
|
|
|
2023-09-15 10:34:14 +03:00
|
|
|
test.afterEach.always(async t => {
|
|
|
|
await t.context.module.close();
|
2023-09-02 21:13:59 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should include callbackUrl in sending email', async t => {
|
2023-09-15 10:34:14 +03:00
|
|
|
const { auth } = t.context;
|
|
|
|
await auth.signUp('Alex Yang', 'alexyang@example.org', '123456');
|
2023-09-02 21:13:59 +03:00
|
|
|
for (const fn of [
|
|
|
|
'sendSetPasswordEmail',
|
|
|
|
'sendChangeEmail',
|
|
|
|
'sendChangePasswordEmail',
|
2023-09-13 19:54:02 +03:00
|
|
|
'sendVerifyChangeEmail',
|
2023-09-02 21:13:59 +03:00
|
|
|
] as const) {
|
|
|
|
const prev = await getCurrentMailMessageCount();
|
|
|
|
await auth[fn]('alexyang@example.org', 'https://test.com/callback');
|
|
|
|
const current = await getCurrentMailMessageCount();
|
|
|
|
const mail = await getLatestMailMessage();
|
|
|
|
t.regex(
|
2023-09-15 10:34:14 +03:00
|
|
|
mail?.Content?.Body,
|
2023-09-02 21:13:59 +03:00
|
|
|
/https:\/\/test.com\/callback/,
|
|
|
|
`should include callbackUrl when calling ${fn}`
|
|
|
|
);
|
|
|
|
t.is(current, prev + 1, `calling ${fn}`);
|
|
|
|
}
|
|
|
|
});
|