2024-03-26 05:24:17 +03:00
|
|
|
import { TestingModule } from '@nestjs/testing';
|
|
|
|
import { PrismaClient } from '@prisma/client';
|
|
|
|
import ava, { TestFn } from 'ava';
|
|
|
|
|
|
|
|
import { TokenService, TokenType } from '../../src/core/auth';
|
|
|
|
import { createTestingModule } from '../utils';
|
|
|
|
|
|
|
|
const test = ava as TestFn<{
|
|
|
|
ts: TokenService;
|
|
|
|
m: TestingModule;
|
|
|
|
}>;
|
|
|
|
|
2024-09-03 12:03:39 +03:00
|
|
|
test.before(async t => {
|
2024-03-26 05:24:17 +03:00
|
|
|
const m = await createTestingModule({
|
|
|
|
providers: [TokenService],
|
|
|
|
});
|
|
|
|
|
|
|
|
t.context.ts = m.get(TokenService);
|
|
|
|
t.context.m = m;
|
|
|
|
});
|
|
|
|
|
2024-09-03 12:03:39 +03:00
|
|
|
test.after.always(async t => {
|
2024-03-26 05:24:17 +03:00
|
|
|
await t.context.m.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should be able to create token', async t => {
|
|
|
|
const { ts } = t.context;
|
|
|
|
const token = await ts.createToken(TokenType.SignIn, 'user@affine.pro');
|
|
|
|
|
|
|
|
t.truthy(
|
|
|
|
await ts.verifyToken(TokenType.SignIn, token, {
|
|
|
|
credential: 'user@affine.pro',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should fail the verification if the token is invalid', async t => {
|
|
|
|
const { ts } = t.context;
|
|
|
|
|
|
|
|
const token = await ts.createToken(TokenType.SignIn, 'user@affine.pro');
|
|
|
|
|
|
|
|
// wrong type
|
|
|
|
t.falsy(
|
|
|
|
await ts.verifyToken(TokenType.ChangeEmail, token, {
|
|
|
|
credential: 'user@affine.pro',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
// no credential
|
|
|
|
t.falsy(await ts.verifyToken(TokenType.SignIn, token));
|
|
|
|
|
|
|
|
// wrong credential
|
|
|
|
t.falsy(
|
|
|
|
await ts.verifyToken(TokenType.SignIn, token, {
|
|
|
|
credential: 'wrong@affine.pro',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should fail if the token expired', async t => {
|
|
|
|
const { ts } = t.context;
|
|
|
|
const token = await ts.createToken(TokenType.SignIn, 'user@affine.pro');
|
|
|
|
|
|
|
|
await t.context.m.get(PrismaClient).verificationToken.updateMany({
|
|
|
|
data: {
|
|
|
|
expiresAt: new Date(Date.now() - 1000),
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
t.falsy(
|
|
|
|
await ts.verifyToken(TokenType.SignIn, token, {
|
|
|
|
credential: 'user@affine.pro',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should be able to verify only once', async t => {
|
|
|
|
const { ts } = t.context;
|
|
|
|
const token = await ts.createToken(TokenType.SignIn, 'user@affine.pro');
|
|
|
|
|
|
|
|
t.truthy(
|
|
|
|
await ts.verifyToken(TokenType.SignIn, token, {
|
|
|
|
credential: 'user@affine.pro',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
// will be invalid after the first time of verification
|
|
|
|
t.falsy(
|
|
|
|
await ts.verifyToken(TokenType.SignIn, token, {
|
|
|
|
credential: 'user@affine.pro',
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|