X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fop%2Fver.t;h=79c36b6bc585312b251cefa9f306440dc6198515;hb=3444c34c7da9f235e181b5c175a1fa1357e7a055;hp=f1add6186b010d3c08fd1a056d1b1e5e71d9bfef;hpb=9eeec6595254a060dac5b35fa8473fd63d3bff03;p=p5sagit%2Fp5-mst-13.2.git diff --git a/t/op/ver.t b/t/op/ver.t index f1add61..79c36b6 100755 --- a/t/op/ver.t +++ b/t/op/ver.t @@ -11,9 +11,9 @@ $DOWARN = 1; # enable run-time warnings now use Config; require "test.pl"; -plan( tests => 47 ); +plan( tests => 53 ); -eval { use v5.5.640; }; +eval 'use v5.5.640'; is( $@, '', "use v5.5.640; $@"); require_ok('v5.5.640'); @@ -52,7 +52,7 @@ is(v1.20.300.4000, "\x{1}\x{14}\x{12c}\x{fa0}",'compare embedded \x{} string'); # # now do the same without the "v" -eval { use 5.5.640; }; +eval 'use 5.5.640'; is( $@, '', "use 5.5.640; $@"); require_ok('5.5.640'); @@ -205,9 +205,20 @@ is(v200, eval("+v200"), 'v200 eq eval("+v200")' ); # Tests for string/numeric value of $] itself my ($revision,$version,$subversion) = split '\.', sprintf("%vd",$^V); +print "# revision = '$revision'\n"; +print "# version = '$version'\n"; +print "# subversion = '$subversion'\n"; + my $v = sprintf("%d.%.3d%.3d",$revision,$version,$subversion); -ok( $v eq "$]", qq{"\$^V eq "\$]"}); +print "# v = '$v'\n"; +print "# ] = '$]'\n"; + +$v =~ s/000$// if $subversion == 0; + +print "# v = '$v'\n"; + +ok( $v eq "$]", qq{\$^V eq "\$]"}); $v = $revision + $version/1000 + $subversion/1000000; @@ -234,3 +245,22 @@ SKIP: { } } } + +# Tests for magic v-strings + +$v = 1.2.3; +is( ref(\$v), 'VSTRING', 'v-string objects' ); + +$v = v1.2_3; +is( ref(\$v), 'VSTRING', 'v-string objects with v' ); +is( sprintf("%vd", $v), '1.23', 'v-string ignores underscores' ); + +# [perl #16010] +%h = (v65 => 42); +ok( exists $h{v65}, "v-stringness is not engaged for vX" ); +%h = (v65.66 => 42); +ok( exists $h{chr(65).chr(66)}, "v-stringness is engaged for vX.Y" ); +%h = (65.66.67 => 42); +ok( exists $h{chr(65).chr(66).chr(67)}, "v-stringness is engaged for X.Y.Z" ); + +