X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FTest%2FMoose.pm;h=216931f09422f9da1bbfb962c43c22341a6c5ab4;hb=efa728b4984ddf1611bc9931fbc209438459652c;hp=e9694e2d14b454177b8774d2c0a6cd7f89e01f49;hpb=adf823317010b616dfabab828adb8936de0065c3;p=gitmo%2FMoose.git diff --git a/lib/Test/Moose.pm b/lib/Test/Moose.pm index e9694e2..216931f 100644 --- a/lib/Test/Moose.pm +++ b/lib/Test/Moose.pm @@ -1,40 +1,85 @@ package Test::Moose; -use Exporter; -use Moose::Util qw/does_role/; -use Test::Builder; - use strict; use warnings; -our $VERSION = '0.01'; +use Sub::Exporter; +use Test::Builder; + +use List::MoreUtils 'all'; +use Moose::Util 'does_role', 'find_meta'; + +our $VERSION = '1.15'; +$VERSION = eval $VERSION; +our $AUTHORITY = 'cpan:STEVAN'; -our $AUTHORITY = 'cpan:BERLE'; +my @exports = qw[ + meta_ok + does_ok + has_attribute_ok + with_immutable +]; -our @EXPORT = qw/does_ok/; +Sub::Exporter::setup_exporter({ + exports => \@exports, + groups => { default => \@exports } +}); -my $tester = Test::Builder->new; +## the test builder instance ... -sub import { - my $class = shift; +my $Test = Test::Builder->new; - if (@_) { - my $package = caller; - - $tester->exported_to ($package); +## exported functions - $tester->plan (@_); - } +sub meta_ok ($;$) { + my ($class_or_obj, $message) = @_; - @_ = ($class); + $message ||= "The object has a meta"; - goto &Exporter::import; + 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); + } +} + +sub has_attribute_ok ($$;$) { + my ($class_or_obj, $attr_name, $message) = @_; - return $tester->ok (does_role ($class,$does),$name) + $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); + } +} + +sub with_immutable (&@) { + my $block = shift; + my $before = $Test->current_test; + $block->(); + Class::MOP::class_of($_)->make_immutable for @_; + $block->(); + my $num_tests = $Test->current_test - $before; + return all { $_ } ($Test->summary)[-$num_tests..-1]; } 1; @@ -49,20 +94,62 @@ 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"); + +=head1 DESCRIPTION + +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 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. + +=item B + +Tests if a class or object has a certain attribute, similar to what C +does for the methods. + +=item B + +Runs B (which should contain normal tests) twice, and make each +class in C<@class_names> immutable in between the two runs. - does_ok ($class,$role,"Does $class do $role"); +=back + +=head1 TODO + +=over 4 + +=item Convert the Moose test suite to use this module. -=head1 TESTS +=item Here is a list of possible functions to write =over 4 -=item does_ok +=item immutability predicates - does_ok ($class,$role,$name); +=item anon-class predicates -Tests if a class does a certain role, similar to what isa_ok does for -isa. +=item discovering original method from modified method + +=item attribute metaclass predicates (attribute_isa?) + +=back =back @@ -76,22 +163,22 @@ isa. =head1 BUGS -All complex software has bugs lurking in it, and this module is no -exception. If you find a bug please either email me, or add the bug -to cpan-RT. +See L for details on reporting bugs. =head1 AUTHOR 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 This library is free software; you can redistribute it and/or modify -it under the same terms as Perl itself. +it under the same terms as Perl itself. =cut