From: Rafael Garcia-Suarez Date: Tue, 9 Oct 2001 15:15:06 +0000 (+0000) Subject: new tests, new TODO test X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=e8ebd21be84d480c75c5ed96a29c4345fc910723;p=p5sagit%2Fp5-mst-13.2.git new tests, new TODO test Message-Id: p4raw-id: //depot/perl@12383 --- diff --git a/t/op/subst.t b/t/op/subst.t index 907d0da..10ad7fe 100755 --- a/t/op/subst.t +++ b/t/op/subst.t @@ -1,4 +1,4 @@ -#!./perl +#!./perl -wT BEGIN { chdir 't' if -d 't'; @@ -6,211 +6,206 @@ BEGIN { require Config; import Config; } -print "1..85\n"; +require './test.pl'; +plan( tests => 86 ); $x = 'foo'; $_ = "x"; s/x/\$x/; -print "#1\t:$_: eq :\$x:\n"; -if ($_ eq '$x') {print "ok 1\n";} else {print "not ok 1\n";} +ok( $_ eq '$x', ":$_: eq :\$x:" ); $_ = "x"; s/x/$x/; -print "#2\t:$_: eq :foo:\n"; -if ($_ eq 'foo') {print "ok 2\n";} else {print "not ok 2\n";} +ok( $_ eq 'foo', ":$_: eq :foo:" ); $_ = "x"; s/x/\$x $x/; -print "#3\t:$_: eq :\$x foo:\n"; -if ($_ eq '$x foo') {print "ok 3\n";} else {print "not ok 3\n";} +ok( $_ eq '$x foo', ":$_: eq :\$x foo:" ); $b = 'cd'; ($a = 'abcdef') =~ s<(b${b}e)>'\n$1'; -print "#4\t:$1: eq :bcde:\n"; -print "#4\t:$a: eq :a\\n\$1f:\n"; -if ($1 eq 'bcde' && $a eq 'a\n$1f') {print "ok 4\n";} else {print "not ok 4\n";} +ok( $1 eq 'bcde' && $a eq 'a\n$1f', ":$1: eq :bcde: ; :$a: eq :a\\n\$1f:" ); $a = 'abacada'; -if (($a =~ s/a/x/g) == 4 && $a eq 'xbxcxdx') - {print "ok 5\n";} else {print "not ok 5\n";} +ok( ($a =~ s/a/x/g) == 4 && $a eq 'xbxcxdx' ); -if (($a =~ s/a/y/g) == 0 && $a eq 'xbxcxdx') - {print "ok 6\n";} else {print "not ok 6 $a\n";} +ok( ($a =~ s/a/y/g) == 0 && $a eq 'xbxcxdx' ); -if (($a =~ s/b/y/g) == 1 && $a eq 'xyxcxdx') - {print "ok 7\n";} else {print "not ok 7 $a\n";} +ok( ($a =~ s/b/y/g) == 1 && $a eq 'xyxcxdx' ); $_ = 'ABACADA'; -if (/a/i && s///gi && $_ eq 'BCD') {print "ok 8\n";} else {print "not ok 8 $_\n";} +ok( /a/i && s///gi && $_ eq 'BCD' ); $_ = '\\' x 4; -if (length($_) == 4) {print "ok 9\n";} else {print "not ok 9\n";} -s/\\/\\\\/g; -if ($_ eq '\\' x 8) {print "ok 10\n";} else {print "not ok 10 $_\n";} +ok( length($_) == 4 ); +$snum = s/\\/\\\\/g; +ok( $_ eq '\\' x 8 && $snum == 4 ); $_ = '\/' x 4; -if (length($_) == 8) {print "ok 11\n";} else {print "not ok 11\n";} -s/\//\/\//g; -if ($_ eq '\\//' x 4) {print "ok 12\n";} else {print "not ok 12\n";} -if (length($_) == 12) {print "ok 13\n";} else {print "not ok 13\n";} +ok( length($_) == 8 ); +$snum = s/\//\/\//g; +ok( $_ eq '\\//' x 4 && $snum == 4 ); +ok( length($_) == 12 ); $_ = 'aaaXXXXbbb'; s/^a//; -print $_ eq 'aaXXXXbbb' ? "ok 14\n" : "not ok 14\n"; +ok( $_ eq 'aaXXXXbbb' ); $_ = 'aaaXXXXbbb'; s/a//; -print $_ eq 'aaXXXXbbb' ? "ok 15\n" : "not ok 15\n"; +ok( $_ eq 'aaXXXXbbb' ); $_ = 'aaaXXXXbbb'; s/^a/b/; -print $_ eq 'baaXXXXbbb' ? "ok 16\n" : "not ok 16\n"; +ok( $_ eq 'baaXXXXbbb' ); $_ = 'aaaXXXXbbb'; s/a/b/; -print $_ eq 'baaXXXXbbb' ? "ok 17\n" : "not ok 17\n"; +ok( $_ eq 'baaXXXXbbb' ); $_ = 'aaaXXXXbbb'; s/aa//; -print $_ eq 'aXXXXbbb' ? "ok 18\n" : "not ok 18\n"; +ok( $_ eq 'aXXXXbbb' ); $_ = 'aaaXXXXbbb'; s/aa/b/; -print $_ eq 'baXXXXbbb' ? "ok 19\n" : "not ok 19\n"; +ok( $_ eq 'baXXXXbbb' ); $_ = 'aaaXXXXbbb'; s/b$//; -print $_ eq 'aaaXXXXbb' ? "ok 20\n" : "not ok 20\n"; +ok( $_ eq 'aaaXXXXbb' ); $_ = 'aaaXXXXbbb'; s/b//; -print $_ eq 'aaaXXXXbb' ? "ok 21\n" : "not ok 21\n"; +ok( $_ eq 'aaaXXXXbb' ); $_ = 'aaaXXXXbbb'; s/bb//; -print $_ eq 'aaaXXXXb' ? "ok 22\n" : "not ok 22\n"; +ok( $_ eq 'aaaXXXXb' ); $_ = 'aaaXXXXbbb'; s/aX/y/; -print $_ eq 'aayXXXbbb' ? "ok 23\n" : "not ok 23\n"; +ok( $_ eq 'aayXXXbbb' ); $_ = 'aaaXXXXbbb'; s/Xb/z/; -print $_ eq 'aaaXXXzbb' ? "ok 24\n" : "not ok 24\n"; +ok( $_ eq 'aaaXXXzbb' ); $_ = 'aaaXXXXbbb'; s/aaX.*Xbb//; -print $_ eq 'ab' ? "ok 25\n" : "not ok 25\n"; +ok( $_ eq 'ab' ); $_ = 'aaaXXXXbbb'; s/bb/x/; -print $_ eq 'aaaXXXXxb' ? "ok 26\n" : "not ok 26\n"; +ok( $_ eq 'aaaXXXXxb' ); # now for some unoptimized versions of the same. $_ = 'aaaXXXXbbb'; $x ne $x || s/^a//; -print $_ eq 'aaXXXXbbb' ? "ok 27\n" : "not ok 27\n"; +ok( $_ eq 'aaXXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/a//; -print $_ eq 'aaXXXXbbb' ? "ok 28\n" : "not ok 28\n"; +ok( $_ eq 'aaXXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/^a/b/; -print $_ eq 'baaXXXXbbb' ? "ok 29\n" : "not ok 29\n"; +ok( $_ eq 'baaXXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/a/b/; -print $_ eq 'baaXXXXbbb' ? "ok 30\n" : "not ok 30\n"; +ok( $_ eq 'baaXXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/aa//; -print $_ eq 'aXXXXbbb' ? "ok 31\n" : "not ok 31\n"; +ok( $_ eq 'aXXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/aa/b/; -print $_ eq 'baXXXXbbb' ? "ok 32\n" : "not ok 32\n"; +ok( $_ eq 'baXXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/b$//; -print $_ eq 'aaaXXXXbb' ? "ok 33\n" : "not ok 33\n"; +ok( $_ eq 'aaaXXXXbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/b//; -print $_ eq 'aaaXXXXbb' ? "ok 34\n" : "not ok 34\n"; +ok( $_ eq 'aaaXXXXbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/bb//; -print $_ eq 'aaaXXXXb' ? "ok 35\n" : "not ok 35\n"; +ok( $_ eq 'aaaXXXXb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/aX/y/; -print $_ eq 'aayXXXbbb' ? "ok 36\n" : "not ok 36\n"; +ok( $_ eq 'aayXXXbbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/Xb/z/; -print $_ eq 'aaaXXXzbb' ? "ok 37\n" : "not ok 37\n"; +ok( $_ eq 'aaaXXXzbb' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/aaX.*Xbb//; -print $_ eq 'ab' ? "ok 38\n" : "not ok 38\n"; +ok( $_ eq 'ab' ); $_ = 'aaaXXXXbbb'; $x ne $x || s/bb/x/; -print $_ eq 'aaaXXXXxb' ? "ok 39\n" : "not ok 39\n"; +ok( $_ eq 'aaaXXXXxb' ); $_ = 'abc123xyz'; s/(\d+)/$1*2/e; # yields 'abc246xyz' -print $_ eq 'abc246xyz' ? "ok 40\n" : "not ok 40\n"; +ok( $_ eq 'abc246xyz' ); s/(\d+)/sprintf("%5d",$1)/e; # yields 'abc 246xyz' -print $_ eq 'abc 246xyz' ? "ok 41\n" : "not ok 41\n"; +ok( $_ eq 'abc 246xyz' ); s/(\w)/$1 x 2/eg; # yields 'aabbcc 224466xxyyzz' -print $_ eq 'aabbcc 224466xxyyzz' ? "ok 42\n" : "not ok 42\n"; +ok( $_ eq 'aabbcc 224466xxyyzz' ); $_ = "aaaaa"; -print y/a/b/ == 5 ? "ok 43\n" : "not ok 43\n"; -print y/a/b/ == 0 ? "ok 44\n" : "not ok 44\n"; -print y/b// == 5 ? "ok 45\n" : "not ok 45\n"; -print y/b/c/s == 5 ? "ok 46\n" : "not ok 46\n"; -print y/c// == 1 ? "ok 47\n" : "not ok 47\n"; -print y/c//d == 1 ? "ok 48\n" : "not ok 48\n"; -print $_ eq "" ? "ok 49\n" : "not ok 49\n"; +ok( y/a/b/ == 5 ); +ok( y/a/b/ == 0 ); +ok( y/b// == 5 ); +ok( y/b/c/s == 5 ); +ok( y/c// == 1 ); +ok( y/c//d == 1 ); +ok( $_ eq "" ); $_ = "Now is the %#*! time for all good men..."; -print (($x=(y/a-zA-Z //cd)) == 7 ? "ok 50\n" : "not ok 50\n"); -print y/ / /s == 8 ? "ok 51\n" : "not ok 51\n"; +ok( ($x=(y/a-zA-Z //cd)) == 7 ); +ok( y/ / /s == 8 ); $_ = 'abcdefghijklmnopqrstuvwxyz0123456789'; tr/a-z/A-Z/; -print $_ eq 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789' ? "ok 52\n" : "not ok 52\n"; +ok( $_ eq 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789' ); # same as tr/A-Z/a-z/; -if ($Config{ebcdic} eq 'define') { # EBCDIC. +if (defined $Config{ebcdic} && $Config{ebcdic} eq 'define') { # EBCDIC. no utf8; y[\301-\351][\201-\251]; } else { # Ye Olde ASCII. Or something like it. y[\101-\132][\141-\172]; } -print $_ eq 'abcdefghijklmnopqrstuvwxyz0123456789' ? "ok 53\n" : "not ok 53\n"; +ok( $_ eq 'abcdefghijklmnopqrstuvwxyz0123456789' ); -if (ord("+") == ord(",") - 1 && ord(",") == ord("-") - 1 && - ord("a") == ord("b") - 1 && ord("b") == ord("c") - 1) { - $_ = '+,-'; - tr/+--/a-c/; - print "not " unless $_ eq 'abc'; +SKIP: { + skip("not ASCII",1) unless (ord("+") == ord(",") - 1 + && ord(",") == ord("-") - 1 + && ord("a") == ord("b") - 1 + && ord("b") == ord("c") - 1); + $_ = '+,-'; + tr/+--/a-c/; + ok( $_ eq 'abc' ); } -print "ok 54\n"; $_ = '+,-'; tr/+\--/a\/c/; -print $_ eq 'a,/' ? "ok 55\n" : "not ok 55\n"; +ok( $_ eq 'a,/' ); $_ = '+,-'; tr/-+,/ab\-/; -print $_ eq 'b-a' ? "ok 56\n" : "not ok 56\n"; +ok( $_ eq 'b-a' ); # test recursive substitutions @@ -233,56 +228,48 @@ sub exp_vars { $str; } -print exp_vars('$(AAAAA)',0) eq 'D' - ? "ok 57\n" : "not ok 57\n"; -print exp_vars('$(E)',0) eq 'p HHHHH q' - ? "ok 58\n" : "not ok 58\n"; -print exp_vars('$(DIR)',0) eq '$(UNDEFINEDNAME)/xxx' - ? "ok 59\n" : "not ok 59\n"; -print exp_vars('foo $(DIR)/yyy bar',0) eq 'foo $(UNDEFINEDNAME)/xxx/yyy bar' - ? "ok 60\n" : "not ok 60\n"; - -# a match nested in the RHS of a substitution: +ok( exp_vars('$(AAAAA)',0) eq 'D' ); +ok( exp_vars('$(E)',0) eq 'p HHHHH q' ); +ok( exp_vars('$(DIR)',0) eq '$(UNDEFINEDNAME)/xxx' ); +ok( exp_vars('foo $(DIR)/yyy bar',0) eq 'foo $(UNDEFINEDNAME)/xxx/yyy bar' ); $_ = "abcd"; s/(..)/$x = $1, m#.#/eg; -print $x eq "cd" ? "ok 61\n" : "not ok 61\n"; +ok( $x eq "cd", 'a match nested in the RHS of a substitution' ); # Subst and lookbehind $_="ccccc"; -s/(?/g; +$snum = s/(\d*|x)/<$1>/g; $foo = '<>' . ('<>' x 20) ; -print ($_ eq $foo ? "ok 71\n" : "not ok 71\n#'$_'\n#'$foo'\n"); +ok( $_ eq $foo && $snum == 41 ); $t = 'aaaaaaaaa'; $_ = $t; pos = 6; -s/\Ga/xx/g; -print "not " unless $_ eq 'aaaaaaxxxxxx'; -print "ok 72\n"; +$snum = s/\Ga/xx/g; +ok( $_ eq 'aaaaaaxxxxxx' && $snum == 3 ); $_ = $t; pos = 6; -s/\Ga/x/g; -print "not " unless $_ eq 'aaaaaaxxx'; -print "ok 73\n"; +$snum = s/\Ga/x/g; +ok( $_ eq 'aaaaaaxxx' && $snum == 3 ); $_ = $t; pos = 6; s/\Ga/xx/; -print "not " unless $_ eq 'aaaaaaxxaa'; -print "ok 74\n"; +ok( $_ eq 'aaaaaaxxaa' ); $_ = $t; pos = 6; s/\Ga/x/; -print "not " unless $_ eq 'aaaaaaxaa'; -print "ok 75\n"; +ok( $_ eq 'aaaaaaxaa' ); $_ = $t; -s/\Ga/xx/g; -print "not " unless $_ eq 'xxxxxxxxxxxxxxxxxx'; -print "ok 76\n"; +$snum = s/\Ga/xx/g; +ok( $_ eq 'xxxxxxxxxxxxxxxxxx' && $snum == 9 ); $_ = $t; -s/\Ga/x/g; -print "not " unless $_ eq 'xxxxxxxxx'; -print "ok 77\n"; +$snum = s/\Ga/x/g; +ok( $_ eq 'xxxxxxxxx' && $snum == 9 ); $_ = $t; s/\Ga/xx/; -print "not " unless $_ eq 'xxaaaaaaaa'; -print "ok 78\n"; +ok( $_ eq 'xxaaaaaaaa' ); $_ = $t; s/\Ga/x/; -print "not " unless $_ eq 'xaaaaaaaa'; -print "ok 79\n"; +ok( $_ eq 'xaaaaaaaa' ); $_ = 'aaaa'; -s/\ba/./g; -print "#'$_'\nnot " unless $_ eq '.aaa'; -print "ok 80\n"; +$snum = s/\ba/./g; +ok( $_ eq '.aaa' && $snum == 1 ); eval q% s/a/"b"}/e %; -print ($@ =~ /Bad evalled substitution/ ? "ok 81\n" : "not ok 81\n"); +ok( $@ =~ /Bad evalled substitution/ ); eval q% ($_ = "x") =~ s/(.)/"$1 "/e %; -print +($_ eq "x " and !length $@) ? "ok 82\n" : "not ok 82\n# \$_ eq $_, $@\n"; +ok( $_ eq "x " and !length $@ ); $x = $x = 'interp'; eval q% ($_ = "x") =~ s/x(($x)*)/"$1"/e %; -print +($_ eq '' and !length $@) ? "ok 83\n" : "not ok 83\n# \$_ eq $_, $@\n"; +ok( $_ eq '' and !length $@ ); $_ = "C:/"; -s/^([a-z]:)/\u$1/ and print "not "; -print "ok 84\n"; +ok( !s/^([a-z]:)/\u$1/ ); $_ = "Charles Bronson"; -s/\B\w//g; -print $_ eq "C B" ? "ok 85\n" : "not ok 85\n# \$_ eq '$_'\n"; - +$snum = s/\B\w//g; +ok( $_ eq "C B" && $snum == 12 );