0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-13 21:30:30 -05:00

test(core): fix unit tests

This commit is contained in:
Gao Sun 2023-01-28 14:43:20 +08:00
parent b07252f9b2
commit 52c2222f4a
No known key found for this signature in database
GPG key ID: 13EBE123E4773688
13 changed files with 56 additions and 22 deletions

View file

@ -1,6 +1,8 @@
import en from '@logto/phrases-ui/lib/locales/en.js'; import en from '@logto/phrases-ui/lib/locales/en.js';
import { CustomPhrase } from '@logto/schemas'; import { CustomPhrase } from '@logto/schemas';
import { mockId } from '#src/test-utils/nanoid.js';
export const enTag = 'en'; export const enTag = 'en';
export const trTrTag = 'tr-TR'; export const trTrTag = 'tr-TR';
export const zhCnTag = 'zh-CN'; export const zhCnTag = 'zh-CN';
@ -8,7 +10,7 @@ export const zhHkTag = 'zh-HK';
export const mockEnCustomPhrase = { export const mockEnCustomPhrase = {
tenantId: 'fake_tenant', tenantId: 'fake_tenant',
id: 'fake_id', id: mockId,
languageTag: enTag, languageTag: enTag,
translation: { translation: {
input: { input: {
@ -23,7 +25,7 @@ export const mockEnCustomPhrase = {
export const mockEnPhrase = { export const mockEnPhrase = {
tenantId: 'fake_tenant', tenantId: 'fake_tenant',
id: 'fake_id', id: mockId,
languageTag: enTag, languageTag: enTag,
translation: { translation: {
...en.translation, ...en.translation,
@ -33,7 +35,7 @@ export const mockEnPhrase = {
export const mockTrTrCustomPhrase = { export const mockTrTrCustomPhrase = {
tenantId: 'fake_tenant', tenantId: 'fake_tenant',
id: 'fake_id', id: mockId,
languageTag: trTrTag, languageTag: trTrTag,
translation: { translation: {
input: { input: {
@ -48,7 +50,7 @@ export const mockTrTrCustomPhrase = {
export const mockZhCnCustomPhrase = { export const mockZhCnCustomPhrase = {
tenantId: 'fake_tenant', tenantId: 'fake_tenant',
id: 'fake_id', id: mockId,
languageTag: zhCnTag, languageTag: zhCnTag,
translation: { translation: {
input: { input: {
@ -63,7 +65,7 @@ export const mockZhCnCustomPhrase = {
export const mockZhHkCustomPhrase = { export const mockZhHkCustomPhrase = {
tenantId: 'fake_tenant', tenantId: 'fake_tenant',
id: 'fake_id', id: mockId,
languageTag: zhHkTag, languageTag: zhHkTag,
translation: { translation: {
input: { input: {

View file

@ -73,6 +73,8 @@ it('should ignore empty string values from the custom phrase', async () => {
findCustomPhraseByLanguageTag.mockResolvedValueOnce(mockEnCustomPhraseWithEmptyStringValues); findCustomPhraseByLanguageTag.mockResolvedValueOnce(mockEnCustomPhraseWithEmptyStringValues);
await expect(getPhrases(enTag, [enTag])).resolves.toEqual( await expect(getPhrases(enTag, [enTag])).resolves.toEqual(
deepmerge(englishBuiltInPhrase, { deepmerge(englishBuiltInPhrase, {
id: 'fake_id',
tenantId: 'fake_tenant',
languageTag: enTag, languageTag: enTag,
translation: { translation: {
input: { input: {

View file

@ -191,7 +191,8 @@ describe('connector queries', () => {
return createMockQueryResult([connector]); return createMockQueryResult([connector]);
}); });
await expect(insertConnector(mockConnector)).resolves.toEqual(connector); const { tenantId, ...data } = mockConnector;
await expect(insertConnector(data)).resolves.toEqual(connector);
}); });
it('updateConnector (with id)', async () => { it('updateConnector (with id)', async () => {

View file

@ -125,7 +125,7 @@ describe('roles query', () => {
const keys = excludeAutoSetFields(Roles.fieldKeys); const keys = excludeAutoSetFields(Roles.fieldKeys);
const expectSql = ` const expectSql = `
insert into "roles" ("id", "name", "description") insert into "roles" ("tenant_id", "id", "name", "description")
values (${keys.map((_, index) => `$${index + 1}`).join(', ')}) values (${keys.map((_, index) => `$${index + 1}`).join(', ')})
returning * returning *
`; `;

View file

@ -21,7 +21,7 @@ const { findDefaultSignInExperience, updateDefaultSignInExperience } =
describe('sign-in-experience query', () => { describe('sign-in-experience query', () => {
const id = 'default'; const id = 'default';
const dbvalue = { const databaseValue = {
...mockSignInExperience, ...mockSignInExperience,
color: JSON.stringify(mockSignInExperience.color), color: JSON.stringify(mockSignInExperience.color),
branding: JSON.stringify(mockSignInExperience.branding), branding: JSON.stringify(mockSignInExperience.branding),
@ -35,7 +35,7 @@ describe('sign-in-experience query', () => {
it('findDefaultSignInExperience', async () => { it('findDefaultSignInExperience', async () => {
/* eslint-disable sql/no-unsafe-query */ /* eslint-disable sql/no-unsafe-query */
const expectSql = ` const expectSql = `
select "id", "color", "branding", "language_info", "terms_of_use_url", "sign_in", "sign_up", "social_sign_in_connector_targets", "sign_in_mode" select "tenant_id", "id", "color", "branding", "language_info", "terms_of_use_url", "sign_in", "sign_up", "social_sign_in_connector_targets", "sign_in_mode"
from "sign_in_experiences" from "sign_in_experiences"
where "id"=$1 where "id"=$1
`; `;
@ -45,10 +45,10 @@ describe('sign-in-experience query', () => {
expectSqlAssert(sql, expectSql); expectSqlAssert(sql, expectSql);
expect(values).toEqual([id]); expect(values).toEqual([id]);
return createMockQueryResult([dbvalue]); return createMockQueryResult([databaseValue]);
}); });
await expect(findDefaultSignInExperience()).resolves.toEqual(dbvalue); await expect(findDefaultSignInExperience()).resolves.toEqual(databaseValue);
}); });
it('updateDefaultSignInExperience', async () => { it('updateDefaultSignInExperience', async () => {
@ -67,9 +67,9 @@ describe('sign-in-experience query', () => {
expectSqlAssert(sql, expectSql); expectSqlAssert(sql, expectSql);
expect(values).toEqual([termsOfUseUrl, id]); expect(values).toEqual([termsOfUseUrl, id]);
return createMockQueryResult([dbvalue]); return createMockQueryResult([databaseValue]);
}); });
await expect(updateDefaultSignInExperience({ termsOfUseUrl })).resolves.toEqual(dbvalue); await expect(updateDefaultSignInExperience({ termsOfUseUrl })).resolves.toEqual(databaseValue);
}); });
}); });

View file

@ -1,11 +1,14 @@
import { pickDefault } from '@logto/shared/esm'; import { pickDefault } from '@logto/shared/esm';
import { mockRole, mockUser } from '#src/__mocks__/index.js'; import { mockRole, mockUser } from '#src/__mocks__/index.js';
import { mockId, mockStandardId } from '#src/test-utils/nanoid.js';
import { MockTenant } from '#src/test-utils/tenant.js'; import { MockTenant } from '#src/test-utils/tenant.js';
import { createRequester } from '#src/utils/test-utils.js'; import { createRequester } from '#src/utils/test-utils.js';
const { jest } = import.meta; const { jest } = import.meta;
await mockStandardId();
const users = { findUserById: jest.fn() }; const users = { findUserById: jest.fn() };
const roles = { const roles = {
@ -14,7 +17,6 @@ const roles = {
countRoles: jest.fn(async () => ({ count: 1 })), countRoles: jest.fn(async () => ({ count: 1 })),
findRoles: jest.fn(async () => [mockRole]), findRoles: jest.fn(async () => [mockRole]),
}; };
const { findRolesByRoleIds } = roles;
const usersRoles = { const usersRoles = {
findUsersRolesByUserId: jest.fn(), findUsersRolesByUserId: jest.fn(),
@ -43,7 +45,9 @@ describe('user role routes', () => {
roleIds: [mockRole.id], roleIds: [mockRole.id],
}); });
expect(response.status).toEqual(201); expect(response.status).toEqual(201);
expect(insertUsersRoles).toHaveBeenCalledWith([{ userId: mockUser.id, roleId: mockRole.id }]); expect(insertUsersRoles).toHaveBeenCalledWith([
{ id: mockId, userId: mockUser.id, roleId: mockRole.id },
]);
}); });
it('DELETE /users/:id/roles/:roleId', async () => { it('DELETE /users/:id/roles/:roleId', async () => {

View file

@ -6,12 +6,15 @@ import { pickDefault, createMockUtils } from '@logto/shared/esm';
import { mockZhCnCustomPhrase, trTrTag, zhCnTag } from '#src/__mocks__/custom-phrase.js'; import { mockZhCnCustomPhrase, trTrTag, zhCnTag } from '#src/__mocks__/custom-phrase.js';
import { mockSignInExperience } from '#src/__mocks__/index.js'; import { mockSignInExperience } from '#src/__mocks__/index.js';
import RequestError from '#src/errors/RequestError/index.js'; import RequestError from '#src/errors/RequestError/index.js';
import { mockId, mockStandardId } from '#src/test-utils/nanoid.js';
import { MockTenant } from '#src/test-utils/tenant.js'; import { MockTenant } from '#src/test-utils/tenant.js';
import { createRequester } from '#src/utils/test-utils.js'; import { createRequester } from '#src/utils/test-utils.js';
const { jest } = import.meta; const { jest } = import.meta;
const { mockEsm } = createMockUtils(jest); const { mockEsm } = createMockUtils(jest);
await mockStandardId();
const mockLanguageTag = zhCnTag; const mockLanguageTag = zhCnTag;
const mockPhrase = mockZhCnCustomPhrase; const mockPhrase = mockZhCnCustomPhrase;
const mockCustomPhrases: Record<string, CustomPhrase> = { const mockCustomPhrases: Record<string, CustomPhrase> = {
@ -126,6 +129,7 @@ describe('customPhraseRoutes', () => {
input: { ...inputTranslation, password: '' }, input: { ...inputTranslation, password: '' },
}); });
expect(upsertCustomPhrase).toBeCalledWith({ expect(upsertCustomPhrase).toBeCalledWith({
id: mockId,
languageTag: mockLanguageTag, languageTag: mockLanguageTag,
translation: { input: inputTranslation }, translation: { input: inputTranslation },
}); });
@ -146,7 +150,9 @@ describe('customPhraseRoutes', () => {
it('should call upsertCustomPhrase with specified language tag', async () => { it('should call upsertCustomPhrase with specified language tag', async () => {
await customPhraseRequest.put(`/custom-phrases/${mockLanguageTag}`).send(translation); await customPhraseRequest.put(`/custom-phrases/${mockLanguageTag}`).send(translation);
expect(upsertCustomPhrase).toBeCalledWith(mockCustomPhrases[mockLanguageTag]); // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
const { tenantId, ...phrase } = mockCustomPhrases[mockLanguageTag]!;
expect(upsertCustomPhrase).toBeCalledWith(phrase);
}); });
it('should return custom phrase after upserting', async () => { it('should return custom phrase after upserting', async () => {

View file

@ -90,6 +90,7 @@ describe('resource routes', () => {
expect(response.status).toEqual(200); expect(response.status).toEqual(200);
expect(response.body).toEqual({ expect(response.body).toEqual({
tenantId: 'fake_tenant',
id: 'randomId', id: 'randomId',
name, name,
indicator, indicator,

View file

@ -2,11 +2,14 @@ import type { Role } from '@logto/schemas';
import { pickDefault } from '@logto/shared/esm'; import { pickDefault } from '@logto/shared/esm';
import { mockRole, mockScope, mockResource } from '#src/__mocks__/index.js'; import { mockRole, mockScope, mockResource } from '#src/__mocks__/index.js';
import { mockId, mockStandardId } from '#src/test-utils/nanoid.js';
import { MockTenant } from '#src/test-utils/tenant.js'; import { MockTenant } from '#src/test-utils/tenant.js';
import { createRequester } from '#src/utils/test-utils.js'; import { createRequester } from '#src/utils/test-utils.js';
const { jest } = import.meta; const { jest } = import.meta;
await mockStandardId();
const roles = { const roles = {
findRoles: jest.fn(async (): Promise<Role[]> => [mockRole]), findRoles: jest.fn(async (): Promise<Role[]> => [mockRole]),
countRoles: jest.fn(async () => ({ count: 10 })), countRoles: jest.fn(async () => ({ count: 10 })),
@ -77,7 +80,7 @@ describe('role scope routes', () => {
}); });
expect(response.status).toEqual(200); expect(response.status).toEqual(200);
expect(insertRolesScopes).toHaveBeenCalledWith([ expect(insertRolesScopes).toHaveBeenCalledWith([
{ roleId: mockRole.id, scopeId: mockScope.id }, { id: mockId, roleId: mockRole.id, scopeId: mockScope.id },
]); ]);
}); });

View file

@ -2,11 +2,14 @@ import type { Role } from '@logto/schemas';
import { pickDefault } from '@logto/shared/esm'; import { pickDefault } from '@logto/shared/esm';
import { mockRole, mockScope, mockUser, mockResource } from '#src/__mocks__/index.js'; import { mockRole, mockScope, mockUser, mockResource } from '#src/__mocks__/index.js';
import { mockId, mockStandardId } from '#src/test-utils/nanoid.js';
import { MockTenant } from '#src/test-utils/tenant.js'; import { MockTenant } from '#src/test-utils/tenant.js';
import { createRequester } from '#src/utils/test-utils.js'; import { createRequester } from '#src/utils/test-utils.js';
const { jest } = import.meta; const { jest } = import.meta;
await mockStandardId();
const roles = { const roles = {
findRoles: jest.fn(async (): Promise<Role[]> => [mockRole]), findRoles: jest.fn(async (): Promise<Role[]> => [mockRole]),
countRoles: jest.fn(async () => ({ count: 10 })), countRoles: jest.fn(async () => ({ count: 10 })),
@ -15,12 +18,14 @@ const roles = {
insertRole: jest.fn(async (data) => ({ insertRole: jest.fn(async (data) => ({
...data, ...data,
id: mockRole.id, id: mockRole.id,
tenantId: 'fake_tenant',
})), })),
deleteRoleById: jest.fn(), deleteRoleById: jest.fn(),
findRoleById: jest.fn(), findRoleById: jest.fn(),
updateRoleById: jest.fn(async (id, data) => ({ updateRoleById: jest.fn(async (id, data) => ({
...mockRole, ...mockRole,
...data, ...data,
tenantId: 'fake_tenant',
})), })),
findRolesByRoleIds: jest.fn(), findRolesByRoleIds: jest.fn(),
}; };
@ -172,7 +177,9 @@ describe('role routes', () => {
userIds: [mockUser.id], userIds: [mockUser.id],
}); });
expect(response.status).toEqual(201); expect(response.status).toEqual(201);
expect(insertUsersRoles).toHaveBeenCalledWith([{ userId: mockUser.id, roleId: mockRole.id }]); expect(insertUsersRoles).toHaveBeenCalledWith([
{ id: mockId, userId: mockUser.id, roleId: mockRole.id },
]);
}); });
it('DELETE /roles/:id/users/:userId', async () => { it('DELETE /roles/:id/users/:userId', async () => {

View file

@ -1,4 +1,4 @@
import { buildIdGenerator, generateStandardId } from '@logto/core-kit'; import { generateStandardId } from '@logto/core-kit';
import type { RoleResponse } from '@logto/schemas'; import type { RoleResponse } from '@logto/schemas';
import { userInfoSelectFields, Roles } from '@logto/schemas'; import { userInfoSelectFields, Roles } from '@logto/schemas';
import { tryThat } from '@logto/shared'; import { tryThat } from '@logto/shared';
@ -13,8 +13,6 @@ import { parseSearchParamsForSearch } from '#src/utils/search.js';
import type { AuthedRouter, RouterInitArgs } from './types.js'; import type { AuthedRouter, RouterInitArgs } from './types.js';
const roleId = buildIdGenerator(21);
export default function roleRoutes<T extends AuthedRouter>( export default function roleRoutes<T extends AuthedRouter>(
...[router, { queries }]: RouterInitArgs<T> ...[router, { queries }]: RouterInitArgs<T>
) { ) {
@ -108,7 +106,7 @@ export default function roleRoutes<T extends AuthedRouter>(
const role = await insertRole({ const role = await insertRole({
...roleBody, ...roleBody,
id: roleId(), id: generateStandardId(),
}); });
if (scopeIds) { if (scopeIds) {

View file

@ -37,6 +37,7 @@ describe('settings routes', () => {
expect(response.status).toEqual(200); expect(response.status).toEqual(200);
expect(response.body).toEqual({ expect(response.body).toEqual({
tenantId: 'fake_tenant',
adminConsole, adminConsole,
}); });
}); });

View file

@ -0,0 +1,9 @@
import { createMockUtils } from '@logto/shared/esm';
const { mockEsmWithActual } = createMockUtils(import.meta.jest);
export const mockId = 'mockId';
export const mockStandardId = async () =>
mockEsmWithActual('@logto/core-kit', () => ({
generateStandardId: () => mockId,
}));