X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FTest%2FMoose.pm;h=d2c2418e94fedc6feadb07f1767f16623b02867f;hb=4b2189ce8dae168787b635b71a918bd64461ed7a;hp=9808b3aa59ddc1aea1191e3ae58c6bdcce1361f6;hpb=dee94c90f23598899a96df13aba6cf706824f0e9;p=gitmo%2FMoose.git diff --git a/lib/Test/Moose.pm b/lib/Test/Moose.pm index 9808b3a..d2c2418 100644 --- a/lib/Test/Moose.pm +++ b/lib/Test/Moose.pm @@ -1,40 +1,73 @@ package Test::Moose; -use Exporter; -use Moose::Util qw/can_role/; -use Test::Builder; - use strict; use warnings; -our $VERSION = '0.01'; +use Sub::Exporter; +use Test::Builder; -our $AUTHORITY = 'cpan:BERLE'; +use Moose::Util 'does_role', 'find_meta'; -our @EXPORT = qw/does_ok/; +our $VERSION = '0.72'; +$VERSION = eval $VERSION; +our $AUTHORITY = 'cpan:STEVAN'; -my $tester = Test::Builder->new; +my @exports = qw[ + meta_ok + does_ok + has_attribute_ok +]; -sub import { - my $class = shift; +Sub::Exporter::setup_exporter({ + exports => \@exports, + groups => { default => \@exports } +}); - if (@_) { - my $package = caller; - - $tester->exported_to ($package); +## the test builder instance ... - $tester->plan (@_); - } +my $Test = Test::Builder->new; - @_ = ($class); +## exported functions - goto &Exporter::import; +sub meta_ok ($;$) { + my ($class_or_obj, $message) = @_; + + $message ||= "The object has a meta"; + + if (find_meta($class_or_obj)) { + return $Test->ok(1, $message) + } + else { + return $Test->ok(0, $message); + } } sub does_ok ($$;$) { - my ($class,$does,$name) = @_; + my ($class_or_obj, $does, $message) = @_; + + $message ||= "The object does $does"; + + if (does_role($class_or_obj, $does)) { + return $Test->ok(1, $message) + } + else { + return $Test->ok(0, $message); + } +} - return $tester->ok (can_role ($class,$does),$name) +sub has_attribute_ok ($$;$) { + my ($class_or_obj, $attr_name, $message) = @_; + + $message ||= "The object does has an attribute named $attr_name"; + + my $meta = find_meta($class_or_obj); + + if ($meta->find_attribute_by_name($attr_name)) { + return $Test->ok(1, $message) + } + else { + return $Test->ok(0, $message); + } } 1; @@ -49,20 +82,57 @@ Test::Moose - Test functions for Moose specific features =head1 SYNOPSIS - use Test::Moose plan => 1; + use Test::More plan => 1; + use Test::Moose; + + meta_ok($class_or_obj, "... Foo has a ->meta"); + does_ok($class_or_obj, $role, "... Foo does the Baz role"); + has_attribute_ok($class_or_obj, $attr_name, "... Foo has the 'bar' attribute"); - does_ok ($class,$role,"Does $class do $role"); +=head1 DESCRIPTION -=head1 TESTS +This module provides some useful test functions for Moose based classes. It +is an experimental first release, so comments and suggestions are very welcome. + +=head1 EXPORTED FUNCTIONS =over 4 -=item does_ok +=item B + +Tests if a class or object has a metaclass. + +=item B + +Tests if a class or object does a certain role, similar to what C +does for the C method. - does_ok ($class,$role,$name); +=item B -Tests if a class does a certain role, similar to what isa_ok does for -isa. +Tests if a class or object has a certain attribute, similar to what C +does for the methods. + +=back + +=head1 TODO + +=over 4 + +=item Convert the Moose test suite to use this module. + +=item Here is a list of possible functions to write + +=over 4 + +=item immutability predicates + +=item anon-class predicates + +=item discovering original method from modified method + +=item attribute metaclass predicates (attribute_isa?) + +=back =back @@ -84,9 +154,11 @@ to cpan-RT. Anders Nor Berle Edebolaz@gmail.comE +Stevan Little Estevan@iinteractive.comE + =head1 COPYRIGHT AND LICENSE -Copyright 2007 by Infinity Interactive, Inc. +Copyright 2007-2009 by Infinity Interactive, Inc. L