#!./perl
BEGIN {
chdir 't' if -d 't';
@INC = '../lib';
}
print "1..36\n";
print defined($a) ? "not ok 1\n" : "ok 1\n";
$a = 1+1;
print defined($a) ? "ok 2\n" : "not ok 2\n";
undef $a;
print defined($a) ? "not ok 3\n" : "ok 3\n";
$a = "hi";
print defined($a) ? "ok 4\n" : "not ok 4\n";
$a = $b;
print defined($a) ? "not ok 5\n" : "ok 5\n";
@ary = ("1arg");
$a = pop(@ary);
print defined($a) ? "ok 6\n" : "not ok 6\n";
$a = pop(@ary);
print defined($a) ? "not ok 7\n" : "ok 7\n";
@ary = ("1arg");
$a = shift(@ary);
print defined($a) ? "ok 8\n" : "not ok 8\n";
$a = shift(@ary);
print defined($a) ? "not ok 9\n" : "ok 9\n";
$ary{'foo'} = 'hi';
print defined($ary{'foo'}) ? "ok 10\n" : "not ok 10\n";
print defined($ary{'bar'}) ? "not ok 11\n" : "ok 11\n";
undef $ary{'foo'};
print defined($ary{'foo'}) ? "not ok 12\n" : "ok 12\n";
print defined(@ary) ? "ok 13\n" : "not ok 13\n";
print defined(%ary) ? "ok 14\n" : "not ok 14\n";
undef @ary;
print defined(@ary) ? "not ok 15\n" : "ok 15\n";
undef %ary;
print defined(%ary) ? "not ok 16\n" : "ok 16\n";
@ary = (1);
print defined @ary ? "ok 17\n" : "not ok 17\n";
%ary = (1,1);
print defined %ary ? "ok 18\n" : "not ok 18\n";
sub foo { print "ok 19\n"; }
&foo || print "not ok 19\n";
print defined &foo ? "ok 20\n" : "not ok 20\n";
undef &foo;
print defined(&foo) ? "not ok 21\n" : "ok 21\n";
eval { undef $1 };
print $@ =~ /^Modification of a read/ ? "ok 22\n" : "not ok 22\n";
eval { $1 = undef };
print $@ =~ /^Modification of a read/ ? "ok 23\n" : "not ok 23\n";
{
require Tie::Hash;
tie my %foo, 'Tie::StdHash';
print defined %foo ? "ok 24\n" : "not ok 24\n";
%foo = ( a => 1 );
print defined %foo ? "ok 25\n" : "not ok 25\n";
}
{
require Tie::Array;
tie my @foo, 'Tie::StdArray';
print defined @foo ? "ok 26\n" : "not ok 26\n";
@foo = ( a => 1 );
print defined @foo ? "ok 27\n" : "not ok 27\n";
}
{
# [perl #17753] segfault when undef'ing unquoted string constant
eval 'undef tcp';
print $@ =~ /^Can't modify constant item/ ? "ok 28\n" : "not ok 28\n";
}
# bugid 3096
# undefing a hash may free objects with destructors that then try to
# modify the hash. To them, the hash should appear empty.
$test = 29;
%hash = (
key1 => bless({}, 'X'),
key2 => bless({}, 'X'),
);
undef %hash;
sub X::DESTROY {
print "not " if keys %hash; print "ok $test\n"; $test++;
print "not " if values %hash; print "ok $test\n"; $test++;
print "not " if each %hash; print "ok $test\n"; $test++;
print "not " if defined delete $hash{'key2'}; print "ok $test\n"; $test++;
}