bump version to 0.75_01
[gitmo/Moose.git] / lib / Test / Moose.pm
index 9808b3a..4489fb6 100644 (file)
@@ -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.75_01';
+$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<meta_ok ($class_or_object)>
+
+Tests if a class or object has a metaclass.
+
+=item B<does_ok ($class_or_object, $role, ?$message)>
+
+Tests if a class or object does a certain role, similar to what C<isa_ok> 
+does for the C<isa> method.
 
-  does_ok ($class,$role,$name);
+=item B<has_attribute_ok($class_or_object, $attr_name, ?$message)>
 
-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<can_ok> 
+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 E<lt>debolaz@gmail.comE<gt>
 
+Stevan Little E<lt>stevan@iinteractive.comE<gt>
+
 =head1 COPYRIGHT AND LICENSE
 
-Copyright 2007 by Infinity Interactive, Inc.
+Copyright 2007-2009 by Infinity Interactive, Inc.
 
 L<http://www.iinteractive.com>