diff options
author | chromatic <chromatic@wgz.org> | 2006-05-30 10:41:08 -0700 |
---|---|---|
committer | Rafael Garcia-Suarez <rgarciasuarez@gmail.com> | 2006-06-12 16:41:44 +0000 |
commit | cbc021f9c76c5db718d993d3cc885284fbbff80f (patch) | |
tree | a6fb93ddedbd052fb5a34890efe9474db6559a9a /t/op/universal.t | |
parent | e77388947cb2bf6620678b8c9693537e8c7df7e6 (diff) | |
download | perl-cbc021f9c76c5db718d993d3cc885284fbbff80f.tar.gz |
Add the new method UNIVERSAL::DOES() and the API function sv_does()
Subject: Re: [PROPOSED PATCH: universal.c, t/op/universal.t] Add does()
Message-Id: <200605301741.08363.chromatic@wgz.org>
p4raw-id: //depot/perl@28387
Diffstat (limited to 't/op/universal.t')
-rwxr-xr-x | t/op/universal.t | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/t/op/universal.t b/t/op/universal.t index 18501279b0..e37bfc724d 100755 --- a/t/op/universal.t +++ b/t/op/universal.t @@ -10,7 +10,7 @@ BEGIN { require "./test.pl"; } -plan tests => 104; +plan tests => 109; $a = {}; bless $a, "Bob"; @@ -123,9 +123,9 @@ my $subs = join ' ', sort grep { defined &{"UNIVERSAL::$_"} } keys %UNIVERSAL::; ## The test for import here is *not* because we want to ensure that UNIVERSAL ## can always import; it is an historical accident that UNIVERSAL can import. if ('a' lt 'A') { - is $subs, "can import isa VERSION"; + is $subs, "can does import isa VERSION"; } else { - is $subs, "VERSION can import isa"; + is $subs, "VERSION can does import isa"; } ok $a->isa("UNIVERSAL"); @@ -146,9 +146,9 @@ ok $a->isa("UNIVERSAL"); my $sub2 = join ' ', sort grep { defined &{"UNIVERSAL::$_"} } keys %UNIVERSAL::; # XXX import being here is really a bug if ('a' lt 'A') { - is $sub2, "can import isa VERSION"; + is $sub2, "can does import isa VERSION"; } else { - is $sub2, "VERSION can import isa"; + is $sub2, "VERSION can does import isa"; } eval 'sub UNIVERSAL::sleep {}'; @@ -200,3 +200,19 @@ is $@, ''; # This segfaulted in a blead. fresh_perl_is('package Foo; Foo->VERSION; print "ok"', 'ok'); +package Foo; + +sub does { 1 } + +package Bar; + +@Bar::ISA = 'Foo'; + +package Baz; + +package main; +ok( Foo->does( 'bar' ), 'does() should call does() on class' ); +ok( Bar->does( 'Bar' ), '... and should fall back to isa()' ); +ok( Bar->does( 'Foo' ), '... even when inherited' ); +ok( Baz->does( 'Baz' ), '... even without inheriting any other does()' ); +ok( ! Baz->does( 'Foo' ), '... returning true or false appropriately' ); |