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.