Some checks failed
CI/CD Pipeline / 🧪 Tests (push) Has been cancelled
CI/CD Pipeline / 🏗️ Build (push) Has been cancelled
CI/CD Pipeline / 🚀 Deploy to Staging (push) Has been cancelled
CI/CD Pipeline / 🚀 Deploy to Production (push) Has been cancelled
CI/CD Pipeline / 🏷️ Create Release (push) Has been cancelled
CI/CD Pipeline / 🧹 Cleanup (push) Has been cancelled
Implementados 4 módulos con agent swarm: 1. TESTING FUNCIONAL (Jest) - Configuración Jest + ts-jest - Tests unitarios: auth, booking, court (55 tests) - Tests integración: routes (56 tests) - Factories y utilidades de testing - Coverage configurado (70% servicios) - Scripts: test, test:watch, test:coverage 2. TESTING DE USUARIO (Beta) - Sistema de beta testers - Feedback con categorías y severidad - Beta issues tracking - 8 testers de prueba creados - API completa para gestión de feedback 3. DOCUMENTACIÓN COMPLETA - API.md - 150+ endpoints documentados - SETUP.md - Guía de instalación - DEPLOY.md - Deploy en VPS - ARCHITECTURE.md - Arquitectura del sistema - APP_STORE.md - Material para stores - Postman Collection completa - PM2 ecosystem config - Nginx config con SSL 4. GO LIVE Y PRODUCCIÓN - Sistema de monitoreo (logs, health checks) - Servicio de alertas multi-canal - Pre-deploy check script - Docker + docker-compose producción - Backup automatizado - CI/CD GitHub Actions - Launch checklist completo ESTADÍSTICAS FINALES: - Fases completadas: 7/7 - Archivos creados: 250+ - Líneas de código: 60,000+ - Endpoints API: 150+ - Tests: 110+ - Documentación: 5,000+ líneas PROYECTO COMPLETO Y LISTO PARA PRODUCCIÓN
119 lines
3.5 KiB
Docker
119 lines
3.5 KiB
Docker
# =============================================================================
|
|
# Dockerfile para Producción - App Padel API
|
|
# Fase 7.4 - Go Live y Soporte
|
|
# =============================================================================
|
|
# Multi-stage build para optimizar el tamaño de la imagen final
|
|
# Node.js 20 Alpine para menor tamaño y mayor seguridad
|
|
# =============================================================================
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Stage 1: Builder
|
|
# Instala dependencias y compila TypeScript
|
|
# -----------------------------------------------------------------------------
|
|
FROM node:20-alpine AS builder
|
|
|
|
# Instalar dependencias del sistema necesarias para compilación
|
|
RUN apk add --no-cache \
|
|
python3 \
|
|
make \
|
|
g++ \
|
|
openssl \
|
|
libc6-compat
|
|
|
|
# Crear directorio de trabajo
|
|
WORKDIR /app
|
|
|
|
# Copiar archivos de dependencias primero (para caché de Docker)
|
|
COPY package*.json ./
|
|
COPY prisma ./prisma/
|
|
|
|
# Instalar TODAS las dependencias (incluyendo devDependencies)
|
|
RUN npm ci
|
|
|
|
# Generar cliente Prisma
|
|
RUN npx prisma generate
|
|
|
|
# Copiar código fuente
|
|
COPY . .
|
|
|
|
# Compilar TypeScript
|
|
RUN npm run build
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Stage 2: Production
|
|
# Imagen final optimizada con solo lo necesario
|
|
# -----------------------------------------------------------------------------
|
|
FROM node:20-alpine AS production
|
|
|
|
# Metadata de la imagen
|
|
LABEL maintainer="Canchas Padel <dev@tudominio.com>"
|
|
LABEL version="1.0.0"
|
|
LABEL description="API REST para App de Canchas de Pádel"
|
|
|
|
# Instalar solo las dependencias del sistema necesarias para ejecutar
|
|
RUN apk add --no-cache \
|
|
dumb-init \
|
|
curl \
|
|
&& addgroup -g 1001 -S nodejs \
|
|
&& adduser -S nodejs -u 1001
|
|
|
|
# Crear directorio de trabajo
|
|
WORKDIR /app
|
|
|
|
# Crear directorios necesarios con permisos correctos
|
|
RUN mkdir -p logs uploads tmp \
|
|
&& chown -R nodejs:nodejs /app
|
|
|
|
# Copiar archivos de dependencias
|
|
COPY --chown=nodejs:nodejs package*.json ./
|
|
COPY --chown=nodejs:nodejs prisma ./prisma/
|
|
|
|
# Instalar SOLO dependencias de producción
|
|
# --omit=dev excluye devDependencies
|
|
# --ignore-scripts evita ejecutar scripts post-install
|
|
RUN npm ci --omit=dev --ignore-scripts && npm cache clean --force
|
|
|
|
# Generar cliente Prisma para producción
|
|
RUN npx prisma generate
|
|
|
|
# Copiar código compilado desde el stage builder
|
|
COPY --chown=nodejs:nodejs --from=builder /app/dist ./dist
|
|
|
|
# Copiar archivos estáticos necesarios
|
|
COPY --chown=nodejs:nodejs --from=builder /app/package.json ./package.json
|
|
|
|
# Cambiar a usuario no-root por seguridad
|
|
USER nodejs
|
|
|
|
# Puerto expuesto
|
|
EXPOSE 3000
|
|
|
|
# Health check
|
|
# Verifica que la aplicación esté respondiendo cada 30 segundos
|
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
|
CMD curl -f http://localhost:3000/api/v1/health || exit 1
|
|
|
|
# Variables de entorno por defecto
|
|
ENV NODE_ENV=production \
|
|
PORT=3000 \
|
|
LOG_LEVEL=info
|
|
|
|
# Usar dumb-init para manejar señales de proceso correctamente
|
|
ENTRYPOINT ["dumb-init", "--"]
|
|
|
|
# Comando de inicio
|
|
CMD ["node", "dist/index.js"]
|
|
|
|
# -----------------------------------------------------------------------------
|
|
# Notas:
|
|
# -----------------------------------------------------------------------------
|
|
# Build:
|
|
# docker build -f Dockerfile.prod -t padel-api:latest .
|
|
#
|
|
# Run:
|
|
# docker run -p 3000:3000 --env-file .env padel-api:latest
|
|
#
|
|
# Verificar health:
|
|
# docker exec <container> curl http://localhost:3000/api/v1/health
|
|
# -----------------------------------------------------------------------------
|