summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--MANIFEST1
-rwxr-xr-xt/TEST2
-rw-r--r--t/camel-III/vstring.t37
-rw-r--r--t/harness2
-rwxr-xr-xt/op/ver.t128
5 files changed, 79 insertions, 91 deletions
diff --git a/MANIFEST b/MANIFEST
index f09c981eb5..6219354cc9 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 a1080e230e..702409e467 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 6dec4ddd69..0000000000
--- 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 ca8a676aea..3cacc59337 100644
--- a/t/harness
+++ b/t/harness
@@ -37,7 +37,7 @@ foreach (keys %datahandle) {
}
@tests = @ARGV;
-@tests = <base/*.t comp/*.t cmd/*.t io/*.t op/*.t pragma/*.t lib/*.t camel-III/*.t> unless @tests;
+@tests = <base/*.t comp/*.t cmd/*.t io/*.t op/*.t pragma/*.t lib/*.t pod/*.t> unless @tests;
Test::Harness::runtests @tests;
exit(0) unless -e "../testcompile";
diff --git a/t/op/ver.t b/t/op/ver.t
index 2eddabd22d..0fe7fd1bbb 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");