Mutation testing αξιολογεί την ποιότητα ενός test suite εισάγοντας σκόπιμα μικρά bugs ("mutants") στον κώδικα και ελέγχοντας αν τα tests τα ανιχνεύουν. Μετρά πόσο καλά τα tests ανιχνεύουν πραγματικά ελαττώματα — πηγαίνοντας πέρα από την κάλυψη, η οποία μετρά μόνο την εκτέλεση.
Πώς λειτουργεί το mutation testing
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
