pilothub 0.0.1 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -0
- package/README.md +36 -129
- package/dist/browserAuth.d.ts +20 -0
- package/dist/browserAuth.js +156 -0
- package/dist/browserAuth.js.map +1 -0
- package/dist/browserAuth.test.d.ts +1 -0
- package/dist/browserAuth.test.js +83 -0
- package/dist/browserAuth.test.js.map +1 -0
- package/dist/cli/buildInfo.d.ts +3 -0
- package/dist/cli/buildInfo.js +103 -0
- package/dist/cli/buildInfo.js.map +1 -0
- package/dist/cli/commands/auth.d.ts +9 -0
- package/dist/cli/commands/auth.js +75 -0
- package/dist/cli/commands/auth.js.map +1 -0
- package/dist/cli/commands/delete.d.ts +11 -0
- package/dist/cli/commands/delete.js +67 -0
- package/dist/cli/commands/delete.js.map +1 -0
- package/dist/cli/commands/delete.test.d.ts +1 -0
- package/dist/cli/commands/delete.test.js +52 -0
- package/dist/cli/commands/delete.test.js.map +1 -0
- package/dist/cli/commands/publish.d.ts +9 -0
- package/dist/cli/commands/publish.js +87 -0
- package/dist/cli/commands/publish.js.map +1 -0
- package/dist/cli/commands/publish.test.d.ts +1 -0
- package/dist/cli/commands/publish.test.js +104 -0
- package/dist/cli/commands/publish.test.js.map +1 -0
- package/dist/cli/commands/skills.d.ts +23 -0
- package/dist/cli/commands/skills.js +298 -0
- package/dist/cli/commands/skills.js.map +1 -0
- package/dist/cli/commands/skills.test.d.ts +1 -0
- package/dist/cli/commands/skills.test.js +156 -0
- package/dist/cli/commands/skills.test.js.map +1 -0
- package/dist/cli/commands/star.d.ts +8 -0
- package/dist/cli/commands/star.js +38 -0
- package/dist/cli/commands/star.js.map +1 -0
- package/dist/cli/commands/sync.d.ts +3 -0
- package/dist/cli/commands/sync.js +160 -0
- package/dist/cli/commands/sync.js.map +1 -0
- package/dist/cli/commands/sync.test.d.ts +1 -0
- package/dist/cli/commands/sync.test.js +277 -0
- package/dist/cli/commands/sync.test.js.map +1 -0
- package/dist/cli/commands/syncHelpers.d.ts +76 -0
- package/dist/cli/commands/syncHelpers.js +349 -0
- package/dist/cli/commands/syncHelpers.js.map +1 -0
- package/dist/cli/commands/syncHelpers.test.d.ts +1 -0
- package/dist/cli/commands/syncHelpers.test.js +22 -0
- package/dist/cli/commands/syncHelpers.test.js.map +1 -0
- package/dist/cli/commands/syncTypes.d.ts +24 -0
- package/dist/cli/commands/syncTypes.js +2 -0
- package/dist/cli/commands/syncTypes.js.map +1 -0
- package/dist/cli/commands/unstar.d.ts +8 -0
- package/dist/cli/commands/unstar.js +38 -0
- package/dist/cli/commands/unstar.js.map +1 -0
- package/dist/cli/helpStyle.d.ts +13 -0
- package/dist/cli/helpStyle.js +38 -0
- package/dist/cli/helpStyle.js.map +1 -0
- package/dist/cli/pilotbotConfig.d.ts +6 -0
- package/dist/cli/pilotbotConfig.js +110 -0
- package/dist/cli/pilotbotConfig.js.map +1 -0
- package/dist/cli/pilotbotConfig.test.d.ts +1 -0
- package/dist/cli/pilotbotConfig.test.js +133 -0
- package/dist/cli/pilotbotConfig.test.js.map +1 -0
- package/dist/cli/registry.d.ts +7 -0
- package/dist/cli/registry.js +42 -0
- package/dist/cli/registry.js.map +1 -0
- package/dist/cli/registry.test.d.ts +1 -0
- package/dist/cli/registry.test.js +48 -0
- package/dist/cli/registry.test.js.map +1 -0
- package/dist/cli/scanSkills.d.ts +7 -0
- package/dist/cli/scanSkills.js +75 -0
- package/dist/cli/scanSkills.js.map +1 -0
- package/dist/cli/scanSkills.test.d.ts +1 -0
- package/dist/cli/scanSkills.test.js +60 -0
- package/dist/cli/scanSkills.test.js.map +1 -0
- package/dist/cli/slug.d.ts +2 -0
- package/dist/cli/slug.js +16 -0
- package/dist/cli/slug.js.map +1 -0
- package/dist/cli/types.d.ts +15 -0
- package/dist/cli/types.js +2 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/cli/ui.d.ts +7 -0
- package/dist/cli/ui.js +72 -0
- package/dist/cli/ui.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +268 -0
- package/dist/cli.js.map +1 -0
- package/dist/config.d.ts +4 -0
- package/dist/config.js +38 -0
- package/dist/config.js.map +1 -0
- package/dist/discovery.d.ts +5 -0
- package/dist/discovery.js +21 -0
- package/dist/discovery.js.map +1 -0
- package/dist/discovery.test.d.ts +1 -0
- package/dist/discovery.test.js +46 -0
- package/dist/discovery.test.js.map +1 -0
- package/dist/http.d.ts +32 -0
- package/dist/http.js +261 -0
- package/dist/http.js.map +1 -0
- package/dist/http.test.d.ts +1 -0
- package/dist/http.test.js +135 -0
- package/dist/http.test.js.map +1 -0
- package/dist/schema/ark.js.map +1 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/routes.js.map +1 -0
- package/{packages/schema/dist → dist/schema}/schemas.d.ts +0 -39
- package/{packages/schema/dist → dist/schema}/schemas.js +0 -22
- package/dist/schema/schemas.js.map +1 -0
- package/dist/schema/textFiles.js.map +1 -0
- package/dist/schema/textFiles.test.d.ts +1 -0
- package/dist/schema/textFiles.test.js +20 -0
- package/dist/schema/textFiles.test.js.map +1 -0
- package/dist/skills.d.ts +43 -0
- package/dist/skills.js +163 -0
- package/dist/skills.js.map +1 -0
- package/dist/skills.test.d.ts +1 -0
- package/dist/skills.test.js +144 -0
- package/dist/skills.test.js.map +1 -0
- package/dist/types.d.ts +7 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +27 -70
- package/.env.local.example +0 -19
- package/.github/workflows/ci.yml +0 -40
- package/.oxlintrc.json +0 -3
- package/AGENTS.md +0 -45
- package/CHANGELOG.md +0 -138
- package/DEPRECATIONS.md +0 -7
- package/biome.json +0 -41
- package/convex/_generated/api.d.ts +0 -153
- package/convex/_generated/api.js +0 -23
- package/convex/_generated/dataModel.d.ts +0 -60
- package/convex/_generated/server.d.ts +0 -143
- package/convex/_generated/server.js +0 -93
- package/convex/auth.config.ts +0 -8
- package/convex/auth.ts +0 -19
- package/convex/comments.ts +0 -88
- package/convex/crons.ts +0 -34
- package/convex/devSeed.ts +0 -459
- package/convex/devSeedExtra.ts +0 -541
- package/convex/downloads.ts +0 -78
- package/convex/githubBackups.ts +0 -170
- package/convex/githubBackupsNode.ts +0 -183
- package/convex/githubImport.ts +0 -317
- package/convex/githubSoulBackups.ts +0 -170
- package/convex/githubSoulBackupsNode.ts +0 -186
- package/convex/http.ts +0 -194
- package/convex/httpApi.handlers.test.ts +0 -488
- package/convex/httpApi.test.ts +0 -70
- package/convex/httpApi.ts +0 -305
- package/convex/httpApiV1.handlers.test.ts +0 -584
- package/convex/httpApiV1.ts +0 -1172
- package/convex/leaderboards.ts +0 -39
- package/convex/lib/access.ts +0 -36
- package/convex/lib/apiTokenAuth.ts +0 -36
- package/convex/lib/badges.ts +0 -50
- package/convex/lib/changelog.test.ts +0 -34
- package/convex/lib/changelog.ts +0 -278
- package/convex/lib/embeddings.ts +0 -38
- package/convex/lib/githubBackup.ts +0 -443
- package/convex/lib/githubImport.test.ts +0 -247
- package/convex/lib/githubImport.ts +0 -425
- package/convex/lib/githubSoulBackup.ts +0 -443
- package/convex/lib/leaderboards.ts +0 -103
- package/convex/lib/moderation.ts +0 -42
- package/convex/lib/public.ts +0 -89
- package/convex/lib/searchText.test.ts +0 -46
- package/convex/lib/searchText.ts +0 -27
- package/convex/lib/skillBackfill.test.ts +0 -34
- package/convex/lib/skillBackfill.ts +0 -67
- package/convex/lib/skillPublish.test.ts +0 -28
- package/convex/lib/skillPublish.ts +0 -284
- package/convex/lib/skillStats.ts +0 -80
- package/convex/lib/skills.test.ts +0 -197
- package/convex/lib/skills.ts +0 -273
- package/convex/lib/soulChangelog.ts +0 -273
- package/convex/lib/soulPublish.ts +0 -236
- package/convex/lib/tokens.test.ts +0 -33
- package/convex/lib/tokens.ts +0 -51
- package/convex/lib/webhooks.test.ts +0 -91
- package/convex/lib/webhooks.ts +0 -112
- package/convex/maintenance.test.ts +0 -270
- package/convex/maintenance.ts +0 -840
- package/convex/rateLimits.ts +0 -50
- package/convex/schema.ts +0 -472
- package/convex/search.test.ts +0 -12
- package/convex/search.ts +0 -254
- package/convex/seed.test.ts +0 -37
- package/convex/seed.ts +0 -254
- package/convex/seedSouls.ts +0 -111
- package/convex/skillStatEvents.ts +0 -568
- package/convex/skills.ts +0 -1606
- package/convex/soulComments.ts +0 -88
- package/convex/soulDownloads.ts +0 -14
- package/convex/soulStars.ts +0 -71
- package/convex/souls.ts +0 -570
- package/convex/stars.ts +0 -108
- package/convex/statsMaintenance.ts +0 -205
- package/convex/telemetry.ts +0 -434
- package/convex/tokens.ts +0 -88
- package/convex/tsconfig.json +0 -7
- package/convex/uploads.ts +0 -20
- package/convex/users.ts +0 -122
- package/convex/webhooks.ts +0 -50
- package/convex.json +0 -3
- package/docs/README.md +0 -32
- package/docs/api.md +0 -51
- package/docs/architecture.md +0 -61
- package/docs/auth.md +0 -54
- package/docs/cli.md +0 -117
- package/docs/deploy.md +0 -78
- package/docs/diffing.md +0 -84
- package/docs/github-import.md +0 -171
- package/docs/http-api.md +0 -187
- package/docs/manual-testing.md +0 -64
- package/docs/mintlify.md +0 -43
- package/docs/quickstart.md +0 -120
- package/docs/skill-format.md +0 -58
- package/docs/soul-format.md +0 -37
- package/docs/spec.md +0 -177
- package/docs/telemetry.md +0 -91
- package/docs/troubleshooting.md +0 -49
- package/docs/webhook.md +0 -51
- package/e2e/menu-smoke.pw.test.ts +0 -49
- package/e2e/pilothub.e2e.test.ts +0 -494
- package/e2e/search-exact.pw.test.ts +0 -97
- package/packages/pilothub/LICENSE +0 -22
- package/packages/pilothub/README.md +0 -57
- package/packages/pilothub/package.json +0 -41
- package/packages/pilothub/src/browserAuth.test.ts +0 -96
- package/packages/pilothub/src/browserAuth.ts +0 -174
- package/packages/pilothub/src/cli/buildInfo.ts +0 -94
- package/packages/pilothub/src/cli/commands/auth.ts +0 -97
- package/packages/pilothub/src/cli/commands/delete.test.ts +0 -73
- package/packages/pilothub/src/cli/commands/delete.ts +0 -83
- package/packages/pilothub/src/cli/commands/publish.test.ts +0 -122
- package/packages/pilothub/src/cli/commands/publish.ts +0 -108
- package/packages/pilothub/src/cli/commands/skills.test.ts +0 -191
- package/packages/pilothub/src/cli/commands/skills.ts +0 -380
- package/packages/pilothub/src/cli/commands/star.ts +0 -46
- package/packages/pilothub/src/cli/commands/sync.test.ts +0 -310
- package/packages/pilothub/src/cli/commands/sync.ts +0 -200
- package/packages/pilothub/src/cli/commands/syncHelpers.test.ts +0 -26
- package/packages/pilothub/src/cli/commands/syncHelpers.ts +0 -427
- package/packages/pilothub/src/cli/commands/syncTypes.ts +0 -27
- package/packages/pilothub/src/cli/commands/unstar.ts +0 -48
- package/packages/pilothub/src/cli/helpStyle.ts +0 -45
- package/packages/pilothub/src/cli/pilotbotConfig.test.ts +0 -159
- package/packages/pilothub/src/cli/pilotbotConfig.ts +0 -147
- package/packages/pilothub/src/cli/registry.test.ts +0 -63
- package/packages/pilothub/src/cli/registry.ts +0 -43
- package/packages/pilothub/src/cli/scanSkills.test.ts +0 -64
- package/packages/pilothub/src/cli/scanSkills.ts +0 -84
- package/packages/pilothub/src/cli/slug.ts +0 -16
- package/packages/pilothub/src/cli/types.ts +0 -12
- package/packages/pilothub/src/cli/ui.ts +0 -75
- package/packages/pilothub/src/cli.ts +0 -311
- package/packages/pilothub/src/config.ts +0 -36
- package/packages/pilothub/src/discovery.test.ts +0 -75
- package/packages/pilothub/src/discovery.ts +0 -19
- package/packages/pilothub/src/http.test.ts +0 -156
- package/packages/pilothub/src/http.ts +0 -301
- package/packages/pilothub/src/schema/ark.ts +0 -29
- package/packages/pilothub/src/schema/index.ts +0 -5
- package/packages/pilothub/src/schema/routes.ts +0 -22
- package/packages/pilothub/src/schema/schemas.ts +0 -260
- package/packages/pilothub/src/schema/textFiles.test.ts +0 -23
- package/packages/pilothub/src/schema/textFiles.ts +0 -66
- package/packages/pilothub/src/skills.test.ts +0 -191
- package/packages/pilothub/src/skills.ts +0 -172
- package/packages/pilothub/src/types.ts +0 -10
- package/packages/pilothub/tsconfig.json +0 -14
- package/packages/schema/README.md +0 -3
- package/packages/schema/dist/ark.js.map +0 -1
- package/packages/schema/dist/index.js.map +0 -1
- package/packages/schema/dist/routes.js.map +0 -1
- package/packages/schema/dist/schemas.js.map +0 -1
- package/packages/schema/dist/textFiles.js.map +0 -1
- package/packages/schema/package.json +0 -26
- package/packages/schema/src/ark.ts +0 -29
- package/packages/schema/src/index.ts +0 -5
- package/packages/schema/src/routes.ts +0 -22
- package/packages/schema/src/schemas.test.ts +0 -123
- package/packages/schema/src/schemas.ts +0 -287
- package/packages/schema/src/textFiles.test.ts +0 -23
- package/packages/schema/src/textFiles.ts +0 -66
- package/packages/schema/tsconfig.json +0 -15
- package/pilothub +0 -46
- package/playwright.config.ts +0 -33
- package/public/.well-known/pilothub.json +0 -6
- package/public/api/v1/openapi.json +0 -379
- package/public/favicon.ico +0 -0
- package/public/logo192.png +0 -0
- package/public/logo512.png +0 -0
- package/public/manifest.json +0 -25
- package/public/og.png +0 -0
- package/public/og.svg +0 -98
- package/public/pilot-logo.png +0 -0
- package/public/pilot-mark.png +0 -0
- package/public/robots.txt +0 -3
- package/public/tanstack-circle-logo.png +0 -0
- package/public/tanstack-word-logo-white.svg +0 -1
- package/scripts/check-peer-deps.ts +0 -56
- package/scripts/docs-list.ts +0 -148
- package/scripts/run-playwright-local.sh +0 -14
- package/server/og/fetchSkillOgMeta.ts +0 -27
- package/server/og/fetchSoulOgMeta.ts +0 -27
- package/server/og/ogAssets.ts +0 -80
- package/server/og/skillOgSvg.test.ts +0 -59
- package/server/og/skillOgSvg.ts +0 -258
- package/server/og/soulOgSvg.ts +0 -209
- package/server/routes/og/skill.png.ts +0 -103
- package/server/routes/og/soul.png.ts +0 -111
- package/src/__tests__/skill-detail-page.test.tsx +0 -86
- package/src/__tests__/skills-index.test.tsx +0 -145
- package/src/__tests__/upload.route.test.tsx +0 -228
- package/src/components/AppProviders.tsx +0 -19
- package/src/components/ClientOnly.tsx +0 -18
- package/src/components/Footer.tsx +0 -29
- package/src/components/Header.tsx +0 -295
- package/src/components/InstallSwitcher.tsx +0 -53
- package/src/components/SkillCard.tsx +0 -36
- package/src/components/SkillDetailPage.tsx +0 -817
- package/src/components/SkillDiffCard.tsx +0 -485
- package/src/components/SoulCard.tsx +0 -19
- package/src/components/SoulDetailPage.tsx +0 -263
- package/src/components/UserBootstrap.tsx +0 -18
- package/src/components/ui/dropdown-menu.tsx +0 -67
- package/src/components/ui/toggle-group.tsx +0 -35
- package/src/convex/client.ts +0 -3
- package/src/lib/badges.ts +0 -29
- package/src/lib/diffing.test.ts +0 -163
- package/src/lib/diffing.ts +0 -106
- package/src/lib/gravatar.test.ts +0 -9
- package/src/lib/gravatar.ts +0 -158
- package/src/lib/og.test.ts +0 -142
- package/src/lib/og.ts +0 -156
- package/src/lib/publicUser.ts +0 -39
- package/src/lib/roles.ts +0 -19
- package/src/lib/site.test.ts +0 -130
- package/src/lib/site.ts +0 -84
- package/src/lib/theme-transition.test.ts +0 -134
- package/src/lib/theme-transition.ts +0 -134
- package/src/lib/theme.test.tsx +0 -88
- package/src/lib/theme.ts +0 -43
- package/src/lib/uploadFiles.jsdom.test.ts +0 -33
- package/src/lib/uploadFiles.test.ts +0 -123
- package/src/lib/uploadFiles.ts +0 -245
- package/src/lib/uploadUtils.test.ts +0 -78
- package/src/lib/uploadUtils.ts +0 -93
- package/src/lib/useAuthStatus.ts +0 -12
- package/src/lib/utils.test.ts +0 -9
- package/src/lib/utils.ts +0 -6
- package/src/logo.svg +0 -12
- package/src/routeTree.gen.ts +0 -345
- package/src/router.tsx +0 -17
- package/src/routes/$owner/$slug.tsx +0 -55
- package/src/routes/__root.tsx +0 -136
- package/src/routes/admin.tsx +0 -11
- package/src/routes/cli/auth.tsx +0 -168
- package/src/routes/dashboard.tsx +0 -97
- package/src/routes/import.tsx +0 -415
- package/src/routes/index.tsx +0 -252
- package/src/routes/management.tsx +0 -529
- package/src/routes/settings.tsx +0 -203
- package/src/routes/skills/index.tsx +0 -422
- package/src/routes/souls/$slug.tsx +0 -55
- package/src/routes/souls/index.tsx +0 -243
- package/src/routes/stars.tsx +0 -68
- package/src/routes/u/$handle.tsx +0 -307
- package/src/routes/upload/utils.ts +0 -81
- package/src/routes/upload.tsx +0 -499
- package/src/styles.css +0 -2718
- package/tsconfig.json +0 -24
- package/tsconfig.oxlint.json +0 -16
- package/vercel.json +0 -8
- package/vite.config.ts +0 -48
- package/vitest.config.ts +0 -47
- package/vitest.e2e.config.ts +0 -11
- package/vitest.setup.ts +0 -1
- /package/{packages/pilothub/bin → bin}/pilothub.js +0 -0
- /package/{packages/schema/dist → dist/schema}/ark.d.ts +0 -0
- /package/{packages/schema/dist → dist/schema}/ark.js +0 -0
- /package/{packages/schema/dist → dist/schema}/index.d.ts +0 -0
- /package/{packages/schema/dist → dist/schema}/index.js +0 -0
- /package/{packages/schema/dist → dist/schema}/routes.d.ts +0 -0
- /package/{packages/schema/dist → dist/schema}/routes.js +0 -0
- /package/{packages/schema/dist → dist/schema}/textFiles.d.ts +0 -0
- /package/{packages/schema/dist → dist/schema}/textFiles.js +0 -0
|
@@ -1,488 +0,0 @@
|
|
|
1
|
-
/* @vitest-environment node */
|
|
2
|
-
import { afterEach, describe, expect, it, vi } from 'vitest'
|
|
3
|
-
|
|
4
|
-
vi.mock('./lib/apiTokenAuth', () => ({
|
|
5
|
-
requireApiTokenUser: vi.fn(),
|
|
6
|
-
}))
|
|
7
|
-
|
|
8
|
-
vi.mock('./skills', () => ({
|
|
9
|
-
publishVersionForUser: vi.fn(),
|
|
10
|
-
}))
|
|
11
|
-
|
|
12
|
-
const { requireApiTokenUser } = await import('./lib/apiTokenAuth')
|
|
13
|
-
const { publishVersionForUser } = await import('./skills')
|
|
14
|
-
const { __handlers } = await import('./httpApi')
|
|
15
|
-
const { hashSkillFiles } = await import('./lib/skills')
|
|
16
|
-
|
|
17
|
-
function makeCtx(partial: Record<string, unknown>) {
|
|
18
|
-
return partial as unknown as import('./_generated/server').ActionCtx
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
describe('httpApi handlers', () => {
|
|
22
|
-
afterEach(() => {
|
|
23
|
-
vi.mocked(requireApiTokenUser).mockReset()
|
|
24
|
-
vi.mocked(publishVersionForUser).mockReset()
|
|
25
|
-
})
|
|
26
|
-
|
|
27
|
-
it('searchSkillsHttp returns empty results for empty query', async () => {
|
|
28
|
-
const response = await __handlers.searchSkillsHandler(
|
|
29
|
-
makeCtx({ runAction: vi.fn() }),
|
|
30
|
-
new Request('https://example.com/api/search?q=%20%20'),
|
|
31
|
-
)
|
|
32
|
-
expect(response.status).toBe(200)
|
|
33
|
-
expect(await response.json()).toEqual({ results: [] })
|
|
34
|
-
})
|
|
35
|
-
|
|
36
|
-
it('searchSkillsHttp forwards args (approvedOnly alias)', async () => {
|
|
37
|
-
const runAction = vi.fn().mockResolvedValue([
|
|
38
|
-
{
|
|
39
|
-
score: 1,
|
|
40
|
-
skill: { slug: 'a', displayName: 'A', summary: null, updatedAt: 1 },
|
|
41
|
-
version: null,
|
|
42
|
-
},
|
|
43
|
-
])
|
|
44
|
-
const response = await __handlers.searchSkillsHandler(
|
|
45
|
-
makeCtx({ runAction }),
|
|
46
|
-
new Request('https://example.com/api/search?q=test&approvedOnly=true&limit=5'),
|
|
47
|
-
)
|
|
48
|
-
expect(runAction).toHaveBeenCalledWith(expect.anything(), {
|
|
49
|
-
query: 'test',
|
|
50
|
-
limit: 5,
|
|
51
|
-
highlightedOnly: true,
|
|
52
|
-
})
|
|
53
|
-
expect(response.status).toBe(200)
|
|
54
|
-
const json = await response.json()
|
|
55
|
-
expect(json.results[0].slug).toBe('a')
|
|
56
|
-
})
|
|
57
|
-
|
|
58
|
-
it('searchSkillsHttp forwards highlightedOnly', async () => {
|
|
59
|
-
const runAction = vi.fn().mockResolvedValue([])
|
|
60
|
-
await __handlers.searchSkillsHandler(
|
|
61
|
-
makeCtx({ runAction }),
|
|
62
|
-
new Request('https://example.com/api/search?q=test&highlightedOnly=true'),
|
|
63
|
-
)
|
|
64
|
-
expect(runAction).toHaveBeenCalledWith(expect.anything(), {
|
|
65
|
-
query: 'test',
|
|
66
|
-
limit: undefined,
|
|
67
|
-
highlightedOnly: true,
|
|
68
|
-
})
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
it('searchSkillsHttp omits highlightedOnly when approvedOnly is false', async () => {
|
|
72
|
-
const runAction = vi.fn().mockResolvedValue([])
|
|
73
|
-
await __handlers.searchSkillsHandler(
|
|
74
|
-
makeCtx({ runAction }),
|
|
75
|
-
new Request('https://example.com/api/search?q=test&approvedOnly=false'),
|
|
76
|
-
)
|
|
77
|
-
expect(runAction).toHaveBeenCalledWith(expect.anything(), {
|
|
78
|
-
query: 'test',
|
|
79
|
-
limit: undefined,
|
|
80
|
-
highlightedOnly: undefined,
|
|
81
|
-
})
|
|
82
|
-
})
|
|
83
|
-
|
|
84
|
-
it('getSkillHttp validates slug', async () => {
|
|
85
|
-
const response = await __handlers.getSkillHandler(
|
|
86
|
-
makeCtx({ runQuery: vi.fn() }),
|
|
87
|
-
new Request('https://example.com/api/skill'),
|
|
88
|
-
)
|
|
89
|
-
expect(response.status).toBe(400)
|
|
90
|
-
})
|
|
91
|
-
|
|
92
|
-
it('getSkillHttp returns 404 when missing', async () => {
|
|
93
|
-
const runQuery = vi.fn().mockResolvedValue(null)
|
|
94
|
-
const response = await __handlers.getSkillHandler(
|
|
95
|
-
makeCtx({ runQuery }),
|
|
96
|
-
new Request('https://example.com/api/skill?slug=missing'),
|
|
97
|
-
)
|
|
98
|
-
expect(response.status).toBe(404)
|
|
99
|
-
})
|
|
100
|
-
|
|
101
|
-
it('getSkillHttp returns payload with owner and latestVersion', async () => {
|
|
102
|
-
const runQuery = vi.fn().mockResolvedValue({
|
|
103
|
-
skill: {
|
|
104
|
-
slug: 'demo',
|
|
105
|
-
displayName: 'Demo',
|
|
106
|
-
summary: 'x',
|
|
107
|
-
tags: {},
|
|
108
|
-
stats: {
|
|
109
|
-
downloads: 0,
|
|
110
|
-
installsCurrent: 0,
|
|
111
|
-
installsAllTime: 0,
|
|
112
|
-
stars: 0,
|
|
113
|
-
versions: 1,
|
|
114
|
-
comments: 0,
|
|
115
|
-
},
|
|
116
|
-
createdAt: 1,
|
|
117
|
-
updatedAt: 2,
|
|
118
|
-
},
|
|
119
|
-
latestVersion: { version: '1.0.0', createdAt: 3, changelog: 'c' },
|
|
120
|
-
owner: { handle: 'p', displayName: 'Peter', image: null },
|
|
121
|
-
})
|
|
122
|
-
const response = await __handlers.getSkillHandler(
|
|
123
|
-
makeCtx({ runQuery }),
|
|
124
|
-
new Request('https://example.com/api/skill?slug=demo'),
|
|
125
|
-
)
|
|
126
|
-
expect(response.status).toBe(200)
|
|
127
|
-
const json = await response.json()
|
|
128
|
-
expect(json.skill.slug).toBe('demo')
|
|
129
|
-
expect(json.latestVersion.version).toBe('1.0.0')
|
|
130
|
-
expect(json.owner.handle).toBe('p')
|
|
131
|
-
})
|
|
132
|
-
|
|
133
|
-
it('getSkillHttp returns payload with null owner/latestVersion', async () => {
|
|
134
|
-
const runQuery = vi.fn().mockResolvedValue({
|
|
135
|
-
skill: {
|
|
136
|
-
slug: 'demo',
|
|
137
|
-
displayName: 'Demo',
|
|
138
|
-
summary: null,
|
|
139
|
-
tags: {},
|
|
140
|
-
stats: {},
|
|
141
|
-
createdAt: 1,
|
|
142
|
-
updatedAt: 2,
|
|
143
|
-
},
|
|
144
|
-
latestVersion: null,
|
|
145
|
-
owner: null,
|
|
146
|
-
})
|
|
147
|
-
const response = await __handlers.getSkillHandler(
|
|
148
|
-
makeCtx({ runQuery }),
|
|
149
|
-
new Request('https://example.com/api/skill?slug=demo'),
|
|
150
|
-
)
|
|
151
|
-
expect(response.status).toBe(200)
|
|
152
|
-
const json = await response.json()
|
|
153
|
-
expect(json.latestVersion).toBeNull()
|
|
154
|
-
expect(json.owner).toBeNull()
|
|
155
|
-
})
|
|
156
|
-
|
|
157
|
-
it('resolveSkillVersionHttp validates hash', async () => {
|
|
158
|
-
const response = await __handlers.resolveSkillVersionHandler(
|
|
159
|
-
makeCtx({ runQuery: vi.fn() }),
|
|
160
|
-
new Request('https://example.com/api/skill/resolve?slug=demo&hash=bad'),
|
|
161
|
-
)
|
|
162
|
-
expect(response.status).toBe(400)
|
|
163
|
-
})
|
|
164
|
-
|
|
165
|
-
it('resolveSkillVersionHttp returns 404 when missing', async () => {
|
|
166
|
-
const runQuery = vi.fn().mockResolvedValue(null)
|
|
167
|
-
const response = await __handlers.resolveSkillVersionHandler(
|
|
168
|
-
makeCtx({ runQuery }),
|
|
169
|
-
new Request(
|
|
170
|
-
'https://example.com/api/skill/resolve?slug=missing&hash=aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
|
|
171
|
-
),
|
|
172
|
-
)
|
|
173
|
-
expect(response.status).toBe(404)
|
|
174
|
-
})
|
|
175
|
-
|
|
176
|
-
it('resolveSkillVersionHttp returns match and latestVersion', async () => {
|
|
177
|
-
const matchHash = await hashSkillFiles([{ path: 'SKILL.md', sha256: 'abc' }])
|
|
178
|
-
const runQuery = vi.fn().mockResolvedValueOnce({
|
|
179
|
-
match: { version: '1.0.0' },
|
|
180
|
-
latestVersion: { version: '2.0.0' },
|
|
181
|
-
})
|
|
182
|
-
|
|
183
|
-
const response = await __handlers.resolveSkillVersionHandler(
|
|
184
|
-
makeCtx({ runQuery }),
|
|
185
|
-
new Request(`https://example.com/api/skill/resolve?slug=demo&hash=${matchHash}`),
|
|
186
|
-
)
|
|
187
|
-
expect(response.status).toBe(200)
|
|
188
|
-
const json = await response.json()
|
|
189
|
-
expect(json.match.version).toBe('1.0.0')
|
|
190
|
-
expect(json.latestVersion.version).toBe('2.0.0')
|
|
191
|
-
})
|
|
192
|
-
|
|
193
|
-
it('cliWhoamiHttp returns 401 on auth failure', async () => {
|
|
194
|
-
vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
|
|
195
|
-
const response = await __handlers.cliWhoamiHandler(
|
|
196
|
-
makeCtx({}),
|
|
197
|
-
new Request('https://x/api/cli/whoami'),
|
|
198
|
-
)
|
|
199
|
-
expect(response.status).toBe(401)
|
|
200
|
-
})
|
|
201
|
-
|
|
202
|
-
it('cliWhoamiHttp returns user payload on success', async () => {
|
|
203
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({
|
|
204
|
-
user: { handle: 'p', displayName: 'Peter', image: 'x' },
|
|
205
|
-
} as never)
|
|
206
|
-
const response = await __handlers.cliWhoamiHandler(
|
|
207
|
-
makeCtx({}),
|
|
208
|
-
new Request('https://x/api/cli/whoami'),
|
|
209
|
-
)
|
|
210
|
-
expect(response.status).toBe(200)
|
|
211
|
-
const json = await response.json()
|
|
212
|
-
expect(json.user.handle).toBe('p')
|
|
213
|
-
})
|
|
214
|
-
|
|
215
|
-
it('cliTelemetrySyncHttp forwards roots and returns ok', async () => {
|
|
216
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'users:1' } as never)
|
|
217
|
-
const runMutation = vi.fn().mockResolvedValue(null)
|
|
218
|
-
const response = await __handlers.cliTelemetrySyncHandler(
|
|
219
|
-
makeCtx({ runMutation }),
|
|
220
|
-
new Request('https://x/api/cli/telemetry/sync', {
|
|
221
|
-
method: 'POST',
|
|
222
|
-
headers: { 'Content-Type': 'application/json' },
|
|
223
|
-
body: JSON.stringify({
|
|
224
|
-
roots: [
|
|
225
|
-
{
|
|
226
|
-
rootId: 'abc',
|
|
227
|
-
label: '~/skills',
|
|
228
|
-
skills: [{ slug: 'weather', version: null }],
|
|
229
|
-
},
|
|
230
|
-
],
|
|
231
|
-
}),
|
|
232
|
-
}),
|
|
233
|
-
)
|
|
234
|
-
expect(response.status).toBe(200)
|
|
235
|
-
expect(await response.json()).toEqual({ ok: true })
|
|
236
|
-
expect(runMutation).toHaveBeenCalledTimes(1)
|
|
237
|
-
})
|
|
238
|
-
|
|
239
|
-
it('cliTelemetrySyncHttp returns 400 on invalid payload', async () => {
|
|
240
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'users:1' } as never)
|
|
241
|
-
const response = await __handlers.cliTelemetrySyncHandler(
|
|
242
|
-
makeCtx({ runMutation: vi.fn() }),
|
|
243
|
-
new Request('https://x/api/cli/telemetry/sync', {
|
|
244
|
-
method: 'POST',
|
|
245
|
-
headers: { 'Content-Type': 'application/json' },
|
|
246
|
-
body: JSON.stringify({ roots: 'nope' }),
|
|
247
|
-
}),
|
|
248
|
-
)
|
|
249
|
-
expect(response.status).toBe(400)
|
|
250
|
-
})
|
|
251
|
-
|
|
252
|
-
it('cliTelemetrySyncHttp forwards skill versions when provided', async () => {
|
|
253
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'users:1' } as never)
|
|
254
|
-
const runMutation = vi.fn().mockResolvedValue(null)
|
|
255
|
-
await __handlers.cliTelemetrySyncHandler(
|
|
256
|
-
makeCtx({ runMutation }),
|
|
257
|
-
new Request('https://x/api/cli/telemetry/sync', {
|
|
258
|
-
method: 'POST',
|
|
259
|
-
headers: { 'Content-Type': 'application/json' },
|
|
260
|
-
body: JSON.stringify({
|
|
261
|
-
roots: [
|
|
262
|
-
{
|
|
263
|
-
rootId: 'abc',
|
|
264
|
-
label: '~/skills',
|
|
265
|
-
skills: [{ slug: 'weather', version: '1.0.0' }],
|
|
266
|
-
},
|
|
267
|
-
],
|
|
268
|
-
}),
|
|
269
|
-
}),
|
|
270
|
-
)
|
|
271
|
-
expect(runMutation).toHaveBeenCalledWith(expect.anything(), {
|
|
272
|
-
userId: 'users:1',
|
|
273
|
-
roots: [
|
|
274
|
-
{ rootId: 'abc', label: '~/skills', skills: [{ slug: 'weather', version: '1.0.0' }] },
|
|
275
|
-
],
|
|
276
|
-
})
|
|
277
|
-
})
|
|
278
|
-
|
|
279
|
-
it('cliTelemetrySyncHttp returns 400 on invalid json', async () => {
|
|
280
|
-
const request = new Request('https://x/api/cli/telemetry/sync', { method: 'POST', body: '{' })
|
|
281
|
-
const response = await __handlers.cliTelemetrySyncHandler(makeCtx({}), request)
|
|
282
|
-
expect(response.status).toBe(400)
|
|
283
|
-
})
|
|
284
|
-
|
|
285
|
-
it('cliTelemetrySyncHttp returns 401 when unauthorized', async () => {
|
|
286
|
-
vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
|
|
287
|
-
const response = await __handlers.cliTelemetrySyncHandler(
|
|
288
|
-
makeCtx({}),
|
|
289
|
-
new Request('https://x/api/cli/telemetry/sync', {
|
|
290
|
-
method: 'POST',
|
|
291
|
-
headers: { 'Content-Type': 'application/json' },
|
|
292
|
-
body: JSON.stringify({ roots: [] }),
|
|
293
|
-
}),
|
|
294
|
-
)
|
|
295
|
-
expect(response.status).toBe(401)
|
|
296
|
-
})
|
|
297
|
-
|
|
298
|
-
it('cliUploadUrlHttp returns uploadUrl', async () => {
|
|
299
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
300
|
-
const runMutation = vi.fn().mockResolvedValue('https://upload.local')
|
|
301
|
-
const response = await __handlers.cliUploadUrlHandler(
|
|
302
|
-
makeCtx({ runMutation }),
|
|
303
|
-
new Request('https://x/api/cli/upload-url', { method: 'POST' }),
|
|
304
|
-
)
|
|
305
|
-
expect(response.status).toBe(200)
|
|
306
|
-
expect(await response.json()).toEqual({ uploadUrl: 'https://upload.local' })
|
|
307
|
-
})
|
|
308
|
-
|
|
309
|
-
it('cliUploadUrlHttp returns 401 when unauthorized', async () => {
|
|
310
|
-
vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
|
|
311
|
-
const response = await __handlers.cliUploadUrlHandler(
|
|
312
|
-
makeCtx({}),
|
|
313
|
-
new Request('https://x/api/cli/upload-url', { method: 'POST' }),
|
|
314
|
-
)
|
|
315
|
-
expect(response.status).toBe(401)
|
|
316
|
-
})
|
|
317
|
-
|
|
318
|
-
it('cliPublishHttp returns 400 on invalid json', async () => {
|
|
319
|
-
const request = new Request('https://x/api/cli/publish', { method: 'POST', body: '{' })
|
|
320
|
-
const response = await __handlers.cliPublishHandler(makeCtx({}), request)
|
|
321
|
-
expect(response.status).toBe(400)
|
|
322
|
-
})
|
|
323
|
-
|
|
324
|
-
it('cliPublishHttp returns 401 when unauthorized', async () => {
|
|
325
|
-
vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
|
|
326
|
-
const request = new Request('https://x/api/cli/publish', {
|
|
327
|
-
method: 'POST',
|
|
328
|
-
headers: { 'Content-Type': 'application/json' },
|
|
329
|
-
body: JSON.stringify({}),
|
|
330
|
-
})
|
|
331
|
-
const response = await __handlers.cliPublishHandler(makeCtx({}), request)
|
|
332
|
-
expect(response.status).toBe(401)
|
|
333
|
-
})
|
|
334
|
-
|
|
335
|
-
it('cliPublishHttp returns 400 on publish error', async () => {
|
|
336
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
337
|
-
vi.mocked(publishVersionForUser).mockRejectedValueOnce(new Error('Nope'))
|
|
338
|
-
const request = new Request('https://x/api/cli/publish', {
|
|
339
|
-
method: 'POST',
|
|
340
|
-
headers: { 'Content-Type': 'application/json' },
|
|
341
|
-
body: JSON.stringify({
|
|
342
|
-
slug: 'cool-skill',
|
|
343
|
-
displayName: 'Cool Skill',
|
|
344
|
-
version: '1.2.3',
|
|
345
|
-
changelog: 'c',
|
|
346
|
-
files: [{ path: 'SKILL.md', size: 1, storageId: 'id', sha256: 'a' }],
|
|
347
|
-
}),
|
|
348
|
-
})
|
|
349
|
-
const response = await __handlers.cliPublishHandler(makeCtx({}), request)
|
|
350
|
-
expect(response.status).toBe(400)
|
|
351
|
-
})
|
|
352
|
-
|
|
353
|
-
it('cliPublishHttp returns 200 on success', async () => {
|
|
354
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
355
|
-
vi.mocked(publishVersionForUser).mockResolvedValueOnce({
|
|
356
|
-
skillId: 's',
|
|
357
|
-
versionId: 'v',
|
|
358
|
-
embeddingId: 'e',
|
|
359
|
-
} as never)
|
|
360
|
-
const request = new Request('https://x/api/cli/publish', {
|
|
361
|
-
method: 'POST',
|
|
362
|
-
headers: { 'Content-Type': 'application/json' },
|
|
363
|
-
body: JSON.stringify({
|
|
364
|
-
slug: 'cool-skill',
|
|
365
|
-
displayName: 'Cool Skill',
|
|
366
|
-
version: '1.2.3',
|
|
367
|
-
changelog: 'c',
|
|
368
|
-
files: [{ path: 'SKILL.md', size: 1, storageId: 'id', sha256: 'a' }],
|
|
369
|
-
}),
|
|
370
|
-
})
|
|
371
|
-
const response = await __handlers.cliPublishHandler(makeCtx({}), request)
|
|
372
|
-
expect(response.status).toBe(200)
|
|
373
|
-
const json = await response.json()
|
|
374
|
-
expect(json.ok).toBe(true)
|
|
375
|
-
expect(json.skillId).toBe('s')
|
|
376
|
-
})
|
|
377
|
-
|
|
378
|
-
it('cliSkillDeleteHandler returns 401 when unauthorized', async () => {
|
|
379
|
-
vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
|
|
380
|
-
const request = new Request('https://x/api/cli/skill/delete', {
|
|
381
|
-
method: 'POST',
|
|
382
|
-
headers: { 'Content-Type': 'application/json' },
|
|
383
|
-
body: JSON.stringify({ slug: 'demo' }),
|
|
384
|
-
})
|
|
385
|
-
const response = await __handlers.cliSkillDeleteHandler(makeCtx({}), request, true)
|
|
386
|
-
expect(response.status).toBe(401)
|
|
387
|
-
})
|
|
388
|
-
|
|
389
|
-
it('cliSkillDeleteHandler calls mutation and returns ok', async () => {
|
|
390
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
391
|
-
const runMutation = vi.fn().mockResolvedValue({ ok: true })
|
|
392
|
-
const request = new Request('https://x/api/cli/skill/delete', {
|
|
393
|
-
method: 'POST',
|
|
394
|
-
headers: { 'Content-Type': 'application/json' },
|
|
395
|
-
body: JSON.stringify({ slug: 'demo' }),
|
|
396
|
-
})
|
|
397
|
-
const response = await __handlers.cliSkillDeleteHandler(makeCtx({ runMutation }), request, true)
|
|
398
|
-
expect(response.status).toBe(200)
|
|
399
|
-
expect(runMutation).toHaveBeenCalledWith(expect.anything(), {
|
|
400
|
-
userId: 'user1',
|
|
401
|
-
slug: 'demo',
|
|
402
|
-
deleted: true,
|
|
403
|
-
})
|
|
404
|
-
expect(await response.json()).toEqual({ ok: true })
|
|
405
|
-
})
|
|
406
|
-
|
|
407
|
-
it('cliSkillDeleteHandler supports undelete', async () => {
|
|
408
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
409
|
-
const runMutation = vi.fn().mockResolvedValue({ ok: true })
|
|
410
|
-
const request = new Request('https://x/api/cli/skill/undelete', {
|
|
411
|
-
method: 'POST',
|
|
412
|
-
headers: { 'Content-Type': 'application/json' },
|
|
413
|
-
body: JSON.stringify({ slug: 'demo' }),
|
|
414
|
-
})
|
|
415
|
-
const response = await __handlers.cliSkillDeleteHandler(
|
|
416
|
-
makeCtx({ runMutation }),
|
|
417
|
-
request,
|
|
418
|
-
false,
|
|
419
|
-
)
|
|
420
|
-
expect(response.status).toBe(200)
|
|
421
|
-
expect(runMutation).toHaveBeenCalledWith(expect.anything(), {
|
|
422
|
-
userId: 'user1',
|
|
423
|
-
slug: 'demo',
|
|
424
|
-
deleted: false,
|
|
425
|
-
})
|
|
426
|
-
})
|
|
427
|
-
|
|
428
|
-
it('cliSkillUndeleteHttp calls delete handler with deleted=false', async () => {
|
|
429
|
-
const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {})
|
|
430
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
431
|
-
const runMutation = vi.fn().mockResolvedValue({ ok: true })
|
|
432
|
-
const response = await __handlers.cliSkillDeleteHandler(
|
|
433
|
-
makeCtx({ runMutation }),
|
|
434
|
-
new Request('https://x/api/cli/skill/undelete', {
|
|
435
|
-
method: 'POST',
|
|
436
|
-
headers: { 'Content-Type': 'application/json' },
|
|
437
|
-
body: JSON.stringify({ slug: 'demo' }),
|
|
438
|
-
}),
|
|
439
|
-
false,
|
|
440
|
-
)
|
|
441
|
-
expect(response.status).toBe(200)
|
|
442
|
-
expect(runMutation).toHaveBeenCalledWith(expect.anything(), {
|
|
443
|
-
userId: 'user1',
|
|
444
|
-
slug: 'demo',
|
|
445
|
-
deleted: false,
|
|
446
|
-
})
|
|
447
|
-
warnSpy.mockRestore()
|
|
448
|
-
})
|
|
449
|
-
|
|
450
|
-
it('cliSkillDeleteHttp calls delete handler with deleted=true', async () => {
|
|
451
|
-
const warnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {})
|
|
452
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
453
|
-
const runMutation = vi.fn().mockResolvedValue({ ok: true })
|
|
454
|
-
const response = await __handlers.cliSkillDeleteHandler(
|
|
455
|
-
makeCtx({ runMutation }),
|
|
456
|
-
new Request('https://x/api/cli/skill/delete', {
|
|
457
|
-
method: 'POST',
|
|
458
|
-
headers: { 'Content-Type': 'application/json' },
|
|
459
|
-
body: JSON.stringify({ slug: 'demo' }),
|
|
460
|
-
}),
|
|
461
|
-
true,
|
|
462
|
-
)
|
|
463
|
-
expect(response.status).toBe(200)
|
|
464
|
-
expect(runMutation).toHaveBeenCalledWith(expect.anything(), {
|
|
465
|
-
userId: 'user1',
|
|
466
|
-
slug: 'demo',
|
|
467
|
-
deleted: true,
|
|
468
|
-
})
|
|
469
|
-
warnSpy.mockRestore()
|
|
470
|
-
})
|
|
471
|
-
|
|
472
|
-
it('cliSkillDeleteHandler returns 400 on invalid json', async () => {
|
|
473
|
-
const request = new Request('https://x/api/cli/skill/delete', { method: 'POST', body: '{' })
|
|
474
|
-
const response = await __handlers.cliSkillDeleteHandler(makeCtx({}), request, true)
|
|
475
|
-
expect(response.status).toBe(400)
|
|
476
|
-
})
|
|
477
|
-
|
|
478
|
-
it('cliSkillDeleteHandler returns 400 on invalid payload', async () => {
|
|
479
|
-
vi.mocked(requireApiTokenUser).mockResolvedValueOnce({ userId: 'user1' } as never)
|
|
480
|
-
const request = new Request('https://x/api/cli/skill/delete', {
|
|
481
|
-
method: 'POST',
|
|
482
|
-
headers: { 'Content-Type': 'application/json' },
|
|
483
|
-
body: JSON.stringify({}),
|
|
484
|
-
})
|
|
485
|
-
const response = await __handlers.cliSkillDeleteHandler(makeCtx({}), request, true)
|
|
486
|
-
expect(response.status).toBe(400)
|
|
487
|
-
})
|
|
488
|
-
})
|
package/convex/httpApi.test.ts
DELETED
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
/* @vitest-environment node */
|
|
2
|
-
import { describe, expect, it } from 'vitest'
|
|
3
|
-
import { __test } from './httpApi'
|
|
4
|
-
|
|
5
|
-
describe('httpApi', () => {
|
|
6
|
-
it('parses publish payload', () => {
|
|
7
|
-
const parsed = __test.parsePublishBody({
|
|
8
|
-
slug: 'cool-skill',
|
|
9
|
-
displayName: 'Cool Skill',
|
|
10
|
-
version: '1.2.3',
|
|
11
|
-
changelog: 'stuff',
|
|
12
|
-
tags: ['latest', 'beta'],
|
|
13
|
-
files: [
|
|
14
|
-
{
|
|
15
|
-
path: 'SKILL.md',
|
|
16
|
-
size: 5,
|
|
17
|
-
storageId: 'fakeStorageId',
|
|
18
|
-
sha256: 'abcd',
|
|
19
|
-
contentType: 'text/markdown',
|
|
20
|
-
},
|
|
21
|
-
],
|
|
22
|
-
})
|
|
23
|
-
expect(parsed.slug).toBe('cool-skill')
|
|
24
|
-
expect(parsed.tags).toEqual(['latest', 'beta'])
|
|
25
|
-
expect(parsed.files[0]?.path).toBe('SKILL.md')
|
|
26
|
-
})
|
|
27
|
-
|
|
28
|
-
it('normalizes optional fields in publish payload', () => {
|
|
29
|
-
const parsed = __test.parsePublishBody({
|
|
30
|
-
slug: 'cool-skill',
|
|
31
|
-
displayName: 'Cool Skill',
|
|
32
|
-
version: '1.2.3',
|
|
33
|
-
changelog: '',
|
|
34
|
-
tags: [],
|
|
35
|
-
forkOf: { slug: 'base-skill' },
|
|
36
|
-
files: [
|
|
37
|
-
{
|
|
38
|
-
path: 'SKILL.md',
|
|
39
|
-
size: 5,
|
|
40
|
-
storageId: 'fakeStorageId',
|
|
41
|
-
sha256: 'abcd',
|
|
42
|
-
contentType: 'text/markdown',
|
|
43
|
-
},
|
|
44
|
-
],
|
|
45
|
-
})
|
|
46
|
-
expect(parsed.tags).toBeUndefined()
|
|
47
|
-
expect(parsed.source).toBeUndefined()
|
|
48
|
-
expect(parsed.forkOf).toEqual({ slug: 'base-skill', version: undefined })
|
|
49
|
-
})
|
|
50
|
-
|
|
51
|
-
it('rejects invalid publish payloads', () => {
|
|
52
|
-
expect(() => __test.parsePublishBody(null)).toThrow(/Publish payload/i)
|
|
53
|
-
expect(() =>
|
|
54
|
-
__test.parsePublishBody({
|
|
55
|
-
slug: 'x',
|
|
56
|
-
displayName: 'X',
|
|
57
|
-
version: '1.0.0',
|
|
58
|
-
changelog: 'c',
|
|
59
|
-
files: [],
|
|
60
|
-
}),
|
|
61
|
-
).toThrow(/files required/i)
|
|
62
|
-
})
|
|
63
|
-
|
|
64
|
-
it('parses optional numbers', () => {
|
|
65
|
-
expect(__test.toOptionalNumber(null)).toBeUndefined()
|
|
66
|
-
expect(__test.toOptionalNumber('')).toBeUndefined()
|
|
67
|
-
expect(__test.toOptionalNumber('10')).toBe(10)
|
|
68
|
-
expect(__test.toOptionalNumber('nope')).toBeUndefined()
|
|
69
|
-
})
|
|
70
|
-
})
|