mirror of
https://github.com/toeverything/AFFiNE.git
synced 2024-12-22 18:11:32 +03:00
173 lines
4.2 KiB
TypeScript
173 lines
4.2 KiB
TypeScript
/// <reference types="../src/global.d.ts" />
|
|
import { TestingModule } from '@nestjs/testing';
|
|
import test from 'ava';
|
|
|
|
import { ConfigModule } from '../src/fundamentals/config';
|
|
import {
|
|
mintChallengeResponse,
|
|
verifyChallengeResponse,
|
|
} from '../src/fundamentals/storage';
|
|
import { AuthResolver } from '../src/modules/auth/resolver';
|
|
import { AuthService } from '../src/modules/auth/service';
|
|
import { createTestingModule } from './utils';
|
|
|
|
let authService: AuthService;
|
|
let authResolver: AuthResolver;
|
|
let module: TestingModule;
|
|
|
|
test.beforeEach(async () => {
|
|
module = await createTestingModule({
|
|
imports: [
|
|
ConfigModule.forRoot({
|
|
auth: {
|
|
accessTokenExpiresIn: 1,
|
|
refreshTokenExpiresIn: 1,
|
|
leeway: 1,
|
|
},
|
|
host: 'example.org',
|
|
https: true,
|
|
}),
|
|
],
|
|
});
|
|
|
|
authService = module.get(AuthService);
|
|
authResolver = module.get(AuthResolver);
|
|
});
|
|
|
|
test.afterEach.always(async () => {
|
|
await module.close();
|
|
});
|
|
|
|
test('should be able to register and signIn', async t => {
|
|
await authService.signUp('Alex Yang', 'alexyang@example.org', '123456');
|
|
await authService.signIn('alexyang@example.org', '123456');
|
|
t.pass();
|
|
});
|
|
|
|
test('should be able to verify', async t => {
|
|
await authService.signUp('Alex Yang', 'alexyang@example.org', '123456');
|
|
await authService.signIn('alexyang@example.org', '123456');
|
|
const date = new Date();
|
|
|
|
const user = {
|
|
id: '1',
|
|
name: 'Alex Yang',
|
|
email: 'alexyang@example.org',
|
|
emailVerified: date,
|
|
createdAt: date,
|
|
avatarUrl: '',
|
|
};
|
|
{
|
|
const token = await authService.sign(user);
|
|
const claim = await authService.verify(token);
|
|
t.is(claim.id, '1');
|
|
t.is(claim.name, 'Alex Yang');
|
|
t.is(claim.email, 'alexyang@example.org');
|
|
t.is(claim.emailVerified?.toISOString(), date.toISOString());
|
|
t.is(claim.createdAt.toISOString(), date.toISOString());
|
|
}
|
|
{
|
|
const token = await authService.refresh(user);
|
|
const claim = await authService.verify(token);
|
|
t.is(claim.id, '1');
|
|
t.is(claim.name, 'Alex Yang');
|
|
t.is(claim.email, 'alexyang@example.org');
|
|
t.is(claim.emailVerified?.toISOString(), date.toISOString());
|
|
t.is(claim.createdAt.toISOString(), date.toISOString());
|
|
}
|
|
});
|
|
|
|
test('should not be able to return token if user is invalid', async t => {
|
|
const date = new Date();
|
|
const user = {
|
|
id: '1',
|
|
name: 'Alex Yang',
|
|
email: 'alexyang@example.org',
|
|
emailVerified: date,
|
|
createdAt: date,
|
|
avatarUrl: '',
|
|
};
|
|
const anotherUser = {
|
|
id: '2',
|
|
name: 'Alex Yang 2',
|
|
email: 'alexyang@example.org',
|
|
emailVerified: date,
|
|
createdAt: date,
|
|
avatarUrl: '',
|
|
};
|
|
await t.throwsAsync(
|
|
authResolver.token(
|
|
{
|
|
req: {
|
|
headers: {
|
|
referer: 'https://example.org',
|
|
host: 'example.org',
|
|
},
|
|
} as any,
|
|
},
|
|
user,
|
|
anotherUser
|
|
),
|
|
{
|
|
message: 'Invalid user',
|
|
}
|
|
);
|
|
});
|
|
|
|
test('should not return sessionToken if request headers is invalid', async t => {
|
|
const date = new Date();
|
|
const user = {
|
|
id: '1',
|
|
name: 'Alex Yang',
|
|
email: 'alexyang@example.org',
|
|
emailVerified: date,
|
|
createdAt: date,
|
|
avatarUrl: '',
|
|
};
|
|
const result = await authResolver.token(
|
|
{
|
|
req: {
|
|
headers: {},
|
|
} as any,
|
|
},
|
|
user,
|
|
user
|
|
);
|
|
t.is(result.sessionToken, undefined);
|
|
});
|
|
|
|
test('should return valid sessionToken if request headers valid', async t => {
|
|
const date = new Date();
|
|
const user = {
|
|
id: '1',
|
|
name: 'Alex Yang',
|
|
email: 'alexyang@example.org',
|
|
emailVerified: date,
|
|
createdAt: date,
|
|
avatarUrl: '',
|
|
};
|
|
const result = await authResolver.token(
|
|
{
|
|
req: {
|
|
headers: {
|
|
referer: 'https://example.org/open-app/test',
|
|
host: 'example.org',
|
|
},
|
|
cookies: {
|
|
'next-auth.session-token': '123456',
|
|
},
|
|
} as any,
|
|
},
|
|
user,
|
|
user
|
|
);
|
|
t.is(result.sessionToken, '123456');
|
|
});
|
|
|
|
test('verify challenge', async t => {
|
|
const resource = 'xp8D3rcXV9bMhWrb6abxl';
|
|
const response = await mintChallengeResponse(resource, 20);
|
|
const success = await verifyChallengeResponse(response, 20, resource);
|
|
t.true(success);
|
|
});
|