]> git.vpit.fr Git - perl/modules/Test-Valgrind.git/commitdiff
A new PerlScript command that specializes the Perl command to scripts
authorVincent Pit <vince@profvince.com>
Tue, 14 Apr 2009 13:47:10 +0000 (15:47 +0200)
committerVincent Pit <vince@profvince.com>
Tue, 14 Apr 2009 13:52:42 +0000 (15:52 +0200)
So that we can move the taint mode handling from Test::Valgrind to there.

MANIFEST
lib/Test/Valgrind.pm
lib/Test/Valgrind/Command/PerlScript.pm [new file with mode: 0644]
t/92-pod-coverage.t

index d38a9719dc4754ce98bf30534d1e9aabdff4eac4..785365d76cf859661c211b4fc0082cf698988fa0 100644 (file)
--- a/MANIFEST
+++ b/MANIFEST
@@ -12,6 +12,7 @@ lib/Test/Valgrind/Action/Test.pm
 lib/Test/Valgrind/Carp.pm
 lib/Test/Valgrind/Command.pm
 lib/Test/Valgrind/Command/Perl.pm
+lib/Test/Valgrind/Command/PerlScript.pm
 lib/Test/Valgrind/Report.pm
 lib/Test/Valgrind/Session.pm
 lib/Test/Valgrind/Suppressions.pm
index 1fac2874569b08006eb3e78ada7efd2a794d8cef..a447541b0a7e4e9f63148bcc6f1cbd2a76f6d991 100644 (file)
@@ -136,20 +136,11 @@ sub import {
   return;
  }
 
- my $taint_mode;
- {
-  open my $fh, '<', $file or last;
-  my $first = <$fh>;
-  close $fh;
-  if ($first and my ($args) = $first =~ /^\s*#\s*!\s*perl\s*(.*)/) {
-   $taint_mode = 1 if $args =~ /(?:^|\s)-T(?:$|\s)/;
-  }
- }
-
  require Test::Valgrind::Command;
  my $cmd = Test::Valgrind::Command->new(
-  command => 'Perl',
-  args    => [ '-MTest::Valgrind=run,1', (('-T') x!! $taint_mode), $file ],
+  command => 'PerlScript',
+  file    => $file,
+  args    => [ '-MTest::Valgrind=run,1' ],
  );
 
  my $instanceof = sub {
diff --git a/lib/Test/Valgrind/Command/PerlScript.pm b/lib/Test/Valgrind/Command/PerlScript.pm
new file mode 100644 (file)
index 0000000..a107b79
--- /dev/null
@@ -0,0 +1,121 @@
+package Test::Valgrind::Command::PerlScript;
+
+use strict;
+use warnings;
+
+=head1 NAME
+
+Test::Valgrind::Command::PerlScript - A Test::Valgrind command that invokes a perl script.
+
+=head1 VERSION
+
+Version 1.00
+
+=cut
+
+our $VERSION = '1.00';
+
+=head1 DESCRIPTION
+
+This command is meant to abstract the argument list handling of a C<perl> script.
+
+=cut
+
+use base qw/Test::Valgrind::Command::Perl Test::Valgrind::Carp/;
+
+=head1 METHODS
+
+This class inherits L<Test::Valgrind::Command::Perl>.
+
+=head2 C<< new file => $file, [ taint_mode => $taint_mode ], ... >>
+
+Your usual constructor.
+
+C<$file> is the path to the C<perl> script you want to run.
+
+C<$taint_mode> is a boolean that specifies if the script should be run under taint mode.
+If C<undef> is passed (which is the default), the constructor will try to infer it from the shebang line of the script.
+
+Other arguments are passed straight to C<< Test::Valgrind::Command::Perl->new >>.
+
+=cut
+
+sub new {
+ my $class = shift;
+ $class = ref($class) || $class;
+
+ my %args = @_;
+
+ my $file       = delete $args{file};
+ $class->_croak('Invalid script file') unless $file and -e $file;
+ my $taint_mode = delete $args{taint_mode};
+
+ my $self = bless $class->SUPER::new(%args), $class;
+
+ $self->{file} = $file;
+
+ if (not defined $taint_mode and open my $fh, '<', $file) {
+  my $first = <$fh>;
+  close $fh;
+  if ($first and my ($args) = $first =~ /^\s*#\s*!\s*perl\s*(.*)/) {
+   $taint_mode = 1 if $args =~ /(?:^|\s)-T(?:$|\s)/;
+  }
+  $taint_mode = 0 unless defined $taint_mode;
+ }
+ $self->{taint_mode} = $taint_mode;
+
+ return $self;
+}
+
+sub new_trainer { Test::Valgrind::Command::Perl->new_trainer }
+
+=head2 C<file>
+
+Read-only accessor for the C<file> option.
+
+=head2 C<taint_mode>
+
+Read-only accessor for the C<taint_mode> option.
+
+=cut
+
+eval "sub $_ { \$_[0]->{$_} }" for qw/file taint_mode/;
+
+sub args {
+ my $self = shift;
+
+ return $self->SUPER::args(@_),
+        (('-T') x!! $self->taint_mode),
+        $self->file
+}
+
+=head1 SEE ALSO
+
+L<Test::Valgrind>, L<Test::Valgrind::Command::Perl>.
+
+=head1 AUTHOR
+
+Vincent Pit, C<< <perl at profvince.com> >>, L<http://www.profvince.com>.
+
+You can contact me by mail or on C<irc.perl.org> (vincent).
+
+=head1 BUGS
+
+Please report any bugs or feature requests to C<bug-test-valgrind at rt.cpan.org>, or through the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Test-Valgrind>.
+I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
+
+=head1 SUPPORT
+
+You can find documentation for this module with the perldoc command.
+
+    perldoc Test::Valgrind::Command::PerlScript
+
+=head1 COPYRIGHT & LICENSE
+
+Copyright 2009 Vincent Pit, all rights reserved.
+
+This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
+
+=cut
+
+1; # End of Test::Valgrind::Command::PerlScript
index 3e6f0da9eebf180953d3396138e08ca11855b73b..dcfcec8032252e4e095c308fb62aa7e89d2b4d0f 100644 (file)
@@ -18,7 +18,7 @@ plan skip_all => "Pod::Coverage $min_pc required for testing POD coverage" if $@
 
 my $trustparents = { coverage_class => 'Pod::Coverage::CountParents' };
 
-plan tests => 14;
+plan tests => 15;
 
 pod_coverage_ok('Test::Valgrind');
 
@@ -31,6 +31,7 @@ pod_coverage_ok('Test::Valgrind::Carp');
 
 pod_coverage_ok('Test::Valgrind::Command');
 pod_coverage_ok('Test::Valgrind::Command::Perl', $trustparents);
+pod_coverage_ok('Test::Valgrind::Command::PerlScript', $trustparents);
 
 pod_coverage_ok('Test::Valgrind::Report');
 pod_coverage_ok('Test::Valgrind::Session');