Las pruebas de mutación (mutation testing) evalúan la calidad de un conjunto de pruebas introduciendo deliberadamente pequeños errores ("mutantes") en el código y comprobando si las pruebas los detectan. Miden qué tan buenas son realmente las pruebas para detectar defectos — yendo más allá de la cobertura, que solo mide la ejecución.
Cómo funcionan las pruebas de mutación
1. A tool makes small changes (MUTATIONS) to the code, e.g.:
→ change + to -, > to >=, true to false, remove a statement, change a constant
→ each mutation = a deliberate "bug" (a MUTANT version of the code)
2. Run the TEST SUITE against each mutant:
→ tests FAIL → the mutant is "KILLED" (good — tests caught the bug) ✓
→ tests PASS → the mutant "SURVIVED" (bad — tests DIDN'T catch the bug) ✗
3. MUTATION SCORE = % of mutants killed → measures how good the tests are at catching bugs
