a gitea ci

This commit is contained in:
BeauTroll
2026-01-19 18:36:27 +01:00
parent cbd0cdced4
commit d470eb2cd5
6 changed files with 356 additions and 193 deletions

135
.gitea/workflow/ci.yml Normal file
View File

@@ -0,0 +1,135 @@
name: CI
on:
push:
branches: [main, develop]
pull_request:
branches: [main]
workflow_dispatch:
inputs:
environment:
description: "Environment to deploy"
required: true
default: "staging"
type: choice
options:
- staging
- production
jobs:
test:
runs-on: ubuntu-latest
services:
postgres:
image: postgres:16-alpine
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: dofus_manager
ports:
- 5432:5432
options: >-
--health-cmd "pg_isready -U postgres"
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- uses: actions/checkout@v4
- uses: pnpm/action-setup@v4
with:
version: 9
- uses: actions/setup-node@v4
with:
node-version: "20"
cache: "pnpm"
- name: Install dependencies
run: pnpm install --frozen-lockfile
- name: Generate Prisma client
run: pnpm prisma generate
- name: Run migrations
run: pnpm prisma migrate deploy
env:
DATABASE_URL: postgresql://postgres:postgres@localhost:5432/dofus_manager
- name: Lint
run: pnpm lint
- name: Type check
run: pnpm typecheck
- name: Test
run: pnpm test
env:
DATABASE_URL: postgresql://postgres:postgres@localhost:5432/dofus_manager
build:
needs: test
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/develop'
steps:
- uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to Registry
uses: docker/login-action@v3
with:
registry: ${{ vars.REGISTRY_URL }}
username: ${{ secrets.REGISTRY_USER }}
password: ${{ secrets.REGISTRY_PASSWORD }}
- name: Build and push
uses: docker/build-push-action@v5
with:
context: .
file: docker/Dockerfile
push: true
tags: |
${{ vars.REGISTRY_URL }}/dofus-manager:${{ github.sha }}
${{ vars.REGISTRY_URL }}/dofus-manager:latest
cache-from: type=gha
cache-to: type=gha,mode=max
deploy-staging:
needs: build
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/develop'
environment: staging
steps:
- name: Deploy to staging
run: |
echo "Deploying to staging..."
# SSH ou webhook vers votre serveur staging
curl -X POST "${{ secrets.STAGING_WEBHOOK_URL }}" || true
deploy-production:
needs: build
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/main'
environment: production
steps:
- name: Deploy to production
run: |
echo "Deploying to production..."
curl -X POST "${{ secrets.PRODUCTION_WEBHOOK_URL }}" || true
deploy-manual:
runs-on: ubuntu-latest
if: github.event_name == 'workflow_dispatch'
environment: ${{ github.event.inputs.environment }}
steps:
- name: Deploy to ${{ github.event.inputs.environment }}
run: |
echo "Manual deploy to ${{ github.event.inputs.environment }}"
# Votre logique de déploiement ici

View File

@@ -55,17 +55,17 @@ Draft
- [x] Create `src/lib/utils.ts` with `cn` utility function - [x] Create `src/lib/utils.ts` with `cn` utility function
- [x] Install Lucide React for icons - [x] Install Lucide React for icons
- [ ] Task 5: Configure linting and formatting (AC: 5) - [x] Task 5: Configure linting and formatting (AC: 5)
- [x] Install Biome (as specified in tech stack, not ESLint+Prettier) - [x] Install Biome (as specified in tech stack, not ESLint+Prettier)
- [x] Create `biome.json` with recommended rules - [x] Create `biome.json` with recommended rules
- [x] Add lint and format scripts to `package.json` - [x] Add lint and format scripts to `package.json`
- [ ] Verify linting works on project files - [x] Verify linting works on project files
- [ ] Task 6: Setup Gitea Actions workflow (AC: 6) - [ ] Task 6: Setup Gitea Actions workflow (AC: 6)
- [ ] Create `.gitea/workflows/ci.yml` - [x] Create `.gitea/workflows/ci.yml`
- [ ] Configure test job: lint, typecheck, test - [x] Configure test job: lint, typecheck, test
- [ ] Configure build job: Docker image build and push - [x] Configure build job: Docker image build and push
- [ ] Configure deploy jobs (staging/production) with manual triggers - [x] Configure deploy jobs (staging/production) with manual triggers
- [ ] Add caching for pnpm store - [ ] Add caching for pnpm store
- [ ] Task 7: Create README documentation (AC: 8) - [ ] Task 7: Create README documentation (AC: 8)

View File

@@ -9,7 +9,8 @@
"test": "vitest run", "test": "vitest run",
"lint": "biome check .", "lint": "biome check .",
"lint:fix": "biome check --write .", "lint:fix": "biome check --write .",
"format": "biome format --write ." "format": "biome format --write .",
"typecheck": "tsc --noEmit"
}, },
"dependencies": { "dependencies": {
"@prisma/client": "^7.2.0", "@prisma/client": "^7.2.0",
@@ -50,4 +51,3 @@
"web-vitals": "^5.1.0" "web-vitals": "^5.1.0"
} }
} }

View File

@@ -8,195 +8,216 @@
// You should NOT make any changes in this file as it will be overwritten. // You should NOT make any changes in this file as it will be overwritten.
// Additionally, you should also exclude this file from your linter and/or formatter to prevent it from being checked or modified. // Additionally, you should also exclude this file from your linter and/or formatter to prevent it from being checked or modified.
import { Route as rootRouteImport } from './routes/__root'; import { Route as rootRouteImport } from './routes/__root'
import { Route as DemoApiNamesRouteImport } from './routes/demo/api.names'; import { Route as IndexRouteImport } from './routes/index'
import { Route as DemoStartApiRequestRouteImport } from './routes/demo/start.api-request'; import { Route as ApiHealthRouteImport } from './routes/api/health'
import { Route as DemoStartServerFuncsRouteImport } from './routes/demo/start.server-funcs'; import { Route as DemoStartServerFuncsRouteImport } from './routes/demo/start.server-funcs'
import { Route as DemoStartSsrDataOnlyRouteImport } from './routes/demo/start.ssr.data-only'; import { Route as DemoStartApiRequestRouteImport } from './routes/demo/start.api-request'
import { Route as DemoStartSsrFullSsrRouteImport } from './routes/demo/start.ssr.full-ssr'; import { Route as DemoApiNamesRouteImport } from './routes/demo/api.names'
import { Route as DemoStartSsrIndexRouteImport } from './routes/demo/start.ssr.index'; import { Route as DemoStartSsrIndexRouteImport } from './routes/demo/start.ssr.index'
import { Route as DemoStartSsrSpaModeRouteImport } from './routes/demo/start.ssr.spa-mode'; import { Route as DemoStartSsrSpaModeRouteImport } from './routes/demo/start.ssr.spa-mode'
import { Route as IndexRouteImport } from './routes/index'; import { Route as DemoStartSsrFullSsrRouteImport } from './routes/demo/start.ssr.full-ssr'
import { Route as DemoStartSsrDataOnlyRouteImport } from './routes/demo/start.ssr.data-only'
const IndexRoute = IndexRouteImport.update({ const IndexRoute = IndexRouteImport.update({
id: '/', id: '/',
path: '/', path: '/',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const ApiHealthRoute = ApiHealthRouteImport.update({
id: '/api/health',
path: '/api/health',
getParentRoute: () => rootRouteImport,
} as any)
const DemoStartServerFuncsRoute = DemoStartServerFuncsRouteImport.update({ const DemoStartServerFuncsRoute = DemoStartServerFuncsRouteImport.update({
id: '/demo/start/server-funcs', id: '/demo/start/server-funcs',
path: '/demo/start/server-funcs', path: '/demo/start/server-funcs',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const DemoStartApiRequestRoute = DemoStartApiRequestRouteImport.update({ const DemoStartApiRequestRoute = DemoStartApiRequestRouteImport.update({
id: '/demo/start/api-request', id: '/demo/start/api-request',
path: '/demo/start/api-request', path: '/demo/start/api-request',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const DemoApiNamesRoute = DemoApiNamesRouteImport.update({ const DemoApiNamesRoute = DemoApiNamesRouteImport.update({
id: '/demo/api/names', id: '/demo/api/names',
path: '/demo/api/names', path: '/demo/api/names',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const DemoStartSsrIndexRoute = DemoStartSsrIndexRouteImport.update({ const DemoStartSsrIndexRoute = DemoStartSsrIndexRouteImport.update({
id: '/demo/start/ssr/', id: '/demo/start/ssr/',
path: '/demo/start/ssr/', path: '/demo/start/ssr/',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const DemoStartSsrSpaModeRoute = DemoStartSsrSpaModeRouteImport.update({ const DemoStartSsrSpaModeRoute = DemoStartSsrSpaModeRouteImport.update({
id: '/demo/start/ssr/spa-mode', id: '/demo/start/ssr/spa-mode',
path: '/demo/start/ssr/spa-mode', path: '/demo/start/ssr/spa-mode',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const DemoStartSsrFullSsrRoute = DemoStartSsrFullSsrRouteImport.update({ const DemoStartSsrFullSsrRoute = DemoStartSsrFullSsrRouteImport.update({
id: '/demo/start/ssr/full-ssr', id: '/demo/start/ssr/full-ssr',
path: '/demo/start/ssr/full-ssr', path: '/demo/start/ssr/full-ssr',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
const DemoStartSsrDataOnlyRoute = DemoStartSsrDataOnlyRouteImport.update({ const DemoStartSsrDataOnlyRoute = DemoStartSsrDataOnlyRouteImport.update({
id: '/demo/start/ssr/data-only', id: '/demo/start/ssr/data-only',
path: '/demo/start/ssr/data-only', path: '/demo/start/ssr/data-only',
getParentRoute: () => rootRouteImport, getParentRoute: () => rootRouteImport,
} as any); } as any)
export interface FileRoutesByFullPath { export interface FileRoutesByFullPath {
'/': typeof IndexRoute; '/': typeof IndexRoute
'/demo/api/names': typeof DemoApiNamesRoute; '/api/health': typeof ApiHealthRoute
'/demo/start/api-request': typeof DemoStartApiRequestRoute; '/demo/api/names': typeof DemoApiNamesRoute
'/demo/start/server-funcs': typeof DemoStartServerFuncsRoute; '/demo/start/api-request': typeof DemoStartApiRequestRoute
'/demo/start/ssr/data-only': typeof DemoStartSsrDataOnlyRoute; '/demo/start/server-funcs': typeof DemoStartServerFuncsRoute
'/demo/start/ssr/full-ssr': typeof DemoStartSsrFullSsrRoute; '/demo/start/ssr/data-only': typeof DemoStartSsrDataOnlyRoute
'/demo/start/ssr/spa-mode': typeof DemoStartSsrSpaModeRoute; '/demo/start/ssr/full-ssr': typeof DemoStartSsrFullSsrRoute
'/demo/start/ssr/': typeof DemoStartSsrIndexRoute; '/demo/start/ssr/spa-mode': typeof DemoStartSsrSpaModeRoute
'/demo/start/ssr/': typeof DemoStartSsrIndexRoute
} }
export interface FileRoutesByTo { export interface FileRoutesByTo {
'/': typeof IndexRoute; '/': typeof IndexRoute
'/demo/api/names': typeof DemoApiNamesRoute; '/api/health': typeof ApiHealthRoute
'/demo/start/api-request': typeof DemoStartApiRequestRoute; '/demo/api/names': typeof DemoApiNamesRoute
'/demo/start/server-funcs': typeof DemoStartServerFuncsRoute; '/demo/start/api-request': typeof DemoStartApiRequestRoute
'/demo/start/ssr/data-only': typeof DemoStartSsrDataOnlyRoute; '/demo/start/server-funcs': typeof DemoStartServerFuncsRoute
'/demo/start/ssr/full-ssr': typeof DemoStartSsrFullSsrRoute; '/demo/start/ssr/data-only': typeof DemoStartSsrDataOnlyRoute
'/demo/start/ssr/spa-mode': typeof DemoStartSsrSpaModeRoute; '/demo/start/ssr/full-ssr': typeof DemoStartSsrFullSsrRoute
'/demo/start/ssr': typeof DemoStartSsrIndexRoute; '/demo/start/ssr/spa-mode': typeof DemoStartSsrSpaModeRoute
'/demo/start/ssr': typeof DemoStartSsrIndexRoute
} }
export interface FileRoutesById { export interface FileRoutesById {
__root__: typeof rootRouteImport; __root__: typeof rootRouteImport
'/': typeof IndexRoute; '/': typeof IndexRoute
'/demo/api/names': typeof DemoApiNamesRoute; '/api/health': typeof ApiHealthRoute
'/demo/start/api-request': typeof DemoStartApiRequestRoute; '/demo/api/names': typeof DemoApiNamesRoute
'/demo/start/server-funcs': typeof DemoStartServerFuncsRoute; '/demo/start/api-request': typeof DemoStartApiRequestRoute
'/demo/start/ssr/data-only': typeof DemoStartSsrDataOnlyRoute; '/demo/start/server-funcs': typeof DemoStartServerFuncsRoute
'/demo/start/ssr/full-ssr': typeof DemoStartSsrFullSsrRoute; '/demo/start/ssr/data-only': typeof DemoStartSsrDataOnlyRoute
'/demo/start/ssr/spa-mode': typeof DemoStartSsrSpaModeRoute; '/demo/start/ssr/full-ssr': typeof DemoStartSsrFullSsrRoute
'/demo/start/ssr/': typeof DemoStartSsrIndexRoute; '/demo/start/ssr/spa-mode': typeof DemoStartSsrSpaModeRoute
'/demo/start/ssr/': typeof DemoStartSsrIndexRoute
} }
export interface FileRouteTypes { export interface FileRouteTypes {
fileRoutesByFullPath: FileRoutesByFullPath; fileRoutesByFullPath: FileRoutesByFullPath
fullPaths: fullPaths:
| '/' | '/'
| '/api/health'
| '/demo/api/names' | '/demo/api/names'
| '/demo/start/api-request' | '/demo/start/api-request'
| '/demo/start/server-funcs' | '/demo/start/server-funcs'
| '/demo/start/ssr/data-only' | '/demo/start/ssr/data-only'
| '/demo/start/ssr/full-ssr' | '/demo/start/ssr/full-ssr'
| '/demo/start/ssr/spa-mode' | '/demo/start/ssr/spa-mode'
| '/demo/start/ssr/'; | '/demo/start/ssr/'
fileRoutesByTo: FileRoutesByTo; fileRoutesByTo: FileRoutesByTo
to: to:
| '/' | '/'
| '/api/health'
| '/demo/api/names' | '/demo/api/names'
| '/demo/start/api-request' | '/demo/start/api-request'
| '/demo/start/server-funcs' | '/demo/start/server-funcs'
| '/demo/start/ssr/data-only' | '/demo/start/ssr/data-only'
| '/demo/start/ssr/full-ssr' | '/demo/start/ssr/full-ssr'
| '/demo/start/ssr/spa-mode' | '/demo/start/ssr/spa-mode'
| '/demo/start/ssr'; | '/demo/start/ssr'
id: id:
| '__root__' | '__root__'
| '/' | '/'
| '/api/health'
| '/demo/api/names' | '/demo/api/names'
| '/demo/start/api-request' | '/demo/start/api-request'
| '/demo/start/server-funcs' | '/demo/start/server-funcs'
| '/demo/start/ssr/data-only' | '/demo/start/ssr/data-only'
| '/demo/start/ssr/full-ssr' | '/demo/start/ssr/full-ssr'
| '/demo/start/ssr/spa-mode' | '/demo/start/ssr/spa-mode'
| '/demo/start/ssr/'; | '/demo/start/ssr/'
fileRoutesById: FileRoutesById; fileRoutesById: FileRoutesById
} }
export interface RootRouteChildren { export interface RootRouteChildren {
IndexRoute: typeof IndexRoute; IndexRoute: typeof IndexRoute
DemoApiNamesRoute: typeof DemoApiNamesRoute; ApiHealthRoute: typeof ApiHealthRoute
DemoStartApiRequestRoute: typeof DemoStartApiRequestRoute; DemoApiNamesRoute: typeof DemoApiNamesRoute
DemoStartServerFuncsRoute: typeof DemoStartServerFuncsRoute; DemoStartApiRequestRoute: typeof DemoStartApiRequestRoute
DemoStartSsrDataOnlyRoute: typeof DemoStartSsrDataOnlyRoute; DemoStartServerFuncsRoute: typeof DemoStartServerFuncsRoute
DemoStartSsrFullSsrRoute: typeof DemoStartSsrFullSsrRoute; DemoStartSsrDataOnlyRoute: typeof DemoStartSsrDataOnlyRoute
DemoStartSsrSpaModeRoute: typeof DemoStartSsrSpaModeRoute; DemoStartSsrFullSsrRoute: typeof DemoStartSsrFullSsrRoute
DemoStartSsrIndexRoute: typeof DemoStartSsrIndexRoute; DemoStartSsrSpaModeRoute: typeof DemoStartSsrSpaModeRoute
DemoStartSsrIndexRoute: typeof DemoStartSsrIndexRoute
} }
declare module '@tanstack/react-router' { declare module '@tanstack/react-router' {
interface FileRoutesByPath { interface FileRoutesByPath {
'/': { '/': {
id: '/'; id: '/'
path: '/'; path: '/'
fullPath: '/'; fullPath: '/'
preLoaderRoute: typeof IndexRouteImport; preLoaderRoute: typeof IndexRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/api/health': {
id: '/api/health'
path: '/api/health'
fullPath: '/api/health'
preLoaderRoute: typeof ApiHealthRouteImport
parentRoute: typeof rootRouteImport
}
'/demo/start/server-funcs': { '/demo/start/server-funcs': {
id: '/demo/start/server-funcs'; id: '/demo/start/server-funcs'
path: '/demo/start/server-funcs'; path: '/demo/start/server-funcs'
fullPath: '/demo/start/server-funcs'; fullPath: '/demo/start/server-funcs'
preLoaderRoute: typeof DemoStartServerFuncsRouteImport; preLoaderRoute: typeof DemoStartServerFuncsRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/demo/start/api-request': { '/demo/start/api-request': {
id: '/demo/start/api-request'; id: '/demo/start/api-request'
path: '/demo/start/api-request'; path: '/demo/start/api-request'
fullPath: '/demo/start/api-request'; fullPath: '/demo/start/api-request'
preLoaderRoute: typeof DemoStartApiRequestRouteImport; preLoaderRoute: typeof DemoStartApiRequestRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/demo/api/names': { '/demo/api/names': {
id: '/demo/api/names'; id: '/demo/api/names'
path: '/demo/api/names'; path: '/demo/api/names'
fullPath: '/demo/api/names'; fullPath: '/demo/api/names'
preLoaderRoute: typeof DemoApiNamesRouteImport; preLoaderRoute: typeof DemoApiNamesRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/demo/start/ssr/': { '/demo/start/ssr/': {
id: '/demo/start/ssr/'; id: '/demo/start/ssr/'
path: '/demo/start/ssr'; path: '/demo/start/ssr'
fullPath: '/demo/start/ssr/'; fullPath: '/demo/start/ssr/'
preLoaderRoute: typeof DemoStartSsrIndexRouteImport; preLoaderRoute: typeof DemoStartSsrIndexRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/demo/start/ssr/spa-mode': { '/demo/start/ssr/spa-mode': {
id: '/demo/start/ssr/spa-mode'; id: '/demo/start/ssr/spa-mode'
path: '/demo/start/ssr/spa-mode'; path: '/demo/start/ssr/spa-mode'
fullPath: '/demo/start/ssr/spa-mode'; fullPath: '/demo/start/ssr/spa-mode'
preLoaderRoute: typeof DemoStartSsrSpaModeRouteImport; preLoaderRoute: typeof DemoStartSsrSpaModeRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/demo/start/ssr/full-ssr': { '/demo/start/ssr/full-ssr': {
id: '/demo/start/ssr/full-ssr'; id: '/demo/start/ssr/full-ssr'
path: '/demo/start/ssr/full-ssr'; path: '/demo/start/ssr/full-ssr'
fullPath: '/demo/start/ssr/full-ssr'; fullPath: '/demo/start/ssr/full-ssr'
preLoaderRoute: typeof DemoStartSsrFullSsrRouteImport; preLoaderRoute: typeof DemoStartSsrFullSsrRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
'/demo/start/ssr/data-only': { '/demo/start/ssr/data-only': {
id: '/demo/start/ssr/data-only'; id: '/demo/start/ssr/data-only'
path: '/demo/start/ssr/data-only'; path: '/demo/start/ssr/data-only'
fullPath: '/demo/start/ssr/data-only'; fullPath: '/demo/start/ssr/data-only'
preLoaderRoute: typeof DemoStartSsrDataOnlyRouteImport; preLoaderRoute: typeof DemoStartSsrDataOnlyRouteImport
parentRoute: typeof rootRouteImport; parentRoute: typeof rootRouteImport
}; }
} }
} }
const rootRouteChildren: RootRouteChildren = { const rootRouteChildren: RootRouteChildren = {
IndexRoute: IndexRoute, IndexRoute: IndexRoute,
ApiHealthRoute: ApiHealthRoute,
DemoApiNamesRoute: DemoApiNamesRoute, DemoApiNamesRoute: DemoApiNamesRoute,
DemoStartApiRequestRoute: DemoStartApiRequestRoute, DemoStartApiRequestRoute: DemoStartApiRequestRoute,
DemoStartServerFuncsRoute: DemoStartServerFuncsRoute, DemoStartServerFuncsRoute: DemoStartServerFuncsRoute,
@@ -204,17 +225,16 @@ const rootRouteChildren: RootRouteChildren = {
DemoStartSsrFullSsrRoute: DemoStartSsrFullSsrRoute, DemoStartSsrFullSsrRoute: DemoStartSsrFullSsrRoute,
DemoStartSsrSpaModeRoute: DemoStartSsrSpaModeRoute, DemoStartSsrSpaModeRoute: DemoStartSsrSpaModeRoute,
DemoStartSsrIndexRoute: DemoStartSsrIndexRoute, DemoStartSsrIndexRoute: DemoStartSsrIndexRoute,
}; }
export const routeTree = rootRouteImport export const routeTree = rootRouteImport
._addFileChildren(rootRouteChildren) ._addFileChildren(rootRouteChildren)
._addFileTypes<FileRouteTypes>(); ._addFileTypes<FileRouteTypes>()
import type { createStart } from '@tanstack/react-start';
import type { getRouter } from './router.tsx';
import type { getRouter } from './router.tsx'
import type { createStart } from '@tanstack/react-start'
declare module '@tanstack/react-start' { declare module '@tanstack/react-start' {
interface Register { interface Register {
ssr: true; ssr: true
router: Awaited<ReturnType<typeof getRouter>>; router: Awaited<ReturnType<typeof getRouter>>
} }
} }

View File

@@ -1,3 +1,4 @@
import { createFileRoute } from '@tanstack/react-router'
import { createAPIFileRoute } from '@tanstack/start/api'; import { createAPIFileRoute } from '@tanstack/start/api';
import { prisma } from '@/lib/server/db'; import { prisma } from '@/lib/server/db';
@@ -15,6 +16,6 @@ export const Route = createAPIFileRoute('/api/health')({
status: 'ok', status: 'ok',
timestamp: new Date().toISOString(), timestamp: new Date().toISOString(),
database: dbStatus, database: dbStatus,
}); })
}, },
}); });

View File

@@ -0,0 +1,7 @@
import { describe, expect, it } from 'vitest';
describe('Example', () => {
it('should pass', () => {
expect(1 + 1).toBe(2);
});
});