a gitea ci
This commit is contained in:
135
.gitea/workflow/ci.yml
Normal file
135
.gitea/workflow/ci.yml
Normal 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
|
||||||
@@ -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)
|
||||||
|
|||||||
@@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -8,213 +8,233 @@
|
|||||||
// 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:
|
||||||
| '/'
|
| '/'
|
||||||
| '/demo/api/names'
|
| '/api/health'
|
||||||
| '/demo/start/api-request'
|
| '/demo/api/names'
|
||||||
| '/demo/start/server-funcs'
|
| '/demo/start/api-request'
|
||||||
| '/demo/start/ssr/data-only'
|
| '/demo/start/server-funcs'
|
||||||
| '/demo/start/ssr/full-ssr'
|
| '/demo/start/ssr/data-only'
|
||||||
| '/demo/start/ssr/spa-mode'
|
| '/demo/start/ssr/full-ssr'
|
||||||
| '/demo/start/ssr/';
|
| '/demo/start/ssr/spa-mode'
|
||||||
fileRoutesByTo: FileRoutesByTo;
|
| '/demo/start/ssr/'
|
||||||
to:
|
fileRoutesByTo: FileRoutesByTo
|
||||||
| '/'
|
to:
|
||||||
| '/demo/api/names'
|
| '/'
|
||||||
| '/demo/start/api-request'
|
| '/api/health'
|
||||||
| '/demo/start/server-funcs'
|
| '/demo/api/names'
|
||||||
| '/demo/start/ssr/data-only'
|
| '/demo/start/api-request'
|
||||||
| '/demo/start/ssr/full-ssr'
|
| '/demo/start/server-funcs'
|
||||||
| '/demo/start/ssr/spa-mode'
|
| '/demo/start/ssr/data-only'
|
||||||
| '/demo/start/ssr';
|
| '/demo/start/ssr/full-ssr'
|
||||||
id:
|
| '/demo/start/ssr/spa-mode'
|
||||||
| '__root__'
|
| '/demo/start/ssr'
|
||||||
| '/'
|
id:
|
||||||
| '/demo/api/names'
|
| '__root__'
|
||||||
| '/demo/start/api-request'
|
| '/'
|
||||||
| '/demo/start/server-funcs'
|
| '/api/health'
|
||||||
| '/demo/start/ssr/data-only'
|
| '/demo/api/names'
|
||||||
| '/demo/start/ssr/full-ssr'
|
| '/demo/start/api-request'
|
||||||
| '/demo/start/ssr/spa-mode'
|
| '/demo/start/server-funcs'
|
||||||
| '/demo/start/ssr/';
|
| '/demo/start/ssr/data-only'
|
||||||
fileRoutesById: FileRoutesById;
|
| '/demo/start/ssr/full-ssr'
|
||||||
|
| '/demo/start/ssr/spa-mode'
|
||||||
|
| '/demo/start/ssr/'
|
||||||
|
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
|
||||||
};
|
}
|
||||||
'/demo/start/server-funcs': {
|
'/api/health': {
|
||||||
id: '/demo/start/server-funcs';
|
id: '/api/health'
|
||||||
path: '/demo/start/server-funcs';
|
path: '/api/health'
|
||||||
fullPath: '/demo/start/server-funcs';
|
fullPath: '/api/health'
|
||||||
preLoaderRoute: typeof DemoStartServerFuncsRouteImport;
|
preLoaderRoute: typeof ApiHealthRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
'/demo/start/api-request': {
|
'/demo/start/server-funcs': {
|
||||||
id: '/demo/start/api-request';
|
id: '/demo/start/server-funcs'
|
||||||
path: '/demo/start/api-request';
|
path: '/demo/start/server-funcs'
|
||||||
fullPath: '/demo/start/api-request';
|
fullPath: '/demo/start/server-funcs'
|
||||||
preLoaderRoute: typeof DemoStartApiRequestRouteImport;
|
preLoaderRoute: typeof DemoStartServerFuncsRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
'/demo/api/names': {
|
'/demo/start/api-request': {
|
||||||
id: '/demo/api/names';
|
id: '/demo/start/api-request'
|
||||||
path: '/demo/api/names';
|
path: '/demo/start/api-request'
|
||||||
fullPath: '/demo/api/names';
|
fullPath: '/demo/start/api-request'
|
||||||
preLoaderRoute: typeof DemoApiNamesRouteImport;
|
preLoaderRoute: typeof DemoStartApiRequestRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
'/demo/start/ssr/': {
|
'/demo/api/names': {
|
||||||
id: '/demo/start/ssr/';
|
id: '/demo/api/names'
|
||||||
path: '/demo/start/ssr';
|
path: '/demo/api/names'
|
||||||
fullPath: '/demo/start/ssr/';
|
fullPath: '/demo/api/names'
|
||||||
preLoaderRoute: typeof DemoStartSsrIndexRouteImport;
|
preLoaderRoute: typeof DemoApiNamesRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
'/demo/start/ssr/spa-mode': {
|
'/demo/start/ssr/': {
|
||||||
id: '/demo/start/ssr/spa-mode';
|
id: '/demo/start/ssr/'
|
||||||
path: '/demo/start/ssr/spa-mode';
|
path: '/demo/start/ssr'
|
||||||
fullPath: '/demo/start/ssr/spa-mode';
|
fullPath: '/demo/start/ssr/'
|
||||||
preLoaderRoute: typeof DemoStartSsrSpaModeRouteImport;
|
preLoaderRoute: typeof DemoStartSsrIndexRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
'/demo/start/ssr/full-ssr': {
|
'/demo/start/ssr/spa-mode': {
|
||||||
id: '/demo/start/ssr/full-ssr';
|
id: '/demo/start/ssr/spa-mode'
|
||||||
path: '/demo/start/ssr/full-ssr';
|
path: '/demo/start/ssr/spa-mode'
|
||||||
fullPath: '/demo/start/ssr/full-ssr';
|
fullPath: '/demo/start/ssr/spa-mode'
|
||||||
preLoaderRoute: typeof DemoStartSsrFullSsrRouteImport;
|
preLoaderRoute: typeof DemoStartSsrSpaModeRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
'/demo/start/ssr/data-only': {
|
'/demo/start/ssr/full-ssr': {
|
||||||
id: '/demo/start/ssr/data-only';
|
id: '/demo/start/ssr/full-ssr'
|
||||||
path: '/demo/start/ssr/data-only';
|
path: '/demo/start/ssr/full-ssr'
|
||||||
fullPath: '/demo/start/ssr/data-only';
|
fullPath: '/demo/start/ssr/full-ssr'
|
||||||
preLoaderRoute: typeof DemoStartSsrDataOnlyRouteImport;
|
preLoaderRoute: typeof DemoStartSsrFullSsrRouteImport
|
||||||
parentRoute: typeof rootRouteImport;
|
parentRoute: typeof rootRouteImport
|
||||||
};
|
}
|
||||||
}
|
'/demo/start/ssr/data-only': {
|
||||||
|
id: '/demo/start/ssr/data-only'
|
||||||
|
path: '/demo/start/ssr/data-only'
|
||||||
|
fullPath: '/demo/start/ssr/data-only'
|
||||||
|
preLoaderRoute: typeof DemoStartSsrDataOnlyRouteImport
|
||||||
|
parentRoute: typeof rootRouteImport
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const rootRouteChildren: RootRouteChildren = {
|
const rootRouteChildren: RootRouteChildren = {
|
||||||
IndexRoute: IndexRoute,
|
IndexRoute: IndexRoute,
|
||||||
DemoApiNamesRoute: DemoApiNamesRoute,
|
ApiHealthRoute: ApiHealthRoute,
|
||||||
DemoStartApiRequestRoute: DemoStartApiRequestRoute,
|
DemoApiNamesRoute: DemoApiNamesRoute,
|
||||||
DemoStartServerFuncsRoute: DemoStartServerFuncsRoute,
|
DemoStartApiRequestRoute: DemoStartApiRequestRoute,
|
||||||
DemoStartSsrDataOnlyRoute: DemoStartSsrDataOnlyRoute,
|
DemoStartServerFuncsRoute: DemoStartServerFuncsRoute,
|
||||||
DemoStartSsrFullSsrRoute: DemoStartSsrFullSsrRoute,
|
DemoStartSsrDataOnlyRoute: DemoStartSsrDataOnlyRoute,
|
||||||
DemoStartSsrSpaModeRoute: DemoStartSsrSpaModeRoute,
|
DemoStartSsrFullSsrRoute: DemoStartSsrFullSsrRoute,
|
||||||
DemoStartSsrIndexRoute: DemoStartSsrIndexRoute,
|
DemoStartSsrSpaModeRoute: DemoStartSsrSpaModeRoute,
|
||||||
};
|
DemoStartSsrIndexRoute: DemoStartSsrIndexRoute,
|
||||||
export const routeTree = rootRouteImport
|
}
|
||||||
._addFileChildren(rootRouteChildren)
|
export const routeTree = rootRouteImport
|
||||||
._addFileTypes<FileRouteTypes>();
|
._addFileChildren(rootRouteChildren)
|
||||||
|
._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>>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,
|
||||||
});
|
})
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|||||||
7
tests/unit/example.test.ts
Normal file
7
tests/unit/example.test.ts
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
import { describe, expect, it } from 'vitest';
|
||||||
|
|
||||||
|
describe('Example', () => {
|
||||||
|
it('should pass', () => {
|
||||||
|
expect(1 + 1).toBe(2);
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user