- HERENCIA-SIMCO.md actualizado con directivas v3.7 y v3.8 - Actualizaciones en modulos CRM y OpenAPI Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
14 KiB
PLAN REFINADO FINAL - FASE 5 (CAPVED)
Fecha: 2026-01-10 Version: 3.0 (Final) Basado en: ANALISIS-DEPENDENCIAS-ARCHIVOS-2026-01-10.md Fase CAPVED: P (Planeacion - Refinamiento Final) Orquestador: Claude Code - Opus 4.5
RESUMEN EJECUTIVO
Hallazgo Principal
El proyecto ERP-Core esta 74% mas avanzado de lo que indicaba el plan original. La verificacion detallada de archivos revela que:
- OAuth providers: YA IMPLEMENTADOS (Google, Microsoft)
- Permission Cache: YA IMPLEMENTADO
- Email Verification: YA IMPLEMENTADO
- MFA/2FA: YA IMPLEMENTADO (archivos mfa.* existen)
- Frontend Catalogs: 100% COMPLETO
- Frontend Settings: 100% COMPLETO
- Tests Auth: YA EXISTEN (49KB de tests)
Cambio de Enfoque
ENFOQUE ORIGINAL: Crear infraestructura de tests y features
ENFOQUE NUEVO: VALIDAR lo existente + Crear tests faltantes
Comparativa de Story Points
| Sprint | Original | Ajuste F2 | Ajuste F4 | Final | Delta |
|---|---|---|---|---|---|
| Sprint 1 | 44 | 22 | 3 | 3 | -93% |
| Sprint 2 | 39 | 37 | 15 | 15 | -62% |
| Sprint 3 | 36 | 36 | 16 | 16 | -56% |
| Sprint 4 | 33 | 31 | 5 | 5 | -85% |
| TOTAL | 152 | 126 | 39 | 39 | -74% |
1. TAREAS ELIMINADAS (YA COMPLETADAS)
1.1 Backend - Tareas Eliminadas
| Tarea | SP | Archivo/Componente que YA EXISTE |
|---|---|---|
| BE-002 | 8 | auth/__tests__/ (49KB - 3 archivos) |
| BE-006 | 2 | services/permission-cache.service.ts |
| BE-009 | 8 | providers/google.provider.ts, microsoft.provider.ts |
| BE-011 | 4 | services/email-verification.service.ts |
| Subtotal | 22 |
1.2 Frontend - Tareas Eliminadas
| Tarea | SP | Componente que YA EXISTE |
|---|---|---|
| FE-001 | 5 | features/catalogs/ estructura completa |
| FE-002 | 5 | pages/catalogs/countries/ |
| FE-003 | 5 | pages/catalogs/currencies/ |
| FE-004 | 5 | pages/catalogs/uom/ |
| FE-005 | 8 | pages/catalogs/categories/ |
| FE-006 | 2 | Rutas en routes.tsx (lineas 309-495) |
| FE-007 | 3 | features/catalogs/stores/ |
| FE-008 | 3 | features/settings/ estructura completa |
| FE-009 | 5 | pages/settings/SystemSettingsPage.tsx (parcial) |
| FE-010 | 5 | pages/settings/TenantSettingsPage.tsx |
| FE-011 | 5 | pages/settings/UserPreferencesPage.tsx |
| FE-012 | 5 | pages/settings/FeatureFlagsPage.tsx |
| FE-013 | 3 | features/settings/stores/ |
| FE-015 | 1 | Vitest config completo |
| Subtotal | 60 |
1.3 Total Eliminado
82 SP eliminados de 152 SP originales (54%)
2. PLAN REFINADO - 4 SPRINTS
2.1 SPRINT 1: Validacion + Config (3 SP)
Duracion: 1 semana Objetivo: Validar RLS y verificar configuracion de tests
DB-002:
titulo: "Ejecutar y validar RLS Tests"
sp: 2
tipo: VALIDACION
descripcion: |
Tests SQL ya existen. Ejecutar y documentar resultados.
archivos_existentes:
- database/tests/rls-validation.sql
- database/tests/tenant-isolation.sql
- database/tests/sql-functions.sql
acciones:
- Conectar a DB de desarrollo
- Ejecutar rls-validation.sql
- Ejecutar tenant-isolation.sql
- Documentar resultados en reporte
- Identificar tests fallidos (si hay)
entregables:
- REPORTE-RLS-VALIDATION-2026-01.md
- Lista de issues (si hay)
criterios:
- 100% tests ejecutados
- Documentacion de resultados
perfil: PERFIL-DATABASE.md
BE-001:
titulo: "Verificar configuracion Jest"
sp: 1
tipo: VALIDACION
descripcion: |
Jest ya instalado. Verificar que config existe y funciona.
archivos_a_verificar:
- backend/jest.config.js (crear si no existe)
- backend/tests/setup.ts (crear si no existe)
acciones:
- npm test (verificar que ejecuta)
- Verificar tests auth existentes pasan
- Documentar cobertura actual
criterios:
- npm test ejecuta sin errores
- Tests auth existentes pasan
perfil: PERFIL-BACKEND-EXPRESS.md
Resumen Sprint 1:
| Capa | Tareas | SP |
|---|---|---|
| Database | DB-002 | 2 |
| Backend | BE-001 | 1 |
| TOTAL | 2 tareas | 3 SP |
2.2 SPRINT 2: Tests Foundation (15 SP)
Duracion: 2 semanas Objetivo: Crear tests para modulos foundation sin cobertura
BE-003:
titulo: "Tests Users Module"
sp: 5
tipo: CREACION
descripcion: |
Crear suite completa de tests para modulo users.
Auth tests existen como referencia.
archivos_a_crear:
- backend/src/modules/users/__tests__/users.service.spec.ts
- backend/src/modules/users/__tests__/users.controller.spec.ts
casos_de_prueba:
- CRUD operations (create, read, update, delete)
- Search with filters
- Pagination
- Role assignment
- Activate/deactivate user
- Multi-tenant isolation
referencia: auth/__tests__/*.spec.ts (patron a seguir)
cobertura_target: ">80%"
perfil: PERFIL-BACKEND-EXPRESS.md
BE-004:
titulo: "Tests Roles Module"
sp: 5
tipo: CREACION
descripcion: |
Crear suite completa de tests para modulo roles.
archivos_a_crear:
- backend/src/modules/roles/__tests__/roles.service.spec.ts
- backend/src/modules/roles/__tests__/roles.controller.spec.ts
casos_de_prueba:
- CRUD roles
- Permission assignment
- System role protection (no delete/modify system roles)
- Role hierarchy validation
- Permission validation
cobertura_target: ">80%"
perfil: PERFIL-BACKEND-EXPRESS.md
BE-005:
titulo: "Tests Tenants Module"
sp: 5
tipo: CREACION
descripcion: |
Crear suite completa de tests para modulo tenants.
archivos_a_crear:
- backend/src/modules/tenants/__tests__/tenants.service.spec.ts
- backend/src/modules/tenants/__tests__/tenants.controller.spec.ts
casos_de_prueba:
- Tenant creation/update
- Feature flags per tenant
- Plan limits validation
- Tenant isolation (no cross-tenant access)
- Settings management
cobertura_target: ">80%"
perfil: PERFIL-BACKEND-EXPRESS.md
Resumen Sprint 2:
| Capa | Tareas | SP |
|---|---|---|
| Backend | BE-003, BE-004, BE-005 | 15 |
| TOTAL | 3 tareas | 15 SP |
2.3 SPRINT 3: Tests Core Business + Validacion OAuth (16 SP)
Duracion: 2 semanas Objetivo: Tests financial/inventory + Validar OAuth existente
BE-007:
titulo: "Tests Financial Module"
sp: 8
tipo: CREACION
descripcion: |
Crear tests para modulo financial.
archivos_a_crear:
- backend/src/modules/financial/__tests__/journal.service.spec.ts
- backend/src/modules/financial/__tests__/invoice.service.spec.ts
- backend/src/modules/financial/__tests__/payment.service.spec.ts
casos_de_prueba:
- Journal entries balance validation (debits = credits)
- Invoice workflow (draft -> posted -> paid)
- Payment reconciliation
- Multi-currency handling
- Lock date enforcement
cobertura_target: ">60%"
perfil: PERFIL-BACKEND-EXPRESS.md
BE-008:
titulo: "Tests Inventory Module"
sp: 6
tipo: CREACION
descripcion: |
Crear tests para modulo inventory.
archivos_a_crear:
- backend/src/modules/inventory/__tests__/product.service.spec.ts
- backend/src/modules/inventory/__tests__/stock.service.spec.ts
casos_de_prueba:
- Product CRUD
- Stock moves validation
- Valuation (FIFO, LIFO, Average)
- Stock adjustments
- Location transfers
- Lot/serial tracking
cobertura_target: ">60%"
perfil: PERFIL-BACKEND-EXPRESS.md
VALIDACION-OAUTH:
titulo: "Validar OAuth Flow End-to-End"
sp: 2
tipo: VALIDACION
descripcion: |
OAuth providers ya existen. Validar que funcionan correctamente.
archivos_existentes:
- providers/google.provider.ts
- providers/microsoft.provider.ts
- providers/oauth.service.ts
acciones:
- Configurar credenciales de test (Google, Microsoft)
- Ejecutar flujo OAuth Google
- Ejecutar flujo OAuth Microsoft
- Verificar link/unlink de cuentas
- Documentar resultados
entregables:
- VALIDACION-OAUTH-2026-01.md
- Issues identificados (si hay)
perfil: PERFIL-BACKEND-EXPRESS.md
Resumen Sprint 3:
| Capa | Tareas | SP |
|---|---|---|
| Backend | BE-007, BE-008, VALIDACION-OAUTH | 16 |
| TOTAL | 3 tareas | 16 SP |
2.4 SPRINT 4: Verificacion MFA + Theme Integration (5 SP)
Duracion: 1 semana Objetivo: Verificar MFA y completar integraciones menores
BE-010:
titulo: "Verificar y Completar MFA"
sp: 4
tipo: VALIDACION/COMPLETAR
descripcion: |
MFA ya existe (mfa.service.ts, mfa.controller.ts, mfa.routes.ts).
Verificar estado y completar si es necesario.
archivos_existentes:
- mfa.routes.ts
- mfa.controller.ts
- mfa.service.ts
- dto/mfa.dto.ts
- entities/user-mfa.entity.ts
- entities/trusted-device.entity.ts
acciones:
- Revisar endpoints MFA existentes
- Ejecutar tests MFA (si existen)
- Verificar flujo TOTP setup
- Verificar backup codes
- Documentar estado
- Completar funcionalidad faltante (si hay)
entregables:
- VALIDACION-MFA-2026-01.md
- Fixes aplicados (si necesario)
perfil: PERFIL-BACKEND-EXPRESS.md
FE-014:
titulo: "Integrar Theme Selector"
sp: 1
tipo: INTEGRACION
descripcion: |
useTheme hook ya existe. Integrar selector en UI.
archivos_existentes:
- features/settings/hooks/useTheme.ts
- shared/stores/useUIStore.ts
archivos_a_verificar:
- shared/components/organisms/ThemeSelector.tsx (crear si no existe)
acciones:
- Verificar si ThemeSelector existe
- Integrar en header/settings si falta
- Verificar persistencia en localStorage
- Verificar aplicacion de dark mode
perfil: PERFIL-FRONTEND.md
Resumen Sprint 4:
| Capa | Tareas | SP |
|---|---|---|
| Backend | BE-010 | 4 |
| Frontend | FE-014 | 1 |
| TOTAL | 2 tareas | 5 SP |
3. CRONOGRAMA
SPRINT 1: Validacion + Config
Duracion: 1 semana
SP: 3
Inicio: Inmediato
SPRINT 2: Tests Foundation
Duracion: 2 semanas
SP: 15
Prerequisito: Sprint 1 completado
SPRINT 3: Tests Core + OAuth Validation
Duracion: 2 semanas
SP: 16
Prerequisito: Sprint 2 completado
SPRINT 4: MFA + Theme
Duracion: 1 semana
SP: 5
Prerequisito: Sprint 3 completado
TOTAL: 6 semanas, 39 SP
4. PERFILES DE AGENTES
database_agent:
perfil: PERFIL-DATABASE.md
sprints: [1]
tareas: [DB-002]
sp_total: 2
backend_agent:
perfil: PERFIL-BACKEND-EXPRESS.md
sprints: [1, 2, 3, 4]
tareas: [BE-001, BE-003, BE-004, BE-005, BE-007, BE-008, VALIDACION-OAUTH, BE-010]
sp_total: 36
frontend_agent:
perfil: PERFIL-FRONTEND.md
sprints: [4]
tareas: [FE-014]
sp_total: 1
5. CRITERIOS DE EXITO
5.1 Sprint 1
criterios:
- RLS tests ejecutados: 100%
- Resultados documentados: SI
- Jest config verificado: SI
- npm test ejecuta sin errores: SI
- Tests auth existentes pasan: SI
5.2 Sprint 2
criterios:
- Users tests cobertura: >80%
- Roles tests cobertura: >80%
- Tenants tests cobertura: >80%
- Todos los tests pasan: SI
- npm test incluye nuevos tests: SI
5.3 Sprint 3
criterios:
- Financial tests cobertura: >60%
- Inventory tests cobertura: >60%
- OAuth Google login funcional: SI
- OAuth Microsoft login funcional: SI
- Documentacion OAuth completa: SI
5.4 Sprint 4
criterios:
- MFA TOTP verificado: SI
- Backup codes funcionando: SI
- Theme selector integrado: SI
- Persistencia de tema: SI
6. ENTREGABLES POR SPRINT
Sprint 1
- REPORTE-RLS-VALIDATION-2026-01.md
- Verificacion jest.config.js
Sprint 2
- modules/users/tests/*.spec.ts
- modules/roles/tests/*.spec.ts
- modules/tenants/tests/*.spec.ts
- Coverage report foundation
Sprint 3
- modules/financial/tests/*.spec.ts
- modules/inventory/tests/*.spec.ts
- VALIDACION-OAUTH-2026-01.md
Sprint 4
- VALIDACION-MFA-2026-01.md
- Theme selector integrado (si faltaba)
- Reporte final de estado
7. RIESGOS RESIDUALES
| Riesgo | Probabilidad | Mitigacion |
|---|---|---|
| Tests complejos en financial | MEDIA | Usar fixtures, mocks bien definidos |
| OAuth credentials no disponibles | BAJA | Usar entorno de test de providers |
| MFA tiene bugs | BAJA | Ya tiene estructura, solo validar |
8. COMPARATIVA FINAL
Evolucion del Plan
| Fase | SP | Reduccion |
|---|---|---|
| Plan Original | 152 | - |
| Fase 2 (Ajuste inicial) | 126 | -17% |
| Fase 4 (Verificacion archivos) | 39 | -74% |
| Plan Final | 39 | -74% |
Distribucion Final
| Tipo de Tarea | SP | % |
|---|---|---|
| Creacion de Tests | 29 | 74% |
| Validacion | 9 | 23% |
| Integracion | 1 | 3% |
| Total | 39 | 100% |
Por Capa
| Capa | SP | % |
|---|---|---|
| Database | 2 | 5% |
| Backend | 36 | 92% |
| Frontend | 1 | 3% |
| Total | 39 | 100% |
9. CONCLUSION
El proyecto ERP-Core esta significativamente mas avanzado de lo estimado inicialmente. El plan refinado se enfoca en:
- Validar lo que ya existe (RLS, OAuth, MFA)
- Crear tests para modulos sin cobertura (users, roles, tenants, financial, inventory)
- Completar integraciones menores (theme selector)
Con 39 SP en lugar de 152 SP originales, el proyecto puede alcanzar un estado de produccion mucho mas rapidamente de lo planificado.
10. APROBACION
| Aspecto | Estado |
|---|---|
| Analisis completado | APROBADO |
| Dependencias verificadas | APROBADO |
| Tareas eliminadas justificadas | APROBADO |
| Tareas nuevas definidas | APROBADO |
| Criterios de exito claros | APROBADO |
| PLAN REFINADO FINAL | LISTO PARA EJECUCION |
Documento generado por: ORQUESTADOR (Claude Code Opus 4.5) Sistema: SIMCO + CAPVED Fase actual: P (Planeacion - Refinamiento Final) - COMPLETADA Proxima fase: FASE 6 - Ejecucion