AFFiNE/packages/backend/server/tests/user.e2e.ts

55 lines
1.6 KiB
TypeScript
Raw Normal View History

import type { INestApplication } from '@nestjs/common';
2023-09-01 22:41:29 +03:00
import test from 'ava';
import request from 'supertest';
import { AppModule } from '../src/app.module';
import { createTestingApp, currentUser, signUp } from './utils';
2023-09-01 22:41:29 +03:00
let app: INestApplication;
2023-09-01 22:41:29 +03:00
test.beforeEach(async () => {
const { app: testApp } = await createTestingApp({
2023-09-01 22:41:29 +03:00
imports: [AppModule],
});
app = testApp;
2023-09-01 22:41:29 +03:00
});
test.afterEach.always(async () => {
2023-09-01 22:41:29 +03:00
await app.close();
});
2023-09-01 22:41:29 +03:00
test('should register a user', async t => {
const user = await signUp(app, 'u1', 'u1@affine.pro', '123456');
t.is(typeof user.id, 'string', 'user.id is not a string');
t.is(user.name, 'u1', 'user.name is not valid');
t.is(user.email, 'u1@affine.pro', 'user.email is not valid');
2023-09-01 22:41:29 +03:00
});
2023-09-01 22:41:29 +03:00
test('should get current user', async t => {
const user = await signUp(app, 'u1', 'u1@affine.pro', '123456');
const currUser = await currentUser(app, user.token.token);
t.is(currUser.id, user.id, 'user.id is not valid');
t.is(currUser.name, user.name, 'user.name is not valid');
t.is(currUser.email, user.email, 'user.email is not valid');
t.true(currUser.hasPassword, 'currUser.hasPassword is not valid');
2023-09-01 22:41:29 +03:00
});
2023-09-01 22:41:29 +03:00
test('should be able to delete user', async t => {
const user = await signUp(app, 'u1', 'u1@affine.pro', '123456');
await request(app.getHttpServer())
.post('/graphql')
.auth(user.token.token, { type: 'bearer' })
.send({
query: `
mutation {
deleteAccount {
success
}
}
`,
2023-09-01 22:41:29 +03:00
})
.expect(200);
2023-10-19 05:06:34 +03:00
t.is(await currentUser(app, user.token.token), null);
2023-09-01 22:41:29 +03:00
t.pass();
});