Some checks failed
CI / build-and-test (pull_request) Failing after 1m19s
CI (.gitea/workflows/ci.yaml): lint → typecheck → vitest w/ coverage → OpenNext build → preview smoke → bundle-size budgets; Node 20; npm ci; artifacts; safe env; D1 dry-run scaffold. Budgets: add scripts/budgets.mjs; TOTAL_STATIC_MAX_BYTES and MAX_ASSET_BYTES thresholds; report top offenders; fail on breach; README CI section. Flags: add lib/flags.ts with typed booleans and safe defaults (ADMIN_ENABLED, ARTISTS_MODULE_ENABLED, UPLOADS_ADMIN_ENABLED, BOOKING_ENABLED, PUBLIC_APPOINTMENT_REQUESTS_ENABLED, REFERENCE_UPLOADS_PUBLIC_ENABLED, DEPOSITS_ENABLED, PUBLIC_DB_ARTISTS_ENABLED, ADVANCED_NAV_SCROLL_ANIMATIONS_ENABLED, STRICT_CI_GATES_ENABLED, ISR_CACHE_R2_ENABLED); robust parsing; client provider; unit tests. Wiring: gate Admin shell and admin write APIs (503 JSON on uploads and artists writes); disable booking submit and short-circuit booking mutations when off; render static Hero/Artists when advanced animations off; tests for UI and API guards. Ops: expand docs/prd/rollback-strategy.md with “Feature Flags Operations,” Cloudflare Dashboard and wrangler.toml steps, preview simulation, incident playbook, and post-toggle smoke checklist. Release: add docs/releases/2025-09-19-feature-flags-rollout.md with last-good commit, preview/production flag matrices, rollback notes, and smoke results; link from rollback doc. Chore: fix TS issues (gift-cards boolean handling, Lenis options, tailwind darkMode), remove next-on-pages peer conflict, update package.json scripts, configure Gitea act_runner label, open draft PR to trigger CI. Refs: CI-1, FF-1, FF-2, FF-3, OPS-1 Impact: defaults preserve current behavior; no runtime changes unless flags flipped
24 lines
722 B
TypeScript
24 lines
722 B
TypeScript
import { describe, it, expect, vi } from 'vitest'
|
|
|
|
vi.mock('@/lib/flags', () => ({
|
|
Flags: { UPLOADS_ADMIN_ENABLED: false },
|
|
}))
|
|
vi.mock('@/lib/auth', () => ({
|
|
authOptions: {},
|
|
requireAuth: vi.fn(),
|
|
}))
|
|
vi.mock('next-auth', () => ({
|
|
getServerSession: vi.fn(async () => null),
|
|
}))
|
|
|
|
describe('Uploads admin disabled', () => {
|
|
it('returns 503 for files bulk-delete when UPLOADS_ADMIN_ENABLED=false', async () => {
|
|
const { POST } = await import('../../app/api/files/bulk-delete/route')
|
|
const fakeReq: any = { json: async () => ({ fileIds: ['1'] }) }
|
|
const res = await POST(fakeReq as any)
|
|
const body = await res.json()
|
|
expect(res.status).toBe(503)
|
|
expect(body).toHaveProperty('error')
|
|
})
|
|
})
|