@saulwade/swl-ses 1.5.0 → 1.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (134) hide show
  1. package/CLAUDE.md +19 -2
  2. package/README.md +561 -561
  3. package/agentes/arquitecto-swl.md +33 -1
  4. package/agentes/nemesis-auditor-swl.md +59 -19
  5. package/bin/swl-mcp-server.js +214 -214
  6. package/comandos/swl/.evolved.json +22 -22
  7. package/comandos/swl/contribuir.md +233 -233
  8. package/comandos/swl/nemesis.md +230 -56
  9. package/gateway/lib/event-channel.js +191 -191
  10. package/habilidades/backend-production-resilience/SKILL.md +288 -288
  11. package/habilidades/benchmark-memoria/SKILL.md +186 -186
  12. package/habilidades/diagrama-arquitectura/assets/template.html +276 -276
  13. package/habilidades/doubt-driven-review/SKILL.md +171 -171
  14. package/habilidades/doubt-driven-review/recursos/EXAMPLES.md +130 -130
  15. package/habilidades/ejecutar-task-iterativo/SKILL.md +278 -278
  16. package/habilidades/eval-framework/SKILL.md +212 -212
  17. package/habilidades/feynman-auditor-swl/SKILL.md +123 -123
  18. package/habilidades/feynman-auditor-swl/recursos/preguntas-language-agnostic.md +108 -108
  19. package/habilidades/harness-claude-code/SKILL.md +299 -299
  20. package/habilidades/infra-github-actions/SKILL.md +166 -166
  21. package/habilidades/legacy-code-rescue/SKILL.md +267 -267
  22. package/habilidades/manejo-errores/.evolved.json +8 -8
  23. package/habilidades/meta-skills-estandar/SKILL.md +225 -1
  24. package/habilidades/meta-skills-estandar/recursos/convencion-examples.md +93 -93
  25. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
  26. package/habilidades/nemesis-evaluacion-json/SKILL.md +266 -0
  27. package/habilidades/nemesis-redistribuir/SKILL.md +341 -0
  28. package/habilidades/node-experto/SKILL.md +105 -4
  29. package/habilidades/patrones-python/SKILL.md +229 -229
  30. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -469
  31. package/habilidades/planear-fase/SKILL.md +319 -319
  32. package/habilidades/protocolo-revision-swl/SKILL.md +350 -276
  33. package/habilidades/release-semver/.evolved.json +8 -8
  34. package/habilidades/state-inconsistency-auditor-swl/SKILL.md +166 -166
  35. package/habilidades/state-inconsistency-auditor-swl/recursos/coupled-state-patterns.md +147 -147
  36. package/habilidades/tdd-workflow/SKILL.md +150 -4
  37. package/habilidades/testing-python/SKILL.md +340 -340
  38. package/habilidades/verificar-trabajo/SKILL.md +8 -3
  39. package/habilidades/web-fetcher-routing/SKILL.md +75 -75
  40. package/hooks/check-update.js +31 -3
  41. package/hooks/claudemd-bloat-detector.js +161 -161
  42. package/hooks/lib/agent-routing.js +107 -107
  43. package/hooks/lib/auto-consolidator.js +335 -335
  44. package/hooks/lib/error-classifier.js +308 -308
  45. package/hooks/lib/merkle-audit.js +96 -96
  46. package/hooks/lib/provenance-tracker.js +191 -191
  47. package/hooks/lib/rate-limit-tracker.js +253 -253
  48. package/hooks/lib/resource-quota.js +122 -122
  49. package/hooks/lib/retry-jitter.js +165 -165
  50. package/hooks/lib/security-net.js +201 -201
  51. package/hooks/lib/skill-auditor.js +588 -588
  52. package/hooks/lib/sync-status.js +228 -228
  53. package/hooks/lib/taint-tracker.js +107 -107
  54. package/hooks/lib/text-similarity.js +241 -241
  55. package/hooks/lib/toon-compressor.js +245 -245
  56. package/hooks/registro-turnos.js +209 -209
  57. package/hooks/sugerir-regenerar-inventario.js +170 -170
  58. package/hooks/validar-formato-post-subagente.js +140 -140
  59. package/hooks/validar-memoria-hook.js +218 -218
  60. package/instintos/prompt-appendices.yaml +57 -57
  61. package/manifiestos/agent-output-schemas.json +57 -57
  62. package/manifiestos/modulos.json +1324 -1321
  63. package/manifiestos/skills-lock.json +1114 -1114
  64. package/package.json +2 -2
  65. package/plantillas/auditor-veto-template.md +105 -105
  66. package/plantillas/github-workflows/README.md +47 -47
  67. package/plantillas/github-workflows/release-please.yml +44 -44
  68. package/plantillas/github-workflows/swl-ci.yml +107 -107
  69. package/plantillas/github-workflows/swl-security.yml +51 -51
  70. package/plugin.json +353 -351
  71. package/reglas/analisis-previo-tareas-grandes.md +172 -172
  72. package/reglas/arreglar-al-detectar.md +147 -147
  73. package/reglas/fragmentos-compartidos.md +152 -152
  74. package/reglas/harness-claude-code.md +213 -213
  75. package/reglas/registro-componentes-nuevos.md +192 -0
  76. package/reglas/usar-context7.md +226 -226
  77. package/schemas/diary-entry.schema.json +80 -80
  78. package/scripts/actualizar.js +110 -1
  79. package/scripts/audit-tools/audit-history.js +330 -330
  80. package/scripts/audit-tools/bundle-tracker.js +290 -290
  81. package/scripts/audit-tools/canary-monitor.js +352 -352
  82. package/scripts/audit-tools/code-profiler.js +605 -605
  83. package/scripts/audit-tools/dep-doctor.js +320 -320
  84. package/scripts/audit-tools/env-validator.js +206 -206
  85. package/scripts/audit-tools/lib/fs-walk.js +48 -48
  86. package/scripts/audit-tools/lib/output.js +23 -23
  87. package/scripts/audit-tools/migration-checker.js +392 -392
  88. package/scripts/audit-tools/pentest-scanner.js +1436 -1436
  89. package/scripts/benchmark-memoria.js +167 -167
  90. package/scripts/configurar-branch-protection.js +418 -418
  91. package/scripts/derivar-feature-list.js +489 -489
  92. package/scripts/detectar-aprendizajes-duplicados.js +151 -151
  93. package/scripts/doctor.js +58 -4
  94. package/scripts/field-report.js +199 -199
  95. package/scripts/generar-checklists-consolidados.js +273 -273
  96. package/scripts/generar-inventario.js +420 -420
  97. package/scripts/generar-matriz-lenguajes.js +271 -271
  98. package/scripts/lib/artefactos-python.js +43 -43
  99. package/scripts/lib/benchmark-metrics.js +160 -160
  100. package/scripts/lib/budget-enforcer.js +252 -252
  101. package/scripts/lib/configurar-ci.js +380 -380
  102. package/scripts/lib/contadores-inventario.js +217 -217
  103. package/scripts/lib/detectar-stack-detallado.js +307 -307
  104. package/scripts/lib/diary-entry.js +234 -234
  105. package/scripts/lib/eval-metrics-store.js +218 -218
  106. package/scripts/lib/eval-quality.js +171 -171
  107. package/scripts/lib/eval-schemas.js +144 -144
  108. package/scripts/lib/eval-self-correct.js +106 -106
  109. package/scripts/lib/eval-validator.js +185 -185
  110. package/scripts/lib/expandir-targets.js +71 -71
  111. package/scripts/lib/jaccard-similarity.js +98 -98
  112. package/scripts/lib/longmemeval-runner.js +125 -125
  113. package/scripts/lib/mcp_config.py +127 -0
  114. package/scripts/lib/npm-version.js +261 -261
  115. package/scripts/lib/paquetes-conocidos.js +50 -50
  116. package/scripts/lib/prompt-builder.js +264 -264
  117. package/scripts/lib/rrf-fusion.js +175 -175
  118. package/scripts/lib/scoring-instintos.js +277 -277
  119. package/scripts/lib/semantic-search.js +252 -252
  120. package/scripts/lib/toml-merge.js +204 -204
  121. package/scripts/lib/transformadores/codex.js +375 -375
  122. package/scripts/lib/transformadores/cursor.js +359 -359
  123. package/scripts/limpiar-artefactos-python.js +131 -131
  124. package/scripts/mcp-orchestrator.py +8 -18
  125. package/scripts/mcp-pool-manager.py +12 -23
  126. package/scripts/mcp-server/README.md +170 -170
  127. package/scripts/mcp-server/auth.js +105 -105
  128. package/scripts/mcp-server/cache.js +106 -106
  129. package/scripts/mcp-server/telemetry.js +78 -78
  130. package/scripts/migrar-csv-a-array.js +168 -168
  131. package/scripts/migrar-fase-dominio.js +201 -201
  132. package/scripts/publicar.js +511 -511
  133. package/scripts/run-eval.js +141 -141
  134. package/scripts/validar-userland-vacio.js +110 -110
@@ -1,9 +1,9 @@
1
- {
2
- "SKILL.md": {
3
- "evolved": true,
4
- "evolvedFrom": "1.0.1",
5
- "evolvedAt": "2026-05-02",
6
- "evolvedBy": "aprender",
7
- "evolvedNote": "Sección nueva: publish a múltiples registries (republish-only + auth GitHub Packages)"
8
- }
1
+ {
2
+ "SKILL.md": {
3
+ "evolved": true,
4
+ "evolvedFrom": "1.0.1",
5
+ "evolvedAt": "2026-05-02",
6
+ "evolvedBy": "aprender",
7
+ "evolvedNote": "Sección nueva: publish a múltiples registries (republish-only + auth GitHub Packages)"
8
+ }
9
9
  }
@@ -1,166 +1,166 @@
1
- ---
2
- name: state-inconsistency-auditor-swl
3
- description: >
4
- Encuentra bugs donde una operación muta un fragmento de estado acoplado sin
5
- actualizar su contraparte dependiente, causando corrupción silenciosa o fallos
6
- en operaciones posteriores. Mapea sistemáticamente pares de estado acoplado,
7
- todos sus paths de mutación, y los gaps donde un lado se actualiza sin el otro.
8
- Language-agnostic (Python, TS, Go, Rust, Java, C#). Cargar cuando se sospeche
9
- estado desincronizado: caché obsoleta, índices secundarios huérfanos, contadores
10
- que no coinciden con la suma de sus partes, o permisos derivados que no reflejan
11
- el estado de origen.
12
- ---
13
-
14
- # Cuándo cargar
15
-
16
- - Sospechas que un caché, índice secundario, o contador agregado está desincronizado.
17
- - Una función actualiza la tabla principal pero no el índice derivado.
18
- - Hay paths de "emergencia" o "admin" que modifican estado sin pasar por el flujo normal.
19
- - Nemesis está corriendo su Pasada 2.
20
-
21
- # Cuándo NO cargar
22
-
23
- - Para búsqueda de vulnerabilidades conocidas (inyección SQL, XSS) — usar `revisor-seguridad-swl`.
24
- - Para revisión de lógica de función individual sin estado acoplado — usar `feynman-auditor-swl`.
25
- - Para módulos sin persistencia de estado (transformaciones funcionales puras, utilería).
26
-
27
- ---
28
-
29
- # State Inconsistency Auditor
30
-
31
- Encuentra bugs donde una operación actualiza State A sin actualizar State B, cuando el invariante del sistema exige que ambos cambien juntos.
32
-
33
- Los patrones detallados de estado acoplado están en [recursos/coupled-state-patterns.md](recursos/coupled-state-patterns.md).
34
-
35
- ---
36
-
37
- ## El patrón abstracto
38
-
39
- Todo sistema mantiene **PARES DE ESTADO ACOPLADO**: dos o más valores de almacenamiento que deben mantener una relación (un invariante) entre sí. Cuando cualquier operación cambia un lado del par sin ajustar el otro, el invariante se rompe. Operaciones posteriores que leen ambos valores producen resultados incorrectos.
40
-
41
- ---
42
-
43
- ## Reglas del auditor
44
-
45
- ```
46
- REGLA 0: MAPEAR ANTES DE CAZAR
47
- Nunca empezar a revisar funciones sin tener el mapa completo de
48
- dependencias de estado acoplado. No se puede encontrar una actualización
49
- faltante si no se sabe qué actualizaciones son necesarias.
50
-
51
- REGLA 1: TODOS LOS PATHS DE MUTACIÓN IMPORTAN
52
- Una variable de estado puede modificarse desde 5 funciones distintas.
53
- Las 5 deben actualizar el estado acoplado. Si 4 lo hacen y 1 no — ese es el bug.
54
-
55
- REGLA 2: LAS OPERACIONES PARCIALES SON LA FUENTE #1
56
- Las eliminaciones completas (eliminar todo) generalmente resetean todo el estado
57
- correctamente. Las operaciones parciales (reducir en X) frecuentemente olvidan
58
- reducir proporcionalmente el estado acoplado.
59
-
60
- REGLA 3: COMPARAR PATHS PARALELOS
61
- Si transferir() y eliminar() ambos reducen un balance, AMBOS deben actualizar
62
- el mismo conjunto de estado acoplado. Si uno lo hace y el otro no — hallazgo.
63
-
64
- REGLA 4: EL CÓDIGO DEFENSIVO ENMASCARA BUGS
65
- Código como `valor > minimo ? valor - minimo : 0` o `min(calculado, disponible)`
66
- oculta invariantes rotos silenciosamente. Son señales de alerta, no protecciones.
67
-
68
- REGLA 5: SOLO HALLAZGOS BASADOS EN EVIDENCIA
69
- Todo hallazgo debe incluir: el par acoplado, la operación que lo rompe,
70
- una secuencia de trigger concreta, y la consecuencia observable.
71
- ```
72
-
73
- ---
74
-
75
- ## Proceso
76
-
77
- ### Fase 1: Mapear pares de estado acoplado
78
-
79
- Para cada variable de almacenamiento, preguntar: **"¿Qué otros valores de almacenamiento deben cambiar cuando este cambia?"**
80
-
81
- Construir un mapa de dependencias. Ver patrones comunes en `recursos/coupled-state-patterns.md`.
82
-
83
- Salida de Fase 1: **Mapa de Dependencias de Estado Acoplado**.
84
-
85
- ### Fase 2: Matriz de mutación
86
-
87
- Para cada variable identificada en Fase 1, listar TODAS las funciones y paths de código que la modifican. Incluir: escrituras directas, incrementos/decrementos, eliminaciones, mutaciones indirectas (llamadas internas), triggers externos (callbacks, hooks).
88
-
89
- Marcar con `???` toda entrada donde no se ha confirmado si la contraparte acoplada también se actualiza.
90
-
91
- Los `???` son los **objetivos primarios de auditoría**.
92
-
93
- ### Fase 3: Cross-check — el corazón de la auditoría
94
-
95
- Para cada par (operación, variable de estado) de Fase 2:
96
-
97
- > "Esta operación modifica State A. ¿También actualiza todo el estado acoplado que depende de A?"
98
-
99
- Verificar específicamente:
100
- - Eliminación completa (A → 0): ¿se resetea/limpia todo el estado acoplado?
101
- - Eliminación parcial (A decrece): ¿se reduce proporcionalmente todo el estado acoplado?
102
- - Incremento (A crece): ¿se incrementa proporcionalmente todo el estado acoplado?
103
- - Transferencia (A se mueve entre entidades): ¿el estado acoplado se mueve también?
104
- - Eliminación de entrada de colección: ¿la entrada del par también se elimina?
105
- - Operación en lote: ¿el estado acoplado se actualiza por iteración o solo una vez?
106
-
107
- **Si algún path actualiza A sin actualizar su estado acoplado → HALLAZGO.**
108
-
109
- ### Fase 4: Orden de operaciones dentro de funciones
110
-
111
- Muchas funciones realizan múltiples cambios de estado en secuencia. Rastrear el orden exacto y preguntar en cada paso: "¿Después de este paso, todos los pares acoplados siguen siendo consistentes?"
112
-
113
- Bugs de orden comunes:
114
- - Calcular resultado ANTES de actualizar el índice → resultado usa estado obsoleto
115
- - Leer caché DESPUÉS de modificar el origen → validación usa datos viejos
116
- - Emitir evento con valores viejos DESPUÉS del cambio de estado → sistemas externos se desincronizarán
117
-
118
- ### Fase 5: Comparar paths paralelos
119
-
120
- Encontrar operaciones que logran resultados similares por paths distintos. Para cada grupo, comparar: ¿TODOS los paths actualizan el mismo estado acoplado?
121
-
122
- ### Fase 6: Rastrear journeys multi-paso
123
-
124
- Simular secuencias donde un actor interactúa múltiples veces:
125
-
126
- 1. Actor inicializa un recurso (estado inicializado)
127
- 2. Tiempo pasa / estado externo evoluciona
128
- 3. Actor hace modificación PARCIAL (el estado acoplado puede romperse aquí)
129
- 4. Más tiempo pasa
130
- 5. Actor hace otra operación que lee el estado acoplado
131
-
132
- En el paso 5: ¿el estado acoplado sigue siendo válido dado el cambio parcial del paso 3?
133
-
134
- ### Fase 7: Patrones de enmascaramiento
135
-
136
- El código defensivo puede ocultar invariantes rotos. Ver patrones en `recursos/coupled-state-patterns.md`.
137
-
138
- Señal: si un ternario del tipo `a > b ? a - b : 0` está en un cálculo que involucra dos valores acoplados, preguntar: ¿por qué `a` podría ser menor que `b`? Si el invariante se mantuviera, no podría.
139
-
140
- ---
141
-
142
- ## Verificación (obligatoria para C/A/M)
143
-
144
- **Método A: Rastreo de código** — leer la función exacta, rastrear todas las llamadas internas, confirmar que no existe actualización oculta al estado acoplado.
145
-
146
- **Método B: Test de PoC** — escribir un test que ejecute la secuencia de trigger y afirme que el estado es inconsistente después de la operación.
147
-
148
- **Método C: Híbrido** — rastreo + PoC para hallazgos que abarcan múltiples módulos.
149
-
150
- **Falsos positivos frecuentes:**
151
- - Reconciliación oculta en un hook `_before_save` / `_after_update` / middleware.
152
- - Evaluación diferida intencional: el estado acoplado se reconcilia en la próxima lectura.
153
- - Asimetría de diseño documentada: los dos estados no son realmente acoplados como se asumió.
154
-
155
- ---
156
-
157
- ## Adaptación por lenguaje
158
-
159
- | Concepto | Python | TypeScript | Go | Rust | Java | C# |
160
- |---------|--------|------------|-----|------|------|-----|
161
- | Almacenamiento | atributos / BD | propiedades / BD | campos struct / BD | campos struct | campos clase | propiedades |
162
- | Colección clave-valor | `dict` / `HashMap` Redis | `Map` / objeto | `map[K]V` | `HashMap` | `Map<K,V>` | `Dictionary<K,V>` |
163
- | Eliminar entrada | `del d[k]` / `pop` | `delete obj[k]` | `delete(m, k)` | `map.remove(&k)` | `map.remove(k)` | `dict.Remove(k)` |
164
- | Hook post-mutación | `@receiver` / signal | middleware / hook | middleware | `impl Drop` / hook | `@PostUpdate` | event handler |
165
-
166
- <!-- Adaptado de nemesis-auditor-main bajo MIT License (https://github.com/0xiehnnkta/nemesis-auditor) -->
1
+ ---
2
+ name: state-inconsistency-auditor-swl
3
+ description: >
4
+ Encuentra bugs donde una operación muta un fragmento de estado acoplado sin
5
+ actualizar su contraparte dependiente, causando corrupción silenciosa o fallos
6
+ en operaciones posteriores. Mapea sistemáticamente pares de estado acoplado,
7
+ todos sus paths de mutación, y los gaps donde un lado se actualiza sin el otro.
8
+ Language-agnostic (Python, TS, Go, Rust, Java, C#). Cargar cuando se sospeche
9
+ estado desincronizado: caché obsoleta, índices secundarios huérfanos, contadores
10
+ que no coinciden con la suma de sus partes, o permisos derivados que no reflejan
11
+ el estado de origen.
12
+ ---
13
+
14
+ # Cuándo cargar
15
+
16
+ - Sospechas que un caché, índice secundario, o contador agregado está desincronizado.
17
+ - Una función actualiza la tabla principal pero no el índice derivado.
18
+ - Hay paths de "emergencia" o "admin" que modifican estado sin pasar por el flujo normal.
19
+ - Nemesis está corriendo su Pasada 2.
20
+
21
+ # Cuándo NO cargar
22
+
23
+ - Para búsqueda de vulnerabilidades conocidas (inyección SQL, XSS) — usar `revisor-seguridad-swl`.
24
+ - Para revisión de lógica de función individual sin estado acoplado — usar `feynman-auditor-swl`.
25
+ - Para módulos sin persistencia de estado (transformaciones funcionales puras, utilería).
26
+
27
+ ---
28
+
29
+ # State Inconsistency Auditor
30
+
31
+ Encuentra bugs donde una operación actualiza State A sin actualizar State B, cuando el invariante del sistema exige que ambos cambien juntos.
32
+
33
+ Los patrones detallados de estado acoplado están en [recursos/coupled-state-patterns.md](recursos/coupled-state-patterns.md).
34
+
35
+ ---
36
+
37
+ ## El patrón abstracto
38
+
39
+ Todo sistema mantiene **PARES DE ESTADO ACOPLADO**: dos o más valores de almacenamiento que deben mantener una relación (un invariante) entre sí. Cuando cualquier operación cambia un lado del par sin ajustar el otro, el invariante se rompe. Operaciones posteriores que leen ambos valores producen resultados incorrectos.
40
+
41
+ ---
42
+
43
+ ## Reglas del auditor
44
+
45
+ ```
46
+ REGLA 0: MAPEAR ANTES DE CAZAR
47
+ Nunca empezar a revisar funciones sin tener el mapa completo de
48
+ dependencias de estado acoplado. No se puede encontrar una actualización
49
+ faltante si no se sabe qué actualizaciones son necesarias.
50
+
51
+ REGLA 1: TODOS LOS PATHS DE MUTACIÓN IMPORTAN
52
+ Una variable de estado puede modificarse desde 5 funciones distintas.
53
+ Las 5 deben actualizar el estado acoplado. Si 4 lo hacen y 1 no — ese es el bug.
54
+
55
+ REGLA 2: LAS OPERACIONES PARCIALES SON LA FUENTE #1
56
+ Las eliminaciones completas (eliminar todo) generalmente resetean todo el estado
57
+ correctamente. Las operaciones parciales (reducir en X) frecuentemente olvidan
58
+ reducir proporcionalmente el estado acoplado.
59
+
60
+ REGLA 3: COMPARAR PATHS PARALELOS
61
+ Si transferir() y eliminar() ambos reducen un balance, AMBOS deben actualizar
62
+ el mismo conjunto de estado acoplado. Si uno lo hace y el otro no — hallazgo.
63
+
64
+ REGLA 4: EL CÓDIGO DEFENSIVO ENMASCARA BUGS
65
+ Código como `valor > minimo ? valor - minimo : 0` o `min(calculado, disponible)`
66
+ oculta invariantes rotos silenciosamente. Son señales de alerta, no protecciones.
67
+
68
+ REGLA 5: SOLO HALLAZGOS BASADOS EN EVIDENCIA
69
+ Todo hallazgo debe incluir: el par acoplado, la operación que lo rompe,
70
+ una secuencia de trigger concreta, y la consecuencia observable.
71
+ ```
72
+
73
+ ---
74
+
75
+ ## Proceso
76
+
77
+ ### Fase 1: Mapear pares de estado acoplado
78
+
79
+ Para cada variable de almacenamiento, preguntar: **"¿Qué otros valores de almacenamiento deben cambiar cuando este cambia?"**
80
+
81
+ Construir un mapa de dependencias. Ver patrones comunes en `recursos/coupled-state-patterns.md`.
82
+
83
+ Salida de Fase 1: **Mapa de Dependencias de Estado Acoplado**.
84
+
85
+ ### Fase 2: Matriz de mutación
86
+
87
+ Para cada variable identificada en Fase 1, listar TODAS las funciones y paths de código que la modifican. Incluir: escrituras directas, incrementos/decrementos, eliminaciones, mutaciones indirectas (llamadas internas), triggers externos (callbacks, hooks).
88
+
89
+ Marcar con `???` toda entrada donde no se ha confirmado si la contraparte acoplada también se actualiza.
90
+
91
+ Los `???` son los **objetivos primarios de auditoría**.
92
+
93
+ ### Fase 3: Cross-check — el corazón de la auditoría
94
+
95
+ Para cada par (operación, variable de estado) de Fase 2:
96
+
97
+ > "Esta operación modifica State A. ¿También actualiza todo el estado acoplado que depende de A?"
98
+
99
+ Verificar específicamente:
100
+ - Eliminación completa (A → 0): ¿se resetea/limpia todo el estado acoplado?
101
+ - Eliminación parcial (A decrece): ¿se reduce proporcionalmente todo el estado acoplado?
102
+ - Incremento (A crece): ¿se incrementa proporcionalmente todo el estado acoplado?
103
+ - Transferencia (A se mueve entre entidades): ¿el estado acoplado se mueve también?
104
+ - Eliminación de entrada de colección: ¿la entrada del par también se elimina?
105
+ - Operación en lote: ¿el estado acoplado se actualiza por iteración o solo una vez?
106
+
107
+ **Si algún path actualiza A sin actualizar su estado acoplado → HALLAZGO.**
108
+
109
+ ### Fase 4: Orden de operaciones dentro de funciones
110
+
111
+ Muchas funciones realizan múltiples cambios de estado en secuencia. Rastrear el orden exacto y preguntar en cada paso: "¿Después de este paso, todos los pares acoplados siguen siendo consistentes?"
112
+
113
+ Bugs de orden comunes:
114
+ - Calcular resultado ANTES de actualizar el índice → resultado usa estado obsoleto
115
+ - Leer caché DESPUÉS de modificar el origen → validación usa datos viejos
116
+ - Emitir evento con valores viejos DESPUÉS del cambio de estado → sistemas externos se desincronizarán
117
+
118
+ ### Fase 5: Comparar paths paralelos
119
+
120
+ Encontrar operaciones que logran resultados similares por paths distintos. Para cada grupo, comparar: ¿TODOS los paths actualizan el mismo estado acoplado?
121
+
122
+ ### Fase 6: Rastrear journeys multi-paso
123
+
124
+ Simular secuencias donde un actor interactúa múltiples veces:
125
+
126
+ 1. Actor inicializa un recurso (estado inicializado)
127
+ 2. Tiempo pasa / estado externo evoluciona
128
+ 3. Actor hace modificación PARCIAL (el estado acoplado puede romperse aquí)
129
+ 4. Más tiempo pasa
130
+ 5. Actor hace otra operación que lee el estado acoplado
131
+
132
+ En el paso 5: ¿el estado acoplado sigue siendo válido dado el cambio parcial del paso 3?
133
+
134
+ ### Fase 7: Patrones de enmascaramiento
135
+
136
+ El código defensivo puede ocultar invariantes rotos. Ver patrones en `recursos/coupled-state-patterns.md`.
137
+
138
+ Señal: si un ternario del tipo `a > b ? a - b : 0` está en un cálculo que involucra dos valores acoplados, preguntar: ¿por qué `a` podría ser menor que `b`? Si el invariante se mantuviera, no podría.
139
+
140
+ ---
141
+
142
+ ## Verificación (obligatoria para C/A/M)
143
+
144
+ **Método A: Rastreo de código** — leer la función exacta, rastrear todas las llamadas internas, confirmar que no existe actualización oculta al estado acoplado.
145
+
146
+ **Método B: Test de PoC** — escribir un test que ejecute la secuencia de trigger y afirme que el estado es inconsistente después de la operación.
147
+
148
+ **Método C: Híbrido** — rastreo + PoC para hallazgos que abarcan múltiples módulos.
149
+
150
+ **Falsos positivos frecuentes:**
151
+ - Reconciliación oculta en un hook `_before_save` / `_after_update` / middleware.
152
+ - Evaluación diferida intencional: el estado acoplado se reconcilia en la próxima lectura.
153
+ - Asimetría de diseño documentada: los dos estados no son realmente acoplados como se asumió.
154
+
155
+ ---
156
+
157
+ ## Adaptación por lenguaje
158
+
159
+ | Concepto | Python | TypeScript | Go | Rust | Java | C# |
160
+ |---------|--------|------------|-----|------|------|-----|
161
+ | Almacenamiento | atributos / BD | propiedades / BD | campos struct / BD | campos struct | campos clase | propiedades |
162
+ | Colección clave-valor | `dict` / `HashMap` Redis | `Map` / objeto | `map[K]V` | `HashMap` | `Map<K,V>` | `Dictionary<K,V>` |
163
+ | Eliminar entrada | `del d[k]` / `pop` | `delete obj[k]` | `delete(m, k)` | `map.remove(&k)` | `map.remove(k)` | `dict.Remove(k)` |
164
+ | Hook post-mutación | `@receiver` / signal | middleware / hook | middleware | `impl Drop` / hook | `@PostUpdate` | event handler |
165
+
166
+ <!-- Adaptado de nemesis-auditor-main bajo MIT License (https://github.com/0xiehnnkta/nemesis-auditor) -->