erp-construccion-database-v2/validate-clean-load-policy.sh
rckrdmrd bf97e26cdf Migración desde erp-construccion/database - Estándar multi-repo v2
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-16 08:11:21 -06:00

154 lines
6.6 KiB
Bash
Executable File

#!/bin/bash
# =============================================================================
# VALIDATE CLEAN LOAD POLICY
# =============================================================================
# Script de validacion de cumplimiento de DIRECTIVA-POLITICA-CARGA-LIMPIA.md
#
# Uso: ./validate-clean-load-policy.sh
# =============================================================================
set -e
# Colores
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
BLUE='\033[0;34m'
NC='\033[0m'
# Configuracion
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
VIOLATIONS=0
echo -e "${BLUE}=============================================================================${NC}"
echo -e "${BLUE} VALIDACION DE POLITICA DE CARGA LIMPIA${NC}"
echo -e "${BLUE}=============================================================================${NC}"
echo ""
# =============================================================================
# CHECK 1: No debe existir carpeta migrations/
# =============================================================================
echo -e "${YELLOW}[1/6] Verificando que NO existe carpeta migrations/...${NC}"
if [ -d "$SCRIPT_DIR/migrations" ]; then
echo -e "${RED}ERROR: Carpeta migrations/ detectada (PROHIBIDA)${NC}"
echo -e "${RED} Path: $SCRIPT_DIR/migrations${NC}"
echo -e "${YELLOW} Solucion: Eliminar carpeta y mover contenido a schemas/${NC}"
VIOLATIONS=$((VIOLATIONS + 1))
else
echo -e "${GREEN}OK - No existe carpeta migrations/${NC}"
fi
echo ""
# =============================================================================
# CHECK 2: No deben existir archivos fix-*.sql
# =============================================================================
echo -e "${YELLOW}[2/6] Verificando que NO existen archivos fix-*.sql...${NC}"
FIX_FILES=$(find "$SCRIPT_DIR" -name "fix-*.sql" -o -name "patch-*.sql" -o -name "hotfix-*.sql" 2>/dev/null)
if [ -n "$FIX_FILES" ]; then
echo -e "${RED}ERROR: Archivos fix/patch detectados (PROHIBIDOS):${NC}"
echo "$FIX_FILES" | while read -r file; do
echo -e "${RED} - $file${NC}"
done
echo -e "${YELLOW} Solucion: Incorporar cambios en DDL base y eliminar fixes${NC}"
VIOLATIONS=$((VIOLATIONS + 1))
else
echo -e "${GREEN}OK - No existen archivos fix/patch${NC}"
fi
echo ""
# =============================================================================
# CHECK 3: No deben existir archivos migration-*.sql o NNN-*.sql numerados
# =============================================================================
echo -e "${YELLOW}[3/6] Verificando que NO existen archivos tipo migration...${NC}"
MIGRATION_FILES=$(find "$SCRIPT_DIR" -regex ".*[0-9][0-9][0-9][-_].*\.sql" ! -path "*/schemas/*" 2>/dev/null)
if [ -n "$MIGRATION_FILES" ]; then
echo -e "${RED}ERROR: Archivos tipo migration detectados (PROHIBIDOS):${NC}"
echo "$MIGRATION_FILES" | while read -r file; do
echo -e "${RED} - $file${NC}"
done
echo -e "${YELLOW} Solucion: Mover a schemas/ con nomenclatura correcta${NC}"
VIOLATIONS=$((VIOLATIONS + 1))
else
echo -e "${GREEN}OK - No existen archivos tipo migration fuera de schemas/${NC}"
fi
echo ""
# =============================================================================
# CHECK 4: Debe existir script drop-and-recreate-database.sh
# =============================================================================
echo -e "${YELLOW}[4/6] Verificando que existe drop-and-recreate-database.sh...${NC}"
if [ -f "$SCRIPT_DIR/drop-and-recreate-database.sh" ]; then
if [ -x "$SCRIPT_DIR/drop-and-recreate-database.sh" ]; then
echo -e "${GREEN}OK - Script existe y es ejecutable${NC}"
else
echo -e "${YELLOW}WARN: Script existe pero no es ejecutable${NC}"
echo -e "${YELLOW} Solucion: chmod +x drop-and-recreate-database.sh${NC}"
fi
else
echo -e "${RED}ERROR: No existe drop-and-recreate-database.sh (REQUERIDO)${NC}"
echo -e "${YELLOW} Solucion: Crear script de recreacion limpia${NC}"
VIOLATIONS=$((VIOLATIONS + 1))
fi
echo ""
# =============================================================================
# CHECK 5: Deben existir archivos DDL en schemas/
# =============================================================================
echo -e "${YELLOW}[5/6] Verificando que existen archivos DDL en schemas/...${NC}"
DDL_COUNT=$(find "$SCRIPT_DIR/schemas" -name "*.sql" -type f 2>/dev/null | wc -l)
if [ "$DDL_COUNT" -gt 0 ]; then
echo -e "${GREEN}OK - Encontrados $DDL_COUNT archivos DDL en schemas/${NC}"
find "$SCRIPT_DIR/schemas" -name "*.sql" -type f | sort | while read -r file; do
echo -e " - $(basename "$file")"
done
else
echo -e "${YELLOW}WARN: No hay archivos DDL en schemas/${NC}"
echo -e "${YELLOW} La base de datos puede quedar vacia${NC}"
fi
echo ""
# =============================================================================
# CHECK 6: Debe existir archivo de inicializacion
# =============================================================================
echo -e "${YELLOW}[6/6] Verificando archivo de inicializacion...${NC}"
if [ -f "$SCRIPT_DIR/init-scripts/01-init-database.sql" ]; then
echo -e "${GREEN}OK - Existe init-scripts/01-init-database.sql${NC}"
elif [ -f "$SCRIPT_DIR/ddl/00-init.sql" ]; then
echo -e "${GREEN}OK - Existe ddl/00-init.sql${NC}"
else
echo -e "${RED}ERROR: No existe archivo de inicializacion${NC}"
echo -e "${YELLOW} Solucion: Crear init-scripts/01-init-database.sql${NC}"
VIOLATIONS=$((VIOLATIONS + 1))
fi
echo ""
# =============================================================================
# RESUMEN
# =============================================================================
echo -e "${BLUE}=============================================================================${NC}"
if [ "$VIOLATIONS" -eq 0 ]; then
echo -e "${GREEN} POLITICA DE CARGA LIMPIA: CUMPLIDA${NC}"
echo -e "${GREEN}=============================================================================${NC}"
echo -e "${GREEN} Todas las validaciones pasaron correctamente${NC}"
echo -e "${GREEN}=============================================================================${NC}"
exit 0
else
echo -e "${RED} POLITICA DE CARGA LIMPIA: VIOLADA${NC}"
echo -e "${RED}=============================================================================${NC}"
echo -e "${RED} Se encontraron $VIOLATIONS violacion(es)${NC}"
echo -e "${RED} Revisar DIRECTIVA-POLITICA-CARGA-LIMPIA.md para corregir${NC}"
echo -e "${RED}=============================================================================${NC}"
exit 1
fi