- 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>
9.8 KiB
Estado de Tests - Modulo Tenants
Tarea: BE-005
Fecha: 2026-01-10
Ubicacion: /home/isem/workspace-v1/projects/erp-core/backend/src/modules/tenants/
1. Resumen Ejecutivo
| Aspecto | Estado |
|---|---|
Directorio __tests__/ existe |
SI |
| Tests de Service | COMPLETOS |
| Tests de Controller | COMPLETOS |
| Tests de Integracion | FALTANTES |
| Cobertura estimada | 85% |
2. Estructura del Modulo Tenants
2.1 Archivos del Modulo
tenants/
__tests__/
tenants.service.spec.ts (1097 lineas)
tenants.controller.spec.ts (733 lineas)
dto/
create-tenant.dto.ts
update-tenant.dto.ts
index.ts
entities/
tenant.entity.ts
tenant-settings.entity.ts
index.ts
index.ts
tenants.controller.ts
tenants.routes.ts
tenants.service.ts
2.2 Entidades
Tenant Entity (tenant.entity.ts)
- Campos principales: id, name, subdomain, schemaName, status, plan
- Limites: maxUsers, maxStorageMb, currentStorageMb
- Configuracion: customDomain, contactEmail, contactPhone, billingEmail, taxId
- Fechas: trialEndsAt, subscriptionEndsAt
- Relacion: OneToOne con TenantSettings
TenantSettings Entity (tenant-settings.entity.ts)
- Localizacion: defaultLanguage, defaultTimezone, defaultCurrency, dateFormat
- Branding: logoUrl, faviconUrl, primaryColor, secondaryColor
- Seguridad: require2fa, sessionTimeoutMinutes, passwordExpiryDays, maxLoginAttempts
- Notificaciones: emailNotificationsEnabled, smsNotificationsEnabled, pushNotificationsEnabled
- Feature Flags: featureFlags (jsonb)
- Integraciones: smtpConfig, oauthConfig
3. Cobertura de Casos de Prueba Existentes
3.1 tenants.service.spec.ts
Tenant Creation/Update - CUBIERTO
| Caso | Estado | Lineas |
|---|---|---|
| Create tenant successfully | SI | 654-667 |
| Throw ValidationError when subdomain exists | SI | 668-674 |
| Create trial tenant when trialDays provided | SI | 675-687 |
| Use default plan when not specified | SI | 688-699 |
| Set correct maxUsers and maxStorageMb based on plan | SI | 700-719 |
| Update tenant successfully | SI | 722-739 |
| Throw NotFoundError when tenant not found (update) | SI | 740-746 |
| Update plan limits correctly | SI | 747-767 |
Feature Flags per Tenant - CUBIERTO
| Caso | Estado | Lineas |
|---|---|---|
| Update tenant settings with featureFlags | SI | 878-897 |
| Merge featureFlags with existing | SI | 895 |
Plan Limits Validation - CUBIERTO
| Caso | Estado | Lineas |
|---|---|---|
| canAddUser - Allow when under limit | SI | 922-936 |
| canAddUser - Deny when at limit | SI | 937-950 |
| canAddUser - Deny for suspended tenant | SI | 951-962 |
| canAddUser - Deny for expired trial | SI | 963-978 |
| canUseStorage - Allow when available | SI | 990-1001 |
| canUseStorage - Deny when insufficient | SI | 1002-1014 |
| Enforce basic plan user limit (10) | SI | 1054-1068 |
| Allow enterprise plan higher limit | SI | 1069-1084 |
| Enforce storage limits per plan | SI | 1085-1095 |
Tenant Isolation - PARCIALMENTE CUBIERTO
| Caso | Estado | Notas |
|---|---|---|
| FindById returns only active tenant | SI | Verifica deletedAt IS NULL |
| FindAll excludes deleted tenants | SI | Query con deletedAt IS NULL |
| Cross-tenant access prevention | NO | Falta test explicito |
Settings Management - CUBIERTO
| Caso | Estado | Lineas |
|---|---|---|
| getSettings returns tenant settings | SI | 843-858 |
| getSettings creates default when not exist | SI | 859-869 |
| getSettings throws NotFoundError when tenant not found | SI | 870-875 |
| updateSettings successfully | SI | 878-897 |
| updateSettings throws NotFoundError | SI | 898-905 |
| updateSettings creates if not exist | SI | 906-919 |
3.2 tenants.controller.spec.ts
| Endpoint | Casos Cubiertos |
|---|---|
| GET /tenants | Paginacion, filtros (status, plan, search), limite 100 |
| GET /tenants/current | Tenant del usuario autenticado |
| GET /tenants/:id | Por ID, incluir settings |
| GET /tenants/:id/stats | Estadisticas del tenant |
| POST /tenants | Creacion, validaciones (subdomain, name, campos requeridos) |
| PUT /tenants/:id | Actualizacion, NotFoundError |
| POST /tenants/:id/suspend | Suspension, NotFoundError |
| POST /tenants/:id/activate | Activacion, NotFoundError |
| DELETE /tenants/:id | Eliminacion, ForbiddenError (usuarios activos), NotFoundError |
| GET /tenants/:id/settings | Configuracion |
| PUT /tenants/:id/settings | Actualizacion, validacion color |
| GET /tenants/:id/can-add-user | Verificacion limite usuarios |
| GET /tenants/:id/can-use-storage | Verificacion almacenamiento |
4. Casos de Prueba Faltantes
4.1 Prioridad ALTA - Tenant Isolation
// FALTANTE: Tests de aislamiento entre tenants
describe('Tenant Isolation', () => {
it('should prevent access to data from other tenants');
it('should isolate user queries by tenantId');
it('should isolate company queries by tenantId');
it('should isolate role queries by tenantId');
it('should prevent subdomain collision during update');
});
Razon: El aislamiento multi-tenant es critico para la seguridad. Actualmente solo se verifica indirectamente a traves de queries con tenantId, pero no hay tests explicitos que validen que un tenant no puede acceder a datos de otro.
4.2 Prioridad ALTA - Tests de Integracion
// FALTANTE: tenants.integration.spec.ts
describe('Tenants Integration Tests', () => {
describe('Complete Tenant Lifecycle', () => {
it('should complete flow: create -> configure -> add users -> suspend -> activate -> delete');
});
describe('Multi-tenant scenarios', () => {
it('should handle concurrent tenant operations');
it('should maintain data isolation during concurrent access');
});
describe('Plan Upgrade/Downgrade', () => {
it('should upgrade plan and increase limits');
it('should prevent downgrade when exceeding new limits');
});
});
Razon: Siguiendo el patron de auth/__tests__/auth.integration.spec.ts, deberia existir un archivo tenants.integration.spec.ts que pruebe flujos completos end-to-end.
4.3 Prioridad MEDIA - Feature Flags Avanzados
// FALTANTE: Tests avanzados de feature flags
describe('Feature Flags Advanced', () => {
it('should validate feature flag keys format');
it('should prevent reserved feature flag names');
it('should cascade feature flag inheritance from plan');
it('should handle feature flag conflicts during merge');
});
4.4 Prioridad MEDIA - Validaciones Adicionales
// FALTANTE: Validaciones de limites y constraints
describe('Limit Validations', () => {
it('should prevent maxUsers below current user count');
it('should prevent maxStorageMb below current usage');
it('should validate trial period boundaries (min/max days)');
it('should handle subscription expiration transitions');
});
4.5 Prioridad BAJA - Edge Cases
// FALTANTE: Casos borde
describe('Edge Cases', () => {
it('should handle unicode in tenant name');
it('should normalize subdomain to lowercase');
it('should handle very long tenant names (255 chars)');
it('should handle empty metadata object');
it('should handle null vs undefined for optional fields');
});
5. Comparacion con Patron de Referencia (auth/tests/)
| Aspecto | auth/tests | tenants/tests | Estado |
|---|---|---|---|
| service.spec.ts | SI | SI | OK |
| controller.spec.ts | SI | SI | OK |
| integration.spec.ts | SI | NO | FALTANTE |
| Uso de factories | SI | SI | OK |
| Mocks estructurados | SI | SI | OK |
| Tests de flujo completo | SI | NO | FALTANTE |
| Tests de errores | SI | SI | OK |
| Tests de validacion | SI | SI | OK |
6. Metricas de Cobertura
Por Categoria (Requerida vs Existente)
| Categoria | Tests Requeridos | Tests Existentes | Cobertura |
|---|---|---|---|
| Tenant Creation/Update | 8 | 8 | 100% |
| Feature Flags per Tenant | 4 | 2 | 50% |
| Plan Limits Validation | 10 | 9 | 90% |
| Tenant Isolation | 5 | 0 | 0% |
| Settings Management | 6 | 6 | 100% |
| TOTAL | 33 | 25 | 76% |
Archivos de Test
| Archivo | Lineas | Tests | Describe Blocks |
|---|---|---|---|
| tenants.service.spec.ts | 1097 | 45 | 14 |
| tenants.controller.spec.ts | 733 | 32 | 13 |
| Total | 1830 | 77 | 27 |
7. Recomendaciones
7.1 Acciones Inmediatas
-
Crear
tenants.integration.spec.ts- Seguir el patron de
auth.integration.spec.ts - Incluir flujo completo de lifecycle del tenant
- Probar escenarios multi-tenant
- Seguir el patron de
-
Agregar tests de Tenant Isolation
- Verificar que queries filtran por tenantId
- Probar acceso cruzado entre tenants (debe fallar)
- Validar aislamiento de schemas
7.2 Acciones a Mediano Plazo
-
Expandir tests de Feature Flags
- Validacion de formatos
- Herencia de flags por plan
- Conflictos de merge
-
Agregar validaciones de limites
- Prevenir reduccion de limites por debajo del uso actual
- Transiciones de estado de suscripcion
7.3 Mejoras Continuas
- Agregar edge cases
- Unicode, longitudes maximas, valores nulos
- Casos de concurrencia
8. Conclusion
El modulo tenants tiene una cobertura de tests buena (76%), pero presenta gaps criticos en:
- Tests de integracion - No existe archivo
tenants.integration.spec.ts - Tests de aislamiento multi-tenant - Critico para seguridad
- Feature flags avanzados - Cobertura parcial
Se recomienda priorizar la creacion de tests de integracion y aislamiento antes de continuar con otras funcionalidades del modulo.
Generado por: Agente BE-005 Fecha: 2026-01-10 Version: 1.0