summaryrefslogtreecommitdiff
path: root/t/op
diff options
context:
space:
mode:
Diffstat (limited to 't/op')
-rwxr-xr-xt/op/delete.t91
1 files changed, 45 insertions, 46 deletions
diff --git a/t/op/delete.t b/t/op/delete.t
index ac4405c419..493717e768 100755
--- a/t/op/delete.t
+++ b/t/op/delete.t
@@ -1,6 +1,12 @@
#!./perl
-print "1..38\n";
+BEGIN {
+ chdir 't' if -d 't';
+ @INC = qw(. ../lib);
+}
+
+require "test.pl";
+plan( tests => 38 );
# delete() on hash elements
@@ -12,25 +18,25 @@ $foo{5} = 'e';
$foo = delete $foo{2};
-if ($foo eq 'b') {print "ok 1\n";} else {print "not ok 1 $foo\n";}
-unless (exists $foo{2}) {print "ok 2\n";} else {print "not ok 2 $foo{2}\n";}
-if ($foo{1} eq 'a') {print "ok 3\n";} else {print "not ok 3\n";}
-if ($foo{3} eq 'c') {print "ok 4\n";} else {print "not ok 4\n";}
-if ($foo{4} eq 'd') {print "ok 5\n";} else {print "not ok 5\n";}
-if ($foo{5} eq 'e') {print "ok 6\n";} else {print "not ok 6\n";}
+cmp_ok($foo,'eq','b','delete 2');
+ok(!(exists $foo{2}),'b absent');
+cmp_ok($foo{1},'eq','a','a exists');
+cmp_ok($foo{3},'eq','c','c exists');
+cmp_ok($foo{4},'eq','d','d exists');
+cmp_ok($foo{5},'eq','e','e exists');
@foo = delete @foo{4, 5};
-if (@foo == 2) {print "ok 7\n";} else {print "not ok 7 ", @foo+0, "\n";}
-if ($foo[0] eq 'd') {print "ok 8\n";} else {print "not ok 8 ", $foo[0], "\n";}
-if ($foo[1] eq 'e') {print "ok 9\n";} else {print "not ok 9 ", $foo[1], "\n";}
-unless (exists $foo{4}) {print "ok 10\n";} else {print "not ok 10 $foo{4}\n";}
-unless (exists $foo{5}) {print "ok 11\n";} else {print "not ok 11 $foo{5}\n";}
-if ($foo{1} eq 'a') {print "ok 12\n";} else {print "not ok 12\n";}
-if ($foo{3} eq 'c') {print "ok 13\n";} else {print "not ok 13\n";}
+cmp_ok(scalar(@foo),'==',2,'deleted slice');
+cmp_ok($foo[0],'eq','d','slice 1');
+cmp_ok($foo[1],'eq','e','slice 2');
+ok(!(exists $foo{4}),'d absent');
+ok(!(exists $foo{5}),'e absent');
+cmp_ok($foo{1},'eq','a','a still exists');
+cmp_ok($foo{3},'eq','c','c still exists');
$foo = join('',values(%foo));
-if ($foo eq 'ac' || $foo eq 'ca') {print "ok 14\n";} else {print "not ok 14\n";}
+ok($foo eq 'ac' || $foo eq 'ca','remaining keys');
foreach $key (keys %foo) {
delete $foo{$key};
@@ -40,7 +46,7 @@ $foo{'foo'} = 'x';
$foo{'bar'} = 'y';
$foo = join('',values(%foo));
-print +($foo eq 'xy' || $foo eq 'yx') ? "ok 15\n" : "not ok 15\n";
+ok($foo eq 'xy' || $foo eq 'yx','fresh keys');
$refhash{"top"}->{"foo"} = "FOO";
$refhash{"top"}->{"bar"} = "BAR";
@@ -48,7 +54,7 @@ $refhash{"top"}->{"bar"} = "BAR";
delete $refhash{"top"}->{"bar"};
@list = keys %{$refhash{"top"}};
-print "@list" eq "foo" ? "ok 16\n" : "not ok 16 @list\n";
+cmp_ok("@list",'eq',"foo", 'autoviv and delete hashref');
{
my %a = ('bar', 33);
@@ -56,8 +62,7 @@ print "@list" eq "foo" ? "ok 16\n" : "not ok 16 @list\n";
my $b = \$a{bar};
my $c = \delete $a{bar};
- print "not " unless $a == $b && $b == $c;
- print "ok 17\n";
+ ok($a == $b && $b == $c,'a b c equivalent');
}
# delete() on array elements
@@ -71,46 +76,45 @@ $foo[5] = 'e';
$foo = delete $foo[2];
-if ($foo eq 'b') {print "ok 18\n";} else {print "not ok 18 $foo\n";}
-unless (exists $foo[2]) {print "ok 19\n";} else {print "not ok 19 $foo[2]\n";}
-if ($foo[1] eq 'a') {print "ok 20\n";} else {print "not ok 20\n";}
-if ($foo[3] eq 'c') {print "ok 21\n";} else {print "not ok 21\n";}
-if ($foo[4] eq 'd') {print "ok 22\n";} else {print "not ok 22\n";}
-if ($foo[5] eq 'e') {print "ok 23\n";} else {print "not ok 23\n";}
+cmp_ok($foo,'eq','b','ary delete 2');
+ok(!(exists $foo[2]),'ary b absent');
+cmp_ok($foo[1],'eq','a','ary a exists');
+cmp_ok($foo[3],'eq','c','ary c exists');
+cmp_ok($foo[4],'eq','d','ary d exists');
+cmp_ok($foo[5],'eq','e','ary e exists');
@bar = delete @foo[4,5];
-if (@bar == 2) {print "ok 24\n";} else {print "not ok 24 ", @bar+0, "\n";}
-if ($bar[0] eq 'd') {print "ok 25\n";} else {print "not ok 25 ", $bar[0], "\n";}
-if ($bar[1] eq 'e') {print "ok 26\n";} else {print "not ok 26 ", $bar[1], "\n";}
-unless (exists $foo[4]) {print "ok 27\n";} else {print "not ok 27 $foo[4]\n";}
-unless (exists $foo[5]) {print "ok 28\n";} else {print "not ok 28 $foo[5]\n";}
-if ($foo[1] eq 'a') {print "ok 29\n";} else {print "not ok 29\n";}
-if ($foo[3] eq 'c') {print "ok 30\n";} else {print "not ok 30\n";}
+cmp_ok(scalar(@bar),'==',2,'ary deleted slice');
+cmp_ok($bar[0],'eq','d','ary slice 1');
+cmp_ok($bar[1],'eq','e','ary slice 2');
+ok(!(exists $foo[4]),'ary d absent');
+ok(!(exists $foo[5]),'ary e absent');
+cmp_ok($foo[1],'eq','a','ary a still exists');
+cmp_ok($foo[3],'eq','c','ary c still exists');
$foo = join('',@foo);
-if ($foo eq 'ac') {print "ok 31\n";} else {print "not ok 31\n";}
-
-if (@foo == 4) {print "ok 32\n";} else {print "not ok 32\n";}
+cmp_ok($foo,'eq','ac','ary elems');
+cmp_ok(scalar(@foo),'==',4,'four is the number thou shalt count');
foreach $key (0 .. $#foo) {
delete $foo[$key];
}
-if (@foo == 0) {print "ok 33\n";} else {print "not ok 33\n";}
+cmp_ok(scalar(@foo),'==',0,'and then there were none');
$foo[0] = 'x';
$foo[1] = 'y';
$foo = "@foo";
-print +($foo eq 'x y') ? "ok 34\n" : "not ok 34\n";
+cmp_ok($foo,'eq','x y','two fresh');
$refary[0]->[0] = "FOO";
$refary[0]->[3] = "BAR";
delete $refary[0]->[3];
-print @{$refary[0]} == 1 ? "ok 35\n" : "not ok 35 @list\n";
+cmp_ok( scalar(@{$refary[0]}),'==',1,'one down');
{
my @a = 33;
@@ -118,20 +122,16 @@ print @{$refary[0]} == 1 ? "ok 35\n" : "not ok 35 @list\n";
my $b = \$a[0];
my $c = \delete $a[bar];
- print "not " unless $a == $b && $b == $c;
- print "ok 36\n";
+ ok($a == $b && $b == $c,'a b c also equivalent');
}
{
- # [perl #29127] scalar delete of empty slice returned garbage
my %h;
my ($x,$y) = (1, scalar delete @h{()});
- print "not " if defined $y;
- print "ok 37\n";
+ ok(!defined($y),q([perl #29127] scalar delete of empty slice returned garbage));
}
{
- # [perl #30733] array delete didn't free returned element
my $x = 0;
sub X::DESTROY { $x++ }
{
@@ -139,6 +139,5 @@ print @{$refary[0]} == 1 ? "ok 35\n" : "not ok 35 @list\n";
$a[0] = bless [], 'X';
my $y = delete $a[0];
}
- print "not " unless $x == 1;
- print "ok 38\n";
+ cmp_ok($x,'==',1,q([perl #30733] array delete didn't free returned element));
}