0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-06 20:40:08 -05:00

test(core): add unit tests for generateUserId() (#113)

This commit is contained in:
Gao Sun 2021-09-08 10:29:14 +08:00 committed by GitHub
parent 7ae7912642
commit 8e291b51bf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 73 additions and 20 deletions

View file

@ -0,0 +1,50 @@
import { hasUserWithId } from '@/queries/user';
import { generateUserId } from './user';
jest.mock('@/queries/user');
describe('generateUserId()', () => {
afterEach(() => {
(hasUserWithId as jest.MockedFunction<typeof hasUserWithId>).mockClear();
});
it('generates user ID with correct length when no conflict found', async () => {
const mockedHasUserWithId = (
hasUserWithId as jest.MockedFunction<typeof hasUserWithId>
).mockImplementationOnce(async () => false);
await expect(generateUserId()).resolves.toHaveLength(12);
expect(mockedHasUserWithId).toBeCalledTimes(1);
});
it('generates user ID with correct length when retry limit is not reached', async () => {
// eslint-disable-next-line @silverhand/fp/no-let
let tried = 0;
const mockedHasUserWithId = (
hasUserWithId as jest.MockedFunction<typeof hasUserWithId>
).mockImplementation(async () => {
if (tried) {
return false;
}
// eslint-disable-next-line @silverhand/fp/no-mutation
tried++;
return true;
});
await expect(generateUserId(2)).resolves.toHaveLength(12);
expect(mockedHasUserWithId).toBeCalledTimes(2);
});
it('rejects with correct error message when retry limit is reached', async () => {
const mockedHasUserWithId = (
hasUserWithId as jest.MockedFunction<typeof hasUserWithId>
).mockImplementation(async () => true);
await expect(generateUserId(10)).rejects.toThrow(
'Cannot generate user ID in reasonable retries'
);
expect(mockedHasUserWithId).toBeCalledTimes(11);
});
});

View file

@ -0,0 +1,21 @@
import pRetry from 'p-retry';
import { hasUserWithId } from '@/queries/user';
import { buildIdGenerator } from '@/utils/id';
const userId = buildIdGenerator(12);
// LOG-89: Add unit tests
export const generateUserId = async (retries = 500) =>
pRetry(
async () => {
const id = userId();
if (!(await hasUserWithId(id))) {
return id;
}
throw new Error('Cannot generate user ID in reasonable retries');
},
{ retries, factor: 0 } // No need for exponential backoff
);

View file

@ -1,33 +1,15 @@
import { PasswordEncryptionMethod } from '@logto/schemas';
import { nanoid } from 'nanoid';
import pRetry from 'p-retry';
import { object, string } from 'zod';
import RequestError from '@/errors/RequestError';
import { generateUserId } from '@/lib/user';
import koaGuard from '@/middleware/koa-guard';
import { hasUser, hasUserWithId, insertUser } from '@/queries/user';
import { buildIdGenerator } from '@/utils/id';
import { hasUser, insertUser } from '@/queries/user';
import { encryptPassword } from '@/utils/password';
import { AnonymousRouter } from './types';
const userId = buildIdGenerator(12);
// LOG-89: Add unit tests
const generateUserId = async (retries = 500) =>
pRetry(
async () => {
const id = userId();
if (!(await hasUserWithId(id))) {
return id;
}
throw new Error('Cannot generate user ID in reasonable retries');
},
{ retries }
);
export default function userRoutes<T extends AnonymousRouter>(router: T) {
router.post(
'/user',