1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
#!/usr/bin/perl
# Unit testing for PPI::Token::Number::Version
use lib 't/lib';
use PPI::Test::pragmas;
use Test::More tests => 2187 + ($ENV{AUTHOR_TESTING} ? 1 : 0);
use PPI ();
use PPI::Singletons qw( %KEYWORDS %OPERATOR %QUOTELIKE );
use Helper 'safe_new';
LITERAL: {
my $doc1 = new_ok( 'PPI::Document' => [ \'1.2.3.4' ] );
my $doc2 = new_ok( 'PPI::Document' => [ \'v1.2.3.4' ] );
isa_ok( $doc1->child(0), 'PPI::Statement' );
isa_ok( $doc2->child(0), 'PPI::Statement' );
isa_ok( $doc1->child(0)->child(0), 'PPI::Token::Number::Version' );
isa_ok( $doc2->child(0)->child(0), 'PPI::Token::Number::Version' );
my $literal1 = $doc1->child(0)->child(0)->literal;
my $literal2 = $doc2->child(0)->child(0)->literal;
is( length($literal1), 4, 'The literal length of doc1 is 4' );
is( length($literal2), 4, 'The literal length of doc1 is 4' );
is( $literal1, $literal2, 'Literals match for 1.2.3.4 vs v1.2.3.4' );
}
VSTRING_ENDS_CORRECTLY: {
my @tests = (
(
map {
{
desc=>"no . in 'v49$_', so not a version string",
code=>"v49$_",
expected=>[ 'PPI::Token::Word' => "v49$_" ],
}
} (
'x3', # not fooled by faux x operator with operand
'e10', # not fooled by faux scientific notation
keys %KEYWORDS,
),
),
(
map {
{
desc => "version string in 'v49.49$_' stops after number",
code => "v49.49$_",
expected => [
'PPI::Token::Number::Version' => 'v49.49',
get_class($_) => $_,
],
},
} (
keys %KEYWORDS,
),
),
(
map {
{
desc => "version string in '49.49.49$_' stops after number",
code => "49.49.49$_",
expected => [
'PPI::Token::Number::Version' => '49.49.49',
get_class($_) => $_,
],
},
} (
keys %KEYWORDS,
),
),
{
desc => 'version string, x, and operand',
code => 'v49.49.49x3',
expected => [
'PPI::Token::Number::Version' => 'v49.49.49',
'PPI::Token::Operator' => 'x',
'PPI::Token::Number' => '3',
],
},
);
for my $test ( @tests ) {
my $code = $test->{code};
my $d = safe_new \$test->{code};
my $tokens = $d->find( sub { 1; } );
$tokens = [ map { ref($_), $_->content() } @$tokens ];
my $expected = $test->{expected};
unshift @$expected, 'PPI::Statement', $test->{code};
my $ok = is_deeply( $tokens, $expected, $test->{desc} );
if ( !$ok ) {
diag "$test->{code} ($test->{desc})\n";
diag explain $tokens;
diag explain $test->{expected};
}
}
}
sub get_class {
my ( $t ) = @_;
my $ql = $QUOTELIKE{$t};
return "PPI::Token::$ql" if $ql;
return 'PPI::Token::Operator' if $OPERATOR{$t};
return 'PPI::Token::Word';
}
|