# NAME Devel::Mutator - Mutation testing for Perl # SYNOPSIS mutator mutate lib/MyModule.pm mutator test # DESCRIPTION Devel::Mutator is a mutation testing toolkit for Perl. Mutation testing is changing the working program in different ways and checking that the test suite fails and thus detecting the bad testing. ## How it works First we generate mutated code. For example every occurance of `=` is replaced by `!=`. All the mutants are collected in the `mutants/` directory. Then we run the tests replacing original code by the mutant. If the test suite does not fail when the code is changed it is reported with a `diff` output, which helps to see the problem. (10/18) ./mutants/7021082cc1c0afbe9322f60a9b5e5d5f/lib/Input/Validator/Field.pm ... not ok --- ./mutants/7021082cc1c0afbe9322f60a9b5e5d5f/lib/Input/Validator/Field.pm Sat Nov 1 11:27:00 2014 +++ lib/Input/Validator/Field.pm.bak Sun May 18 21:50:14 2014 @@ -14,7 +14,7 @@ my $self = shift; $self->{constraints} ||= []; - $self->{messages} //= {}; + $self->{messages} ||= {}; $self->{trim} = 1 unless defined $self->{trim}; Here we can see that the test suite does not check the need for `//`. ## Warning The original code is replaced by the mutants, so make sure it is under a VCS if something bad happens. This is the easiest and the 100% working way. Maybe this will be changed in the future when a better way is found. ## Mutation testing drawbacks There are several drawbacks. ### The equivalent program The equivalent program can be produced thus failing the test. There is no solution to that for now. ### Infinite loops Infinite loops can be created easily. The solution is to run the test suite limited in time through a `timeout` option, which is 10s by default. After 10s of running, the test suite is killed and `n/a timeout` is reported. # METHODS # CREDITS Alexandr Ciornii (chorny) # AUTHOR Viacheslav Tykhanovskyi, <viacheslav.t@gmail.com> # COPYRIGHT AND LICENSE Copyright (C) 2015, Viacheslav Tykhanovskyi This program is free software, you can redistribute it and/or modify it under the terms of the Artistic License version 2.0. This program is distributed in the hope that it will be useful, but without any warranty; without even the implied warranty of merchantability or fitness for a particular purpose.