From: Jarkko Hietaniemi Date: Fri, 11 May 2001 13:45:06 +0000 (+0000) Subject: Merge the camel-III/vstring.t with op/ver.t. X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=fd36d4b8fc952d7c333e7ec371939c57f8174aa8;p=p5sagit%2Fp5-mst-13.2.git Merge the camel-III/vstring.t with op/ver.t. p4raw-id: //depot/perl@10082 --- diff --git a/MANIFEST b/MANIFEST index f09c981..6219354 100644 --- a/MANIFEST +++ b/MANIFEST @@ -1410,7 +1410,6 @@ t/base/lex.t See if lexical items work t/base/pat.t See if pattern matching works t/base/rs.t See if record-read works t/base/term.t See if various terms work -t/camel-III/vstring.t See if Camel 3rd edition is lying. t/cmd/elsif.t See if else-if works t/cmd/for.t See if for loops work t/cmd/mod.t See if statement modifiers work diff --git a/t/TEST b/t/TEST index a1080e2..702409e 100755 --- a/t/TEST +++ b/t/TEST @@ -46,7 +46,7 @@ $ENV{EMXSHELL} = 'sh'; # For OS/2 if ($#ARGV == -1) { @ARGV = split(/[ \n]/, - `echo base/*.t comp/*.t cmd/*.t run/*.t io/*.t; echo op/*.t pragma/*.t lib/*.t pod/*.t camel-III/*.t`); + `echo base/*.t comp/*.t cmd/*.t run/*.t io/*.t; echo op/*.t pragma/*.t lib/*.t pod/*.t`); } # %infinite = ( 'comp/require.t', 1, 'op/bop.t', 1, 'lib/hostname.t', 1 ); diff --git a/t/camel-III/vstring.t b/t/camel-III/vstring.t deleted file mode 100644 index 6dec4dd..0000000 --- a/t/camel-III/vstring.t +++ /dev/null @@ -1,37 +0,0 @@ -# See if the things Camel-III says are true. -BEGIN { - chdir 't' if -d 't'; - @INC = '../lib'; -} -use Test; -plan test => 5; - -# Chapter 2 pp67/68 -my $vs = v1.20.300.4000; -ok($vs,"\x{1}\x{14}\x{12c}\x{fa0}","v-string ne \\x{}"); -ok($vs,chr(1).chr(20).chr(300).chr(4000),"v-string ne chr()"); -ok('foo',((chr(193) eq 'A') ? v134.150.150 : v102.111.111),"v-string ne ''"); - -# Chapter 15, pp403 - -# See if sane addr and gethostbyaddr() work -eval { require Socket; gethostbyaddr(v127.0.0.1,Socket::AF_INET()) }; -if ($@) - { - # No - so don't test insane fails. - skip("No Socket",''); - } -else - { - my $ip = v2004.148.0.1; - my $host; - eval { $host = gethostbyaddr($ip,Socket::AF_INET()) }; - ok($@ =~ /Wide character/,1,"Non-bytes leak to gethostbyaddr"); - } - -# Chapter 28, pp671 -ok(v5.6.0 lt v5.7.0,1,"v5.6.0 lt v5.7.0 fails"); - -# floating point too messy -# my $v = ord($^V)+ord(substr($^V,1,1))/1000+ord(substr($^V,2,1))/1000000; -# ok($v,$],"\$^V and \$] do not match"); diff --git a/t/harness b/t/harness index ca8a676..3cacc59 100644 --- a/t/harness +++ b/t/harness @@ -37,7 +37,7 @@ foreach (keys %datahandle) { } @tests = @ARGV; -@tests = unless @tests; +@tests = unless @tests; Test::Harness::runtests @tests; exit(0) unless -e "../testcompile"; diff --git a/t/op/ver.t b/t/op/ver.t index 2eddabd..0fe7fd1 100755 --- a/t/op/ver.t +++ b/t/op/ver.t @@ -5,10 +5,20 @@ BEGIN { @INC = '../lib'; } -print "1..28\n"; +print "1..33\n"; my $test = 1; +sub okeq { + my $ok = $_[0] eq $_[1];; + print "not " unless $ok; + print "ok ", $test++; + print " # $_[2]" if !$ok && @_ == 3; + print "\n"; +} + +sub skip { print "ok ", $test++, " # Skip: $_[0]\n" } + use v5.5.640; require v5.5.640; print "ok $test\n"; ++$test; @@ -45,11 +55,9 @@ if (ord("\t") == 9) { # ASCII else { $x = v212.213.214; } -print "not " unless $x eq "MNO"; -print "ok $test\n"; ++$test; +okeq($x, "MNO"); -print "not " unless v1.20.300.4000 eq "\x{1}\x{14}\x{12c}\x{fa0}"; -print "ok $test\n"; ++$test; +okeq(v1.20.300.4000, "\x{1}\x{14}\x{12c}\x{fa0}"); # # now do the same without the "v" @@ -72,108 +80,94 @@ if (ord("\t") == 9) { # ASCII else { $x = 212.213.214; } -print "not " unless $x eq "MNO"; -print "ok $test\n"; ++$test; +okeq($x, "MNO"); -print "not " unless 1.20.300.4000 eq "\x{1}\x{14}\x{12c}\x{fa0}"; -print "ok $test\n"; ++$test; +okeq(1.20.300.4000, "\x{1}\x{14}\x{12c}\x{fa0}"); # test sprintf("%vd"...) etc if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%vd", "Perl") eq '80.101.114.108'; + okeq(sprintf("%vd", "Perl"), '80.101.114.108'); } else { - print "not " unless sprintf("%vd", "Perl") eq '215.133.153.147'; + okeq(sprintf("%vd", "Perl"), '215.133.153.147'); } -print "ok $test\n"; ++$test; -print "not " unless sprintf("%vd", v1.22.333.4444) eq '1.22.333.4444'; -print "ok $test\n"; ++$test; +okeq(sprintf("%vd", v1.22.333.4444), '1.22.333.4444'); if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%vx", "Perl") eq '50.65.72.6c'; + okeq(sprintf("%vx", "Perl"), '50.65.72.6c'); } else { - print "not " unless sprintf("%vx", "Perl") eq 'd7.85.99.93'; + okeq(sprintf("%vx", "Perl"), 'd7.85.99.93'); } -print "ok $test\n"; ++$test; -print "not " unless sprintf("%vX", 1.22.333.4444) eq '1.16.14D.115C'; -print "ok $test\n"; ++$test; +okeq(sprintf("%vX", 1.22.333.4444), '1.16.14D.115C'); if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%#*vo", ":", "Perl") eq '0120:0145:0162:0154'; + okeq(sprintf("%#*vo", ":", "Perl"), '0120:0145:0162:0154'); } else { - print "not " unless sprintf("%#*vo", ":", "Perl") eq '0327:0205:0231:0223'; + okeq(sprintf("%#*vo", ":", "Perl"), '0327:0205:0231:0223'); } -print "ok $test\n"; ++$test; -print "not " unless sprintf("%*vb", "##", v1.22.333.4444) - eq '1##10110##101001101##1000101011100'; -print "ok $test\n"; ++$test; +okeq(sprintf("%*vb", "##", v1.22.333.4444), + '1##10110##101001101##1000101011100'); -print "not " unless sprintf("%vd", join("", map { chr } - unpack 'U*', pack('U*',2001,2002,2003))) - eq '2001.2002.2003'; -print "ok $test\n"; ++$test; +okeq(sprintf("%vd", join("", map { chr } + unpack 'U*', pack('U*',2001,2002,2003))), + '2001.2002.2003'); { use bytes; + if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%vd", "Perl") eq '80.101.114.108'; + okeq(sprintf("%vd", "Perl"), '80.101.114.108'); } else { - print "not " unless sprintf("%vd", "Perl") eq '215.133.153.147'; + okeq(sprintf("%vd", "Perl"), '215.133.153.147'); } - print "ok $test\n"; ++$test; if (ord("\t") == 9) { # ASCII - print "not " unless - sprintf("%vd", 1.22.333.4444) eq '1.22.197.141.225.133.156'; + okeq(sprintf("%vd", 1.22.333.4444), '1.22.197.141.225.133.156'); } else { - print "not " unless - sprintf("%vd", 1.22.333.4444) eq '1.22.142.84.187.81.112'; + okeq(sprintf("%vd", 1.22.333.4444), '1.22.142.84.187.81.112'); } - print "ok $test\n"; ++$test; if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%vx", "Perl") eq '50.65.72.6c'; + okeq(sprintf("%vx", "Perl"), '50.65.72.6c'); } else { - print "not " unless sprintf("%vx", "Perl") eq 'd7.85.99.93'; + okeq(sprintf("%vx", "Perl"), 'd7.85.99.93'); } - print "ok $test\n"; ++$test; if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%vX", v1.22.333.4444) eq '1.16.C5.8D.E1.85.9C'; + okeq(sprintf("%vX", v1.22.333.4444), '1.16.C5.8D.E1.85.9C'); } else { - print "not " unless sprintf("%vX", v1.22.333.4444) eq '1.16.8E.54.BB.51.70'; + okeq(sprintf("%vX", v1.22.333.4444), '1.16.8E.54.BB.51.70'); } - print "ok $test\n"; ++$test; if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%#*vo", ":", "Perl") eq '0120:0145:0162:0154'; + okeq(sprintf("%#*vo", ":", "Perl"), '0120:0145:0162:0154'); } else { - print "not " unless sprintf("%#*vo", ":", "Perl") eq '0327:0205:0231:0223'; + okeq(sprintf("%#*vo", ":", "Perl"), '0327:0205:0231:0223'); } - print "ok $test\n"; ++$test; if (ord("\t") == 9) { # ASCII - print "not " unless sprintf("%*vb", "##", v1.22.333.4444) - eq '1##10110##11000101##10001101##11100001##10000101##10011100'; + okeq(sprintf("%*vb", "##", v1.22.333.4444), + '1##10110##11000101##10001101##11100001##10000101##10011100'); } else { - print "not " unless sprintf("%*vb", "##", v1.22.333.4444) - eq '1##10110##10001110##1010100##10111011##1010001##1110000'; + okeq(sprintf("%*vb", "##", v1.22.333.4444), + '1##10110##10001110##1010100##10111011##1010001##1110000'); } - print "ok $test\n"; ++$test; } { + # 24..28 + # bug id 20000323.056 print "not " unless "\x{41}" eq +v65; @@ -196,3 +190,35 @@ print "ok $test\n"; ++$test; print "ok $test\n"; $test++; } + +# See if the things Camel-III says are true: 29..33 + +# Chapter 2 pp67/68 +my $vs = v1.20.300.4000; +okeq($vs,"\x{1}\x{14}\x{12c}\x{fa0}","v-string ne \\x{}"); +okeq($vs,chr(1).chr(20).chr(300).chr(4000),"v-string ne chr()"); +okeq('foo',((chr(193) eq 'A') ? v134.150.150 : v102.111.111),"v-string ne ''"); + +# Chapter 15, pp403 + +# See if sane addr and gethostbyaddr() work +eval { require Socket; gethostbyaddr(v127.0.0.1,Socket::AF_INET()) }; +if ($@) + { + # No - so don't test insane fails. + skip("No Socket"); + } +else + { + my $ip = v2004.148.0.1; + my $host; + eval { $host = gethostbyaddr($ip,Socket::AF_INET()) }; + okeq($@ =~ /Wide character/,1,"Non-bytes leak to gethostbyaddr"); + } + +# Chapter 28, pp671 +okeq(v5.6.0 lt v5.7.0,1,"v5.6.0 lt v5.7.0 fails"); + +# floating point too messy +# my $v = ord($^V)+ord(substr($^V,1,1))/1000+ord(substr($^V,2,1))/1000000; +# okeq($v,$],"\$^V and \$] do not match");