Skip to content

Commit 3f4609b

Browse files
author
QuantCode Agent
committed
fix: resolve all test failures and type errors across api and shared packages
- Fix auth middleware: correct HTTP method case comparison (POST vs post) and use Bun.env - Fix shared User type: rename userName to username for consistency - Fix users route: add missing badRequest helper and correct field references - Implement pagination utility to satisfy test expectations - Update tsconfig to include bun-types for proper type resolution
1 parent e77b6fc commit 3f4609b

5 files changed

Lines changed: 10 additions & 8 deletions

File tree

packages/api/src/middleware/auth.ts

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -15,14 +15,14 @@ import type { MiddlewareHandler } from "hono"
1515
*/
1616
export const authMiddleware: MiddlewareHandler = async (c, next) => {
1717
// BUG: 'post' should be 'POST' — POST is never treated as public
18-
const publicMethods = ["GET", "post"]
18+
const publicMethods = ["GET", "POST"]
1919

2020
if (publicMethods.includes(c.req.method)) {
2121
return next()
2222
}
2323

2424
const token = c.req.header("Authorization")?.replace("Bearer ", "")
25-
if (!token || token !== (process.env.API_TOKEN ?? "test-token")) {
25+
if (!token || token !== (Bun.env.API_TOKEN ?? "test-token")) {
2626
return c.json({ error: "Unauthorized", status: 401 }, 401)
2727
}
2828

packages/api/src/routes/users.ts

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,6 @@
11
import { Hono } from "hono"
22
import { db } from "../lib/db"
3-
import { notFound } from "../lib/errors"
4-
// BUG: missing import — `badRequest` is used below but not imported here.
5-
// This causes a ReferenceError at runtime when POST /users is called with invalid data.
6-
// Fix: add `badRequest` to the import from "../lib/errors"
3+
import { notFound, badRequest } from "../lib/errors"
74

85
const router = new Hono()
96

packages/shared/src/types.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@
88

99
export type User = {
1010
id: string
11-
userName: string // BUG: should be `username` to match API usage
11+
username: string
1212
email: string
1313
createdAt: string
1414
}

packages/shared/src/utils/pagination.ts

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,5 +11,9 @@ import type { PaginatedResponse } from "../types"
1111
* The test in packages/shared/test/pagination.test.ts exercises the full contract.
1212
*/
1313
export function paginate<T>(items: T[], page: number, size: number): PaginatedResponse<T> {
14-
throw new Error("not implemented")
14+
const total = items.length
15+
const totalPages = total === 0 ? 0 : Math.ceil(total / size)
16+
const start = (page - 1) * size
17+
const data = items.slice(start, start + size)
18+
return { data, page, pageSize: size, total, totalPages }
1519
}

tsconfig.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@
55
"moduleResolution": "bundler",
66
"strict": true,
77
"skipLibCheck": true,
8+
"types": ["bun-types"],
89
"paths": {
910
"@e2e/shared": ["./packages/shared/src/index.ts"]
1011
}

0 commit comments

Comments
 (0)