summaryrefslogtreecommitdiffhomepage
path: root/packages
diff options
context:
space:
mode:
authorKit Langton <[email protected]>2026-04-27 16:29:58 -0400
committerGitHub <[email protected]>2026-04-27 16:29:58 -0400
commitf584f80219b97ea6b7d66b559cb1dc1f21ab9f01 (patch)
tree10a68ffae2214fcc901122978a30e4ad843507dc /packages
parent45eac589f8f26fcaab8341382044684697278694 (diff)
downloadopencode-f584f80219b97ea6b7d66b559cb1dc1f21ab9f01.tar.gz
opencode-f584f80219b97ea6b7d66b559cb1dc1f21ab9f01.zip
test(httpapi): verify reflected route mounts (#24663)
Diffstat (limited to 'packages')
-rw-r--r--packages/opencode/test/server/httpapi-bridge.test.ts65
1 files changed, 64 insertions, 1 deletions
diff --git a/packages/opencode/test/server/httpapi-bridge.test.ts b/packages/opencode/test/server/httpapi-bridge.test.ts
index dac23a654..4417cc446 100644
--- a/packages/opencode/test/server/httpapi-bridge.test.ts
+++ b/packages/opencode/test/server/httpapi-bridge.test.ts
@@ -4,8 +4,23 @@ import { Flag } from "@opencode-ai/core/flag/flag"
import { Instance } from "../../src/project/instance"
import { InstanceRoutes } from "../../src/server/routes/instance"
import { WorkspaceRoutes } from "../../src/server/routes/control/workspace"
-import { FilePaths } from "../../src/server/routes/instance/httpapi/file"
+import { ConfigApi } from "../../src/server/routes/instance/httpapi/config"
+import { EventPaths } from "../../src/server/routes/instance/httpapi/event"
+import { ExperimentalApi } from "../../src/server/routes/instance/httpapi/experimental"
+import { FileApi, FilePaths } from "../../src/server/routes/instance/httpapi/file"
+import { InstanceApi } from "../../src/server/routes/instance/httpapi/instance"
+import { McpApi } from "../../src/server/routes/instance/httpapi/mcp"
+import { PermissionApi } from "../../src/server/routes/instance/httpapi/permission"
+import { ProjectApi } from "../../src/server/routes/instance/httpapi/project"
+import { ProviderApi } from "../../src/server/routes/instance/httpapi/provider"
+import { PtyApi, PtyPaths } from "../../src/server/routes/instance/httpapi/pty"
+import { QuestionApi } from "../../src/server/routes/instance/httpapi/question"
+import { SessionApi } from "../../src/server/routes/instance/httpapi/session"
+import { SyncApi } from "../../src/server/routes/instance/httpapi/sync"
+import { TuiApi } from "../../src/server/routes/instance/httpapi/tui"
+import { WorkspaceApi } from "../../src/server/routes/instance/httpapi/workspace"
import * as Log from "@opencode-ai/core/util/log"
+import { HttpApi, HttpApiGroup } from "effect/unstable/httpapi"
import { resetDatabase } from "../fixture/db"
import { tmpdir } from "../fixture/fixture"
@@ -30,6 +45,39 @@ function routeKey(route: ReturnType<typeof InstanceRoutes>["routes"][number]) {
return `${route.method} ${route.path}`
}
+function reflectedHttpApiRoutes() {
+ const routes = [
+ `GET ${EventPaths.event}`,
+ `GET ${PtyPaths.connect}`,
+ ]
+
+ function addRoutes<Id extends string, Groups extends HttpApiGroup.Any>(api: HttpApi.HttpApi<Id, Groups>) {
+ HttpApi.reflect(api, {
+ onGroup() {},
+ onEndpoint({ endpoint }) {
+ routes.push(`${endpoint.method} ${endpoint.path}`)
+ },
+ })
+ }
+
+ addRoutes(ConfigApi)
+ addRoutes(ExperimentalApi)
+ addRoutes(FileApi)
+ addRoutes(InstanceApi)
+ addRoutes(McpApi)
+ addRoutes(PermissionApi)
+ addRoutes(ProjectApi)
+ addRoutes(ProviderApi)
+ addRoutes(PtyApi)
+ addRoutes(QuestionApi)
+ addRoutes(SessionApi)
+ addRoutes(SyncApi)
+ addRoutes(TuiApi)
+ addRoutes(WorkspaceApi)
+
+ return [...new Set(routes)]
+}
+
function authorization(username: string, password: string) {
return `Basic ${Buffer.from(`${username}:${password}`).toString("base64")}`
}
@@ -69,6 +117,21 @@ describe("HttpApi Hono bridge", () => {
expect([...bridgeRoutes].filter((route) => !legacyRoutes.includes(route)).sort()).toEqual([])
})
+ test("mounts every Effect HttpApi route through the Hono bridge", () => {
+ Flag.OPENCODE_EXPERIMENTAL_HTTPAPI = false
+ const legacy = InstanceRoutes(websocket)
+ Flag.OPENCODE_EXPERIMENTAL_HTTPAPI = true
+ const experimental = InstanceRoutes(websocket)
+
+ const bridgeRoutes = new Set(
+ experimental.routes.slice(0, experimental.routes.length - legacy.routes.length).map(routeKey),
+ )
+ const httpApiRoutes = reflectedHttpApiRoutes()
+
+ expect(httpApiRoutes.filter((route) => !bridgeRoutes.has(route))).toEqual([])
+ expect([...bridgeRoutes].filter((route) => !httpApiRoutes.includes(route)).sort()).toEqual([])
+ })
+
test("allows requests when auth is disabled", async () => {
await using tmp = await tmpdir({ git: true })
await Bun.write(`${tmp.path}/hello.txt`, "hello")