0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2024-12-23 20:33:16 -05:00
logto/packages/integration-tests/tests/users.test.ts

74 lines
2 KiB
TypeScript
Raw Normal View History

import { User } from '@logto/schemas';
import { authedAdminApi } from '@/api';
import { createUser } from '@/helper';
describe('admin console user management', () => {
it('should create user successfully', async () => {
const user = await createUser();
const userDetails = await authedAdminApi.get(`users/${user.id}`).json<User>();
expect(userDetails).toBeTruthy();
expect(userDetails.id).toBe(user.id);
});
it('should get user list successfully', async () => {
await createUser();
const users = await authedAdminApi.get('users').json<User[]>();
expect(users.length).not.toBeLessThan(1);
});
it('should update userinfo successfully', async () => {
const user = await createUser();
const newUserData: Partial<User> = {
name: 'new name',
avatar: 'https://new.avatar.com/avatar.png',
customData: {
level: 1,
},
roleNames: ['admin'],
};
const updatedUser = await authedAdminApi
.patch(`users/${user.id}`, {
json: newUserData,
})
.json<User>();
expect(updatedUser).toMatchObject(newUserData);
});
it('should delete user successfully', async () => {
const user = await createUser();
const fetchedResponseBeforeDeletion = await authedAdminApi.get(`users/${user.id}`, {
throwHttpErrors: false,
});
expect(fetchedResponseBeforeDeletion.statusCode).toBe(200);
await authedAdminApi.delete(`users/${user.id}`);
const fetchedResponseAfterDeletion = await authedAdminApi.get(`users/${user.id}`, {
throwHttpErrors: false,
});
expect(fetchedResponseAfterDeletion.statusCode).toBe(404);
});
it('should update user password successfully', async () => {
const user = await createUser();
const updatePasswordResponse = await authedAdminApi.patch(`users/${user.id}/password`, {
json: {
password: 'newPassword',
},
throwHttpErrors: false,
});
expect(updatePasswordResponse.statusCode).toBe(200);
});
});