X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FTest%2FLeaner.pm;h=bc62c0c54fef6228b760371bcafb425cb47fe642;hb=67d7b560467f2d6b762eeee33aa07e0dba290f2b;hp=d11c4e212cbe22f298ea38f2026880160484fed7;hpb=521c714591253428d7b6e4361d3718e6fe7fbaf2;p=perl%2Fmodules%2FTest-Leaner.git diff --git a/lib/Test/Leaner.pm b/lib/Test/Leaner.pm index d11c4e2..bc62c0c 100644 --- a/lib/Test/Leaner.pm +++ b/lib/Test/Leaner.pm @@ -45,6 +45,11 @@ L, L, L, L, L, L, L and L throws an exception if the given operator isn't a valid Perl binary operator (except C<'='> and variants). +It also tests in scalar context, so C<'..'> will be treated as the flip-flop operator and not the range operator. + +=item * + C, C, C, C, C, C, C, C blocks and C are not implemented. =back @@ -101,7 +106,7 @@ sub croak { die @_, " at $file line $line.\n"; } -sub sanitize_comment { +sub _sanitize_comment { $_[0] =~ s/\n+\z//; $_[0] =~ s/#/\\#/g; $_[0] =~ s/\n/\n# /g; @@ -140,7 +145,7 @@ sub plan { $plan = SKIP_ALL; $plan_str = '1..0 # SKIP'; if (defined $value) { - sanitize_comment($value); + _sanitize_comment($value); $plan_str .= " $value" if length $value; } } else { @@ -160,7 +165,6 @@ sub plan { our @EXPORT = qw< plan - skip_all skip done_testing pass @@ -210,15 +214,6 @@ sub import { goto &Exporter::import; } -=head2 C - -=cut - -sub skip_all { - @_ = (skip_all => $_[0]); - goto &plan; -} - =head2 C<< skip $reason => $count >> =cut @@ -242,7 +237,7 @@ sub skip { my $skip_str = "ok $test # skip"; if (defined $reason) { - sanitize_comment($reason); + _sanitize_comment($reason); $skip_str .= " $reason" if length $reason; } @@ -302,7 +297,7 @@ sub ok ($;$) { ++$failed; } if (defined $desc) { - sanitize_comment($desc); + _sanitize_comment($desc); $test_str .= " - $desc" if length $desc; } @@ -360,12 +355,17 @@ sub isnt ($$;$) { my %binops = ( 'or' => 'or', - 'and' => 'and', 'xor' => 'xor', + 'and' => 'and', '||' => 'hor', + ('//' => 'dor') x ($] >= 5.010), '&&' => 'hand', + '|' => 'bor', + '^' => 'bxor', + '&' => 'band', + 'lt' => 'lt', 'le' => 'le', 'gt' => 'gt', @@ -384,7 +384,21 @@ my %binops = ( '=~' => 'like', '!~' => 'unlike', - '~~' => 'smartmatch', + ('~~' => 'smartmatch') x ($] >= 5.010), + + '+' => 'add', + '-' => 'substract', + '*' => 'multiply', + '/' => 'divide', + '%' => 'modulo', + '<<' => 'lshift', + '>>' => 'rshift', + + '.' => 'concat', + '..' => 'flipflop', + '...' => 'altflipflop', + ',' => 'comma', + '=>' => 'fatcomma', ); my %binop_handlers; @@ -398,7 +412,7 @@ sub _create_binop_handler { eval <<"IS_BINOP"; sub is_$name (\$\$;\$) { my (\$got, \$expected, \$desc) = \@_; - \@_ = ((\$got $op \$expected), \$desc); + \@_ = (scalar(\$got $op \$expected), \$desc); goto &ok; } IS_BINOP @@ -446,7 +460,7 @@ sub _diag_fh { return if $no_diag; my $msg = join '', map { defined($_) ? $_ : 'undef' } @_; - sanitize_comment($msg); + _sanitize_comment($msg); return unless length $msg; local $\; @@ -484,7 +498,7 @@ sub BAIL_OUT { my $bail_out_str = 'Bail out!'; if (defined $desc) { - sanitize_comment($desc); + _sanitize_comment($desc); $bail_out_str .= " $desc" if length $desc; # Two spaces }