From 377942fe3c5c0a68736701682f7c912c185ff05a Mon Sep 17 00:00:00 2001 From: Lars Hampe Date: Tue, 12 Nov 2024 17:33:20 +0100 Subject: [PATCH] feat(api): add access-token tests --- .../api/src/access-token/access-token.test.ts | 151 ++++++++++++++++++ apps/api/src/access-token/delete.ts | 2 +- 2 files changed, 152 insertions(+), 1 deletion(-) create mode 100644 apps/api/src/access-token/access-token.test.ts diff --git a/apps/api/src/access-token/access-token.test.ts b/apps/api/src/access-token/access-token.test.ts new file mode 100644 index 0000000..d30bc20 --- /dev/null +++ b/apps/api/src/access-token/access-token.test.ts @@ -0,0 +1,151 @@ +import { afterAll, beforeAll, describe, expect, test } from 'bun:test' +import { access_token, db, user } from '@boring.tools/database' +import type { + AccessTokenCreateInput, + AccessTokenListOutput, + AccessTokenOutput, + ChangelogCreateInput, + ChangelogCreateOutput, + ChangelogListOutput, + ChangelogOutput, + UserOutput, +} from '@boring.tools/schema' +import type { z } from '@hono/zod-openapi' +import { eq } from 'drizzle-orm' +import { fetch } from '../utils/testing/fetch' + +describe('AccessToken', () => { + let testUser: z.infer + let testAccessToken: z.infer + let createdAccessToken: z.infer + let testChangelog: z.infer + + beforeAll(async () => { + const createdUser = await db + .insert(user) + .values({ email: 'access_token@test.local', providerId: 'test_000' }) + .returning() + const tAccessToken = await db + .insert(access_token) + .values({ + token: '1234567890', + userId: createdUser[0].id, + name: 'testtoken', + }) + .returning() + testAccessToken = tAccessToken[0] as z.infer + testUser = createdUser[0] as z.infer + }) + + afterAll(async () => { + await db.delete(user).where(eq(user.email, 'access_token@test.local')) + }) + + describe('Create', () => { + test('Success', async () => { + const payload: z.infer = { + name: 'Test Token', + } + + const res = await fetch( + { + path: '/v1/access-token', + method: 'POST', + body: payload, + }, + testAccessToken.token as string, + ) + + const json = (await res.json()) as z.infer + + createdAccessToken = json + expect(res.status).toBe(201) + }) + }) + + // describe('By Id', () => { + // test('Success', async () => { + // const res = await fetch( + // { + // path: `/v1/changelog/${testChangelog.id}`, + // method: 'GET', + // }, + // testAccessToken.token as string, + // ) + + // expect(res.status).toBe(200) + // }) + + // test('Not Found', async () => { + // const res = await fetch( + // { + // path: '/v1/changelog/635f4aa7-79fc-4d6b-af7d-6731999cc8bb', + // method: 'GET', + // }, + // testAccessToken.token as string, + // ) + + // expect(res.status).toBe(404) + // }) + + // test('Invalid Id', async () => { + // const res = await fetch( + // { + // path: '/v1/changelog/some', + // method: 'GET', + // }, + // testAccessToken.token as string, + // ) + + // expect(res.status).toBe(400) + + // const json = (await res.json()) as { success: boolean } + // expect(json.success).toBeFalse() + // }) + // }) + + describe('List', () => { + test('Success', async () => { + const res = await fetch( + { + path: '/v1/access-token', + method: 'GET', + }, + testAccessToken.token as string, + ) + + expect(res.status).toBe(200) + + const json = (await res.json()) as z.infer + // Check if token is redacted + expect(json[0].token).toHaveLength(10) + expect(json).toHaveLength(2) + }) + }) + + describe('Remove', () => { + test('Success', async () => { + const res = await fetch( + { + path: `/v1/access-token/${createdAccessToken.id}`, + method: 'DELETE', + }, + testAccessToken.token as string, + ) + + expect(res.status).toBe(200) + }) + + test('Not found', async () => { + const res = await fetch( + { + path: `/v1/access-token/${createdAccessToken.id}`, + method: 'DELETE', + }, + testAccessToken.token as string, + ) + + expect(res.status).toBe(404) + }) + }) +}) diff --git a/apps/api/src/access-token/delete.ts b/apps/api/src/access-token/delete.ts index 3cd0585..8a675f8 100644 --- a/apps/api/src/access-token/delete.ts +++ b/apps/api/src/access-token/delete.ts @@ -29,7 +29,7 @@ export const registerAccessTokenDelete = (api: typeof accessTokenApi) => { const id = c.req.param('id') const userId = await verifyAuthentication(c) - const result = await db + const [result] = await db .delete(access_token) .where(and(eq(access_token.userId, userId), eq(access_token.id, id))) .returning()