cambios en migraciones #19

Merged
jjminguez merged 1 commits from pre-dev into dev 2026-04-14 20:46:59 +00:00
7 changed files with 78 additions and 32 deletions
Showing only changes of commit bf5a38d425 - Show all commits

View File

@@ -0,0 +1 @@
# Archivo para marcar esta carpeta como paquete de migraciones

View File

@@ -0,0 +1 @@
# Archivo para marcar esta carpeta como paquete de migraciones

View File

@@ -0,0 +1,35 @@
[
{
"model": "promociones.promocion",
"pk": 1,
"fields": {
"nombre": "Oferta de Bienvenida",
"fecha_inicio": "2026-04-01",
"descripcion": "Descuento para nuevos usuarios",
"activo": true,
"categoria_id": 1
}
},
{
"model": "promociones.promocion",
"pk": 2,
"fields": {
"nombre": "Promo Primavera",
"fecha_inicio": "2026-05-01",
"descripcion": "Todo al 20% de descuento",
"activo": true,
"categoria_id": 2
}
},
{
"model": "promociones.promocion",
"pk": 3,
"fields": {
"nombre": "Liquidación Stock",
"fecha_inicio": "2026-04-14",
"descripcion": "Últimas unidades",
"activo": false,
"categoria_id": 1
}
}
]

View File

@@ -0,0 +1 @@
# Archivo para marcar esta carpeta como paquete de migraciones

View File

@@ -1,33 +1,35 @@
# Usamos una imagen ligera de Python
# 1. Usamos una imagen ligera de Python
FROM python:3.12-slim
# Evitar que Python genere archivos .pyc y que el buffer se sature
# 2. Evitar archivos .pyc y saturación del buffer
ENV PYTHONDONTWRITEBYTECODE 1
ENV PYTHONUNBUFFERED 1
ENV TZ=Europe/Madrid
# Directorio de trabajo
# 3. Directorio de trabajo interno del contenedor
WORKDIR /app
# Instalar dependencias del sistema necesarias y limpiar caché en un solo paso
# 4. Instalar dependencias del sistema
RUN apt-get update && apt-get install -y \
libpq-dev \
gcc \
gettext \
&& rm -rf /var/lib/apt/lists/*
# Copiar dependencias (Ajustado: asumiendo que están en deployments/)
COPY deployments/requirements.txt /app/
# 5. COPIAR REQUISITOS
# OJO: Ahora el contexto es la RAÍZ, así que el archivo está en deployments/
COPY deployments/requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
# Copiar el resto del código del proyecto
# El contexto de docker-compose suele ser la raíz, por lo que copiamos todo a /app
COPY . /app/
# 6. COPIAR EL CÓDIGO
# Copiamos todo el contenido de la raíz (.) al directorio de trabajo (/app)
# Esto incluirá apps/, core/, manage.py, etc.
COPY . .
# Exponer el puerto de Django
# 7. EXPOSICIÓN Y SCRIPT DE ENTRADA
EXPOSE 8000
# Script de entrada (lo crearemos en el siguiente paso)
# El entrypoint también está en deployments/
COPY deployments/entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh

View File

@@ -1,20 +1,23 @@
version: '3.8'
services:
db:
gitea-db:
image: postgres:15
container_name: ${DB_CONTAINER_NAME:-django_db_local}
# Usará el nombre de tu .env (django_db_local)
container_name: ${DB_CONTAINER_NAME:-django_db_dev}
restart: always
# Solo usamos el .env de esta carpeta
env_file: .env
environment:
- POSTGRES_DB=${DB_NAME}
- POSTGRES_USER=${DB_USER}
- POSTGRES_PASSWORD=${DB_PASSWORD}
POSTGRES_DB: ${DB_NAME:-gitea}
POSTGRES_USER: ${DB_USER:-gitea}
POSTGRES_PASSWORD: ${DB_PASSWORD:-gitea}
volumes:
- postgres_data:/var/lib/postgresql/data
# --- ESTO ES LO QUE FALTA ---
ports:
- "${DATABASE_EXPOSE_PORT:-5432}:5432"
volumes:
- local_postgres_data:/var/lib/postgresql/data
# ----------------------------
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${DB_USER} -d ${DB_NAME}"]
test: ["CMD-SHELL", "pg_isready -U ${DB_USER:-gitea} -d ${DB_NAME:-gitea}"]
interval: 5s
timeout: 5s
retries: 5
@@ -25,18 +28,18 @@ services:
dockerfile: deployments/Dockerfile
container_name: ${APP_CONTAINER_NAME:-django_app_dev}
restart: always
volumes:
- ..:/app
env_file:
- .env
environment:
- DEBUG=${DEBUG_MODE:-1}
# IMPORTANTE: Este nombre debe coincidir con el nombre del servicio arriba (gitea-db)
- DB_HOST=gitea-db
- DB_PORT=5432
ports:
- "${PORT:-8000}:8000"
# Inyectamos el .env local al contenedor web
env_file: .env
environment:
- DB_HOST=db
- DB_PORT=5432
depends_on:
db:
gitea-db:
condition: service_healthy
volumes:
local_postgres_data:
postgres_data:

View File

@@ -4,11 +4,14 @@
set -e
echo "--> Ejecutando migraciones..."
# Esto asegura que si hay cambios en models.py, se generen y apliquen las tablas
python manage.py makemigrations --noinput
python manage.py migrate --noinput
# En el futuro, aquí podrías añadir:
# python manage.py collectstatic --noinput
echo "--> Cargando datos de prueba..."
# Este comando busca archivos JSON en las carpetas 'fixtures' de tus apps
# Usamos || true para que si el archivo no existe o ya están cargados, el contenedor no se detenga
python manage.py loaddata semillas || echo "Aviso: No se pudieron cargar las semillas (fichero no encontrado o error de formato)."
echo "--> Arrancando el servidor Django..."
# Usamos exec para que Django sea el proceso principal (PID 1) y reciba señales de Docker