X-Git-Url: https://perl5.git.perl.org/perl5.git/blobdiff_plain/0e06870bf080a38cda51c06c6612359afc2334e1..65ab9279784aa811d78b2903b57bc0e7947dec78:/t/op/chop.t diff --git a/t/op/chop.t b/t/op/chop.t old mode 100755 new mode 100644 index 65d0669..36f8cad --- a/t/op/chop.t +++ b/t/op/chop.t @@ -1,18 +1,20 @@ #!./perl -print "1..33\n"; +BEGIN { + chdir 't' if -d 't'; + @INC = '../lib'; + require './test.pl'; +} -# optimized +plan tests => 143; $_ = 'abc'; -$c = do foo(); -if ($c . $_ eq 'cab') {print "ok 1\n";} else {print "not ok 1 $c$_\n";} - -# unoptimized +$c = foo(); +is ($c . $_, 'cab', 'optimized'); $_ = 'abc'; $c = chop($_); -if ($c . $_ eq 'cab') {print "ok 2\n";} else {print "not ok 2\n";} +is ($c . $_ , 'cab', 'unoptimized'); sub foo { chop; @@ -21,85 +23,242 @@ sub foo { @foo = ("hi \n","there\n","!\n"); @bar = @foo; chop(@bar); -print join('',@bar) eq 'hi there!' ? "ok 3\n" : "not ok 3\n"; +is (join('',@bar), 'hi there!'); $foo = "\n"; chop($foo,@foo); -print join('',$foo,@foo) eq 'hi there!' ? "ok 4\n" : "not ok 4\n"; +is (join('',$foo,@foo), 'hi there!'); $_ = "foo\n\n"; -print chomp() == 1 ? "ok 5\n" : "not ok 5\n"; -print $_ eq "foo\n" ? "ok 6\n" : "not ok 6\n"; +$got = chomp(); +ok ($got == 1) or print "# got $got\n"; +is ($_, "foo\n"); $_ = "foo\n"; -print chomp() == 1 ? "ok 7\n" : "not ok 7\n"; -print $_ eq "foo" ? "ok 8\n" : "not ok 8\n"; +$got = chomp(); +ok ($got == 1) or print "# got $got\n"; +is ($_, "foo"); $_ = "foo"; -print chomp() == 0 ? "ok 9\n" : "not ok 9\n"; -print $_ eq "foo" ? "ok 10\n" : "not ok 10\n"; +$got = chomp(); +ok ($got == 0) or print "# got $got\n"; +is ($_, "foo"); $_ = "foo"; $/ = "oo"; -print chomp() == 2 ? "ok 11\n" : "not ok 11\n"; -print $_ eq "f" ? "ok 12\n" : "not ok 12\n"; +$got = chomp(); +ok ($got == 2) or print "# got $got\n"; +is ($_, "f"); $_ = "bar"; $/ = "oo"; -print chomp() == 0 ? "ok 13\n" : "not ok 13\n"; -print $_ eq "bar" ? "ok 14\n" : "not ok 14\n"; +$got = chomp(); +ok ($got == 0) or print "# got $got\n"; +is ($_, "bar"); $_ = "f\n\n\n\n\n"; $/ = ""; -print chomp() == 5 ? "ok 15\n" : "not ok 15\n"; -print $_ eq "f" ? "ok 16\n" : "not ok 16\n"; +$got = chomp(); +ok ($got == 5) or print "# got $got\n"; +is ($_, "f"); $_ = "f\n\n"; $/ = ""; -print chomp() == 2 ? "ok 17\n" : "not ok 17\n"; -print $_ eq "f" ? "ok 18\n" : "not ok 18\n"; +$got = chomp(); +ok ($got == 2) or print "# got $got\n"; +is ($_, "f"); $_ = "f\n"; $/ = ""; -print chomp() == 1 ? "ok 19\n" : "not ok 19\n"; -print $_ eq "f" ? "ok 20\n" : "not ok 20\n"; +$got = chomp(); +ok ($got == 1) or print "# got $got\n"; +is ($_, "f"); $_ = "f"; $/ = ""; -print chomp() == 0 ? "ok 21\n" : "not ok 21\n"; -print $_ eq "f" ? "ok 22\n" : "not ok 22\n"; +$got = chomp(); +ok ($got == 0) or print "# got $got\n"; +is ($_, "f"); $_ = "xx"; $/ = "xx"; -print chomp() == 2 ? "ok 23\n" : "not ok 23\n"; -print $_ eq "" ? "ok 24\n" : "not ok 24\n"; +$got = chomp(); +ok ($got == 2) or print "# got $got\n"; +is ($_, ""); $_ = "axx"; $/ = "xx"; -print chomp() == 2 ? "ok 25\n" : "not ok 25\n"; -print $_ eq "a" ? "ok 26\n" : "not ok 26\n"; +$got = chomp(); +ok ($got == 2) or print "# got $got\n"; +is ($_, "a"); $_ = "axx"; $/ = "yy"; -print chomp() == 0 ? "ok 27\n" : "not ok 27\n"; -print $_ eq "axx" ? "ok 28\n" : "not ok 28\n"; +$got = chomp(); +ok ($got == 0) or print "# got $got\n"; +is ($_, "axx"); # This case once mistakenly behaved like paragraph mode. $_ = "ab\n"; $/ = \3; -print chomp() == 0 ? "ok 29\n" : "not ok 29\n"; -print $_ eq "ab\n" ? "ok 30\n" : "not ok 30\n"; +$got = chomp(); +ok ($got == 0) or print "# got $got\n"; +is ($_, "ab\n"); # Go Unicode. $_ = "abc\x{1234}"; chop; -print $_ eq "abc" ? "ok 31\n" : "not ok 31\n"; +is ($_, "abc", "Go Unicode"); $_ = "abc\x{1234}d"; chop; -print $_ eq "abc\x{1234}" ? "ok 32\n" : "not ok 32\n"; +is ($_, "abc\x{1234}"); $_ = "\x{1234}\x{2345}"; chop; -print $_ eq "\x{1234}" ? "ok 33\n" : "not ok 33\n"; +is ($_, "\x{1234}"); + +my @stuff = qw(this that); +is (chop(@stuff[0,1]), 't'); + +# bug id 20010305.012 +@stuff = qw(ab cd ef); +is (chop(@stuff = @stuff), 'f'); + +@stuff = qw(ab cd ef); +is (chop(@stuff[0, 2]), 'f'); + +my %stuff = (1..4); +is (chop(@stuff{1, 3}), '4'); + +# chomp should not stringify references unless it decides to modify them +$_ = []; +$/ = "\n"; +$got = chomp(); +ok ($got == 0) or print "# got $got\n"; +is (ref($_), "ARRAY", "chomp ref (modify)"); + +$/ = ")"; # the last char of something like "ARRAY(0x80ff6e4)" +$got = chomp(); +ok ($got == 1) or print "# got $got\n"; +ok (!ref($_), "chomp ref (no modify)"); + +$/ = "\n"; + +%chomp = ("One" => "One", "Two\n" => "Two", "" => ""); +%chop = ("One" => "On", "Two\n" => "Two", "" => ""); + +foreach (keys %chomp) { + my $key = $_; + eval {chomp $_}; + if ($@) { + my $err = $@; + $err =~ s/\n$//s; + fail ("\$\@ = \"$err\""); + } else { + is ($_, $chomp{$key}, "chomp hash key"); + } +} + +foreach (keys %chop) { + my $key = $_; + eval {chop $_}; + if ($@) { + my $err = $@; + $err =~ s/\n$//s; + fail ("\$\@ = \"$err\""); + } else { + is ($_, $chop{$key}, "chop hash key"); + } +} + +# chop and chomp can't be lvalues +eval 'chop($x) = 1;'; +ok($@ =~ /Can\'t modify.*chop.*in.*assignment/); +eval 'chomp($x) = 1;'; +ok($@ =~ /Can\'t modify.*chom?p.*in.*assignment/); +eval 'chop($x, $y) = (1, 2);'; +ok($@ =~ /Can\'t modify.*chop.*in.*assignment/); +eval 'chomp($x, $y) = (1, 2);'; +ok($@ =~ /Can\'t modify.*chom?p.*in.*assignment/); + +my @chars = ("N", latin1_to_native("\xd3"), substr ("\xd4\x{100}", 0, 1), chr 1296); +foreach my $start (@chars) { + foreach my $end (@chars) { + local $/ = $end; + my $message = "start=" . ord ($start) . " end=" . ord $end; + my $string = $start . $end; + is (chomp ($string), 1, "$message [returns 1]"); + is ($string, $start, $message); + + my $end_utf8 = $end; + utf8::encode ($end_utf8); + next if $end_utf8 eq $end; + + # $end ne $end_utf8, so these should not chomp. + $string = $start . $end_utf8; + my $chomped = $string; + is (chomp ($chomped), 0, "$message (end as bytes) [returns 0]"); + is ($chomped, $string, "$message (end as bytes)"); + + $/ = $end_utf8; + $string = $start . $end; + $chomped = $string; + is (chomp ($chomped), 0, "$message (\$/ as bytes) [returns 0]"); + is ($chomped, $string, "$message (\$/ as bytes)"); + } +} + +{ + # returns length in characters, but not in bytes. + $/ = "\x{100}"; + $a = "A$/"; + $b = chomp $a; + is ($b, 1); + + $/ = "\x{100}\x{101}"; + $a = "A$/"; + $b = chomp $a; + is ($b, 2); +} + +{ + # [perl #36569] chop fails on decoded string with trailing nul + my $asc = "perl\0"; + my $utf = "perl".pack('U',0); # marked as utf8 + is(chop($asc), "\0", "chopping ascii NUL"); + is(chop($utf), "\0", "chopping utf8 NUL"); + is($asc, "perl", "chopped ascii NUL"); + is($utf, "perl", "chopped utf8 NUL"); +} + +{ + # Change 26011: Re: A surprising segfault + # to make sure only that these obfuscated sentences will not crash. + + map chop(+()), ('')x68; + ok(1, "extend sp in pp_chop"); + + map chomp(+()), ('')x68; + ok(1, "extend sp in pp_chomp"); +} + +{ + # [perl #73246] chop doesn't support utf8 + # the problem was UTF8_IS_START() didn't handle perl's extended UTF8 + my $utf = "\x{80000001}\x{80000000}"; + my $result = chop($utf); + is($utf, "\x{80000001}", "chopping high 'unicode'- remnant"); + is($result, "\x{80000000}", "chopping high 'unicode' - result"); + + SKIP: { + use Config; + $Config{ivsize} >= 8 + or skip("this build can't handle very large characters", 2); + my $utf = "\x{ffffffffffffffff}\x{fffffffffffffffe}"; + my $result = chop $utf; + is($utf, "\x{ffffffffffffffff}", "chop even higher 'unicode' - remnant"); + is($result, "\x{fffffffffffffffe}", "chop even higher 'unicode' - result"); + } +}