- Command Line Options
- Using with CI
- Mutation Badge
- How-to Guides
- Debugging Issues
- Infection Playground
- GitHub Sponsors ♥️
- Supported Test Frameworks
- Compare with competitors
- What's new in Infection 0.25.0
- What's new in Infection 0.24.0
- What's new in Infection 0.23.0
- What's new in Infection 0.21.0
- What's new in Infection 0.20.0
There can be a situation, when Infection kills the Mutant, but if you do the same changes in the source code manually, tests pass.
Infection runs the tests in a random order, and if the project’s tests suite is not ready for it, tests can fail because of reordering. Make sure to always run tests randomly:
Another possible reason is that tests are not ready to be executed in parallel, when you use Infection with a
- tests read and write to the same database
- tests read and write to the same filesystem
in both cases, one test can override the data written by another test so that one of them fails.
In order to debug such issues, there is a special
--noop option for it. When it’s used, all mutators leave the code untouched, but Infection still runs the tests in order to kill such Mutants.
If everything works as expected, every Mutant should be escaped. For every mutation (which in fact is not a mutation at all) tests should pass, because the source code is not changed.
This is an example of how the output can look like:
so, Mutants are either not covered by tests or escaped. It means tests are green for each noop mutator that just don’t change the code.
If, for some reason, some Mutants are killed with
--noop, then there is an issue. To further debug the reason,
--log-verbosity=all option can be used to analyze
infection.log file. Don’t forget to enable
text logger in
infection.json configuration file:
In this log file, you can see tests output for every Mutant, with the information about why tests fail.