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

refactor: add alteration and integration test

This commit is contained in:
Gao Sun 2022-12-20 13:02:40 +08:00
parent 92b18c7e3c
commit a023fe97e5
No known key found for this signature in database
GPG key ID: 13EBE123E4773688
7 changed files with 85 additions and 10 deletions

View file

@ -11,6 +11,7 @@ import {
createDemoAppApplication,
defaultRole,
} from '@logto/schemas';
import { Hooks } from '@logto/schemas/models';
import chalk from 'chalk';
import type { DatabasePool, DatabaseTransactionConnection } from 'slonik';
import { sql } from 'slonik';
@ -45,6 +46,11 @@ const createTables = async (connection: DatabaseTransactionConnection) => {
// eslint-disable-next-line no-await-in-loop
await connection.query(sql`${raw(query)}`);
}
for (const table of [Hooks]) {
// eslint-disable-next-line no-await-in-loop
await connection.query(sql`${raw(table.raw)}`);
}
};
const seedTables = async (connection: DatabaseTransactionConnection) => {

View file

@ -35,7 +35,7 @@
"@logto/shared": "workspace:*",
"@silverhand/essentials": "^1.3.0",
"@withtyped/postgres": "^0.3.1",
"@withtyped/server": "^0.3.0",
"@withtyped/server": "^0.3.1",
"chalk": "^5.0.0",
"clean-deep": "^3.4.0",
"date-fns": "^2.29.3",

View file

@ -50,5 +50,8 @@
"eslintConfig": {
"extends": "@silverhand"
},
"prettier": "@silverhand/eslint-config/.prettierrc"
"prettier": "@silverhand/eslint-config/.prettierrc",
"dependencies": {
"@withtyped/server": "^0.3.0"
}
}

View file

@ -0,0 +1,31 @@
import type { Hooks } from '@logto/schemas/models';
import type { InferModelType } from '@withtyped/server';
import { authedAdminApi } from '#src/api/index.js';
describe('hooks', () => {
it('should be able to create, query, and delete a hook', async () => {
type Hook = InferModelType<typeof Hooks>;
const payload = {
event: 'PostRegister',
config: {
url: 'https://foo.bar',
headers: { foo: 'bar' },
retries: 3,
},
};
const created = await authedAdminApi.post('hooks', { json: payload }).json<Hook>();
expect(payload.event).toEqual(created.event);
expect(payload.config).toEqual(created.config);
expect(await authedAdminApi.get('hooks').json<Hook[]>()).toContainEqual(created);
expect(await authedAdminApi.get(`hooks/${created.id}`).json<Hook>()).toEqual(created);
expect(await authedAdminApi.delete(`hooks/${created.id}`)).toHaveProperty('statusCode', 204);
await expect(authedAdminApi.get(`hooks/${created.id}`)).rejects.toHaveProperty(
'response.statusCode',
404
);
});
});

View file

@ -0,0 +1,26 @@
import { sql } from 'slonik';
import type { AlterationScript } from '../src/types/alteration.js';
const alteration: AlterationScript = {
up: async (pool) => {
await pool.query(sql`
create table hooks (
id varchar(32) not null,
event varchar(128) not null,
config jsonb /* @use HookConfig */ not null,
created_at timestamptz not null default(now()),
primary key (id)
);
create index hooks__event on hooks (event);
`);
},
down: async (pool) => {
await pool.query(sql`
drop table hooks;
`);
},
};
export default alteration;

View file

@ -82,7 +82,7 @@
"@logto/language-kit": "workspace:*",
"@logto/phrases": "workspace:*",
"@logto/phrases-ui": "workspace:*",
"@withtyped/server": "^0.3.0",
"@withtyped/server": "^0.3.1",
"zod": "^3.20.2"
}
}

View file

@ -280,7 +280,7 @@ importers:
'@types/sinon': ^10.0.13
'@types/supertest': ^2.0.11
'@withtyped/postgres': ^0.3.1
'@withtyped/server': ^0.3.0
'@withtyped/server': ^0.3.1
chalk: ^5.0.0
clean-deep: ^3.4.0
copyfiles: ^2.4.1
@ -337,8 +337,8 @@ importers:
'@logto/schemas': link:../schemas
'@logto/shared': link:../shared
'@silverhand/essentials': 1.3.0
'@withtyped/postgres': 0.3.1_@withtyped+server@0.3.0
'@withtyped/server': 0.3.0
'@withtyped/postgres': 0.3.1_@withtyped+server@0.3.1
'@withtyped/server': 0.3.1
chalk: 5.1.2
clean-deep: 3.4.0
date-fns: 2.29.3
@ -482,6 +482,7 @@ importers:
'@types/jest': ^29.1.2
'@types/jest-environment-puppeteer': ^5.0.2
'@types/node': ^16.0.0
'@withtyped/server': ^0.3.0
dotenv: ^16.0.0
eslint: ^8.21.0
got: ^12.5.3
@ -494,6 +495,8 @@ importers:
puppeteer: ^19.0.0
text-encoder: ^0.0.4
typescript: ^4.9.4
dependencies:
'@withtyped/server': 0.3.0
devDependencies:
'@jest/types': 29.1.2
'@logto/js': 1.0.0-beta.14
@ -583,7 +586,7 @@ importers:
'@types/lodash.uniq': ^4.5.6
'@types/node': ^16.0.0
'@types/pluralize': ^0.0.29
'@withtyped/server': ^0.3.0
'@withtyped/server': ^0.3.1
camelcase: ^7.0.0
eslint: ^8.21.0
jest: ^29.1.2
@ -600,7 +603,7 @@ importers:
'@logto/language-kit': link:../toolkit/language-kit
'@logto/phrases': link:../phrases
'@logto/phrases-ui': link:../phrases-ui
'@withtyped/server': 0.3.0
'@withtyped/server': 0.3.1
zod: 3.20.2
devDependencies:
'@silverhand/eslint-config': 1.3.0_eu7dlo3qq5moigliolva3udaxa
@ -4657,13 +4660,13 @@ packages:
eslint-visitor-keys: 3.3.0
dev: true
/@withtyped/postgres/0.3.1_@withtyped+server@0.3.0:
/@withtyped/postgres/0.3.1_@withtyped+server@0.3.1:
resolution: {integrity: sha512-+XP+kbmTKKpv/5Nf4KDVKfWp6kYGIyty3aUUnSrBY0KLdOUfesuPjFK6S7sNgbh+7pvk/iU48/3UDsjuy4m+SQ==}
peerDependencies:
'@withtyped/server': ^0.3.0
dependencies:
'@types/pg': 8.6.5
'@withtyped/server': 0.3.0
'@withtyped/server': 0.3.1
'@withtyped/shared': 0.2.0
pg: 8.8.0
transitivePeerDependencies:
@ -4676,6 +4679,12 @@ packages:
'@withtyped/shared': 0.2.0
dev: false
/@withtyped/server/0.3.1:
resolution: {integrity: sha512-AI4QDHVTgv5GWPomWCgP5vqgVWaiby1vm56LBbSqe6r1DTPOZrySoxNoaE5XTQzYX1Jd3pzq1CsOd5AxkgCfpg==}
dependencies:
'@withtyped/shared': 0.2.0
dev: false
/@withtyped/shared/0.2.0:
resolution: {integrity: sha512-SADIVEospfIWAVK0LxX7F1T04hsWMZ0NkfR3lNfvJqOktJ52GglI3FOTVYOM1NJYReDT6pR0XFlCfaF8TVPt8w==}
dev: false