X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FTest%2FValgrind%2FCommand.pm;h=b871cc57f3d58532044c3692eb59ff53a2bf465e;hb=3a312e2c6e7fdc7be70dcc8ccca604e7c62699f5;hp=0329241a19257212128ec4b6060ab13d3303d022;hpb=63f17cfcf624bc6764d32a7e674baf6329fd2d4a;p=perl%2Fmodules%2FTest-Valgrind.git diff --git a/lib/Test/Valgrind/Command.pm b/lib/Test/Valgrind/Command.pm index 0329241..b871cc5 100644 --- a/lib/Test/Valgrind/Command.pm +++ b/lib/Test/Valgrind/Command.pm @@ -9,11 +9,11 @@ Test::Valgrind::Command - Base class for Test::Valgrind commands. =head1 VERSION -Version 1.15 +Version 1.16 =cut -our $VERSION = '1.15'; +our $VERSION = '1.16'; =head1 DESCRIPTION @@ -24,6 +24,8 @@ They should also provide a default setup for generating suppressions. =cut +use Test::Valgrind::Util; + use base qw; =head1 METHODS @@ -48,10 +50,10 @@ sub new { my %args = @_; - if ($class eq __PACKAGE__ and my $cmd = delete $args{command}) { - $cmd =~ s/[^\w:]//g; - $cmd = __PACKAGE__ . "::$cmd" if $cmd !~ /::/; - $class->_croak("Couldn't load command $cmd: $@") unless eval "require $cmd;1"; + my $cmd = delete $args{command}; + if ($class eq __PACKAGE__ and defined $cmd) { + ($cmd, my $msg) = Test::Valgrind::Util::validate_subclass($cmd); + $class->_croak($msg) unless defined $cmd; return $cmd->new(%args); } @@ -110,6 +112,18 @@ This method must be implemented when subclassing. sub suppressions_tag; +=head2 C + + my $supp_ok = $tvc->check_suppressions_file($file); + +Returns a boolean indicating whether the suppressions contained in C<$file> are compatible with the command. + +Defaults to true. + +=cut + +sub check_suppressions_file { 1 } + =head2 C my $filtered_report = $tvc->filter($session, $report);