Merge pull request 'cambios en migraciones' (#19) from pre-dev into dev
All checks were successful
DEPLOY_MULTI_BRACH/pipeline/head This commit looks good
All checks were successful
DEPLOY_MULTI_BRACH/pipeline/head This commit looks good
Reviewed-on: #19
This commit was merged in pull request #19.
This commit is contained in:
@@ -0,0 +1 @@
|
|||||||
|
# Archivo para marcar esta carpeta como paquete de migraciones
|
||||||
1
apps/common/migrations/__init__.py
Normal file
1
apps/common/migrations/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
# Archivo para marcar esta carpeta como paquete de migraciones
|
||||||
35
apps/promociones/fixtures/semillas.json
Normal file
35
apps/promociones/fixtures/semillas.json
Normal 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
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
1
apps/promociones/migrations/__init__.py
Normal file
1
apps/promociones/migrations/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
# Archivo para marcar esta carpeta como paquete de migraciones
|
||||||
@@ -1,33 +1,35 @@
|
|||||||
# Usamos una imagen ligera de Python
|
# 1. Usamos una imagen ligera de Python
|
||||||
FROM python:3.12-slim
|
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 PYTHONDONTWRITEBYTECODE 1
|
||||||
ENV PYTHONUNBUFFERED 1
|
ENV PYTHONUNBUFFERED 1
|
||||||
ENV TZ=Europe/Madrid
|
ENV TZ=Europe/Madrid
|
||||||
|
|
||||||
# Directorio de trabajo
|
# 3. Directorio de trabajo interno del contenedor
|
||||||
WORKDIR /app
|
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 \
|
RUN apt-get update && apt-get install -y \
|
||||||
libpq-dev \
|
libpq-dev \
|
||||||
gcc \
|
gcc \
|
||||||
gettext \
|
gettext \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Copiar dependencias (Ajustado: asumiendo que están en deployments/)
|
# 5. COPIAR REQUISITOS
|
||||||
COPY deployments/requirements.txt /app/
|
# 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
|
RUN pip install --no-cache-dir -r requirements.txt
|
||||||
|
|
||||||
# Copiar el resto del código del proyecto
|
# 6. COPIAR EL CÓDIGO
|
||||||
# El contexto de docker-compose suele ser la raíz, por lo que copiamos todo a /app
|
# Copiamos todo el contenido de la raíz (.) al directorio de trabajo (/app)
|
||||||
COPY . /app/
|
# Esto incluirá apps/, core/, manage.py, etc.
|
||||||
|
COPY . .
|
||||||
|
|
||||||
# Exponer el puerto de Django
|
# 7. EXPOSICIÓN Y SCRIPT DE ENTRADA
|
||||||
EXPOSE 8000
|
EXPOSE 8000
|
||||||
|
|
||||||
# Script de entrada (lo crearemos en el siguiente paso)
|
# El entrypoint también está en deployments/
|
||||||
COPY deployments/entrypoint.sh /entrypoint.sh
|
COPY deployments/entrypoint.sh /entrypoint.sh
|
||||||
RUN chmod +x /entrypoint.sh
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
|||||||
@@ -1,20 +1,23 @@
|
|||||||
|
version: '3.8'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
db:
|
gitea-db:
|
||||||
image: postgres:15
|
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
|
restart: always
|
||||||
# Solo usamos el .env de esta carpeta
|
|
||||||
env_file: .env
|
|
||||||
environment:
|
environment:
|
||||||
- POSTGRES_DB=${DB_NAME}
|
POSTGRES_DB: ${DB_NAME:-gitea}
|
||||||
- POSTGRES_USER=${DB_USER}
|
POSTGRES_USER: ${DB_USER:-gitea}
|
||||||
- POSTGRES_PASSWORD=${DB_PASSWORD}
|
POSTGRES_PASSWORD: ${DB_PASSWORD:-gitea}
|
||||||
|
volumes:
|
||||||
|
- postgres_data:/var/lib/postgresql/data
|
||||||
|
# --- ESTO ES LO QUE FALTA ---
|
||||||
ports:
|
ports:
|
||||||
- "${DATABASE_EXPOSE_PORT:-5432}:5432"
|
- "${DATABASE_EXPOSE_PORT:-5432}:5432"
|
||||||
volumes:
|
# ----------------------------
|
||||||
- local_postgres_data:/var/lib/postgresql/data
|
|
||||||
healthcheck:
|
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
|
interval: 5s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 5
|
retries: 5
|
||||||
@@ -25,18 +28,18 @@ services:
|
|||||||
dockerfile: deployments/Dockerfile
|
dockerfile: deployments/Dockerfile
|
||||||
container_name: ${APP_CONTAINER_NAME:-django_app_dev}
|
container_name: ${APP_CONTAINER_NAME:-django_app_dev}
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
env_file:
|
||||||
- ..:/app
|
- .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:
|
ports:
|
||||||
- "${PORT:-8000}:8000"
|
- "${PORT:-8000}:8000"
|
||||||
# Inyectamos el .env local al contenedor web
|
|
||||||
env_file: .env
|
|
||||||
environment:
|
|
||||||
- DB_HOST=db
|
|
||||||
- DB_PORT=5432
|
|
||||||
depends_on:
|
depends_on:
|
||||||
db:
|
gitea-db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
local_postgres_data:
|
postgres_data:
|
||||||
@@ -4,11 +4,14 @@
|
|||||||
set -e
|
set -e
|
||||||
|
|
||||||
echo "--> Ejecutando migraciones..."
|
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 makemigrations --noinput
|
||||||
python manage.py migrate --noinput
|
python manage.py migrate --noinput
|
||||||
|
|
||||||
# En el futuro, aquí podrías añadir:
|
echo "--> Cargando datos de prueba..."
|
||||||
# python manage.py collectstatic --noinput
|
# 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..."
|
echo "--> Arrancando el servidor Django..."
|
||||||
# Usamos exec para que Django sea el proceso principal (PID 1) y reciba señales de Docker
|
# Usamos exec para que Django sea el proceso principal (PID 1) y reciba señales de Docker
|
||||||
|
|||||||
Reference in New Issue
Block a user