Mutation analysis (mutation testing) - the process of testing a test suite by inserting errors in the system under test (SUT) and then running the test suite against the SUT in order to verify the detection of the inserted errors.
In other words, if you doubt the quality of a test suite, you can find out exactly if and where it falls short with a mutation analysis tool.
prerequisite: user specified SUT and a test suite, which the SUT passes.
- Use acorn.js to generate a AST from SUT
- Walk the generated AST with acorn.js' walker until a candidate AST node for a mutation operator is found
- Check history/log if the candidate/operator pair has been mutated before - if so go to step 2
- Mutate the candidate AST node
- Record the candidate/operator pair in some history/log
- Generate SUT' (now called mutant) from the AST with escodegen
- Save the mutant temporarily
- go to step 2 until sufficient amount of mutants have been created
- Run test suite against all mutants, report those mutants which passed all tests
- ABS: Absolute value insertion
- ROR: Relational operator replacement
- LCR: Logical connector replacement
- UOI: Unary operator insertion
- AOR: Arithmetic operator replacement
- How many mutants needs to be generated?