--- /dev/null
+package Test::Mouse;
+
+use Mouse::Exporter;
+use Mouse::Util qw(does_role find_meta);
+
+use Test::Builder;
+
+Mouse::Exporter->setup_import_methods(
+ as_is => [qw(
+ meta_ok
+ does_ok
+ has_attribute_ok
+ )],
+);
+
+## the test builder instance ...
+
+my $Test = Test::Builder->new;
+
+## exported functions
+
+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_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) = @_;
+
+ $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;
+__END__
+
+=head1 NAME
+
+Test::Mouse - Test functions for Mouse specific features
+
+=head1 SYNOPSIS
+
+ use Test::More plan => 1;
+ use Test::Mouse;
+
+ 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 Mouse based classes. It
+is an experimental first release, so comments and suggestions are very welcome.
+
+=head1 EXPORTED FUNCTIONS
+
+=over 4
+
+=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.
+
+=item B<has_attribute_ok($class_or_object, $attr_name, ?$message)>
+
+Tests if a class or object has a certain attribute, similar to what C<can_ok>
+does for the methods.
+
+=back
+
+=head1 SEE ALSO
+
+=over 4
+
+=item L<Test::More>
+
+=back
+
+=head1 SEE ALSO
+
+L<Mouse>
+
+L<Test::Moose>
+
+=cut
+
use warnings;
use Test::More tests => 21;
use Test::Exception;
+use Test::Mouse;
use lib 't/lib';
-use Test::Mouse;
+use MooseCompat;
do {
package Class;
use Test::Exception;
use Test::Mouse;
+use MooseCompat;
+
{
package My::Attribute::Trait;
use Mouse::Role;
use Test::More tests => 26;
use Test::Exception;
-use lib 't/lib';
-use Test::Mouse; # Mouse::Meta::Module->version
+use Test::Mouse;
use Mouse::Meta::Role;
+use lib 't/lib';
+use MooseCompat;
{
package FooRole;
use Test::Exception;
use lib 't/lib';
-use Test::Mouse; # Mouse::Meta::Module->version
+use Test::Mouse;
+
+use MooseCompat;
=pod
use lib 't/lib';
use Test::Mouse;
+use MooseCompat;
=pod
use Test::More tests => 277;
use Test::Exception;
-use Test::Mouse;
+use MooseCompat;
use Scalar::Util ();
use Test::Exception;
use lib 't/lib';
-use Test::Mouse;
+use MooseCompat;
BEGIN {
use_ok('Mouse::Util::TypeConstraints');
use lib 't/lib';
use Mouse::Util::TypeConstraints;
-use Test::Mouse; # for export_type_constraints_as_functions()
+use MooseCompat;
enum Letter => 'a'..'z', 'A'..'Z';
enum Language => 'Perl 5', 'Perl 6', 'PASM', 'PIR'; # any others? ;)
use Test::More tests => 15;
use Test::Exception;
-use lib 't/lib';
-use Test::Mouse; # Mouse::Meta::Module->version
+use Test::Mouse;
use Mouse::Meta::Role;
+use lib 't/lib';
+use MooseCompat;
{
package FooRole;
--- /dev/null
+package MooseCompat;
+# Moose compatible methods/functions
+
+package Mouse::Meta::Module;
+
+sub version { no strict 'refs'; ${shift->name.'::VERSION'} }
+sub authority { no strict 'refs'; ${shift->name.'::AUTHORITY'} }
+sub identifier {
+ my $self = shift;
+ return join '-' => (
+ $self->name,
+ ($self->version || ()),
+ ($self->authority || ()),
+ );
+}
+
+package Mouse::Meta::Role;
+
+for my $modifier_type (qw/before after around/) {
+ my $modifier = "${modifier_type}_method_modifiers";
+ my $has_method_modifiers = sub{
+ my($self, $method_name) = @_;
+ my $m = $self->{$modifier}->{$method_name};
+ return $m && @{$m} != 0;
+ };
+
+ no strict 'refs';
+ *{ 'has_' . $modifier_type . '_method_modifiers' } = $has_method_modifiers;
+}
+
+
+sub has_override_method_modifier {
+ my ($self, $method_name) = @_;
+ return exists $self->{override_method_modifiers}->{$method_name};
+}
+
+sub get_method_modifier_list {
+ my($self, $modifier_type) = @_;
+
+ return keys %{ $self->{$modifier_type . '_method_modifiers'} };
+}
+
+package Mouse::Util::TypeConstraints;
+
+use Mouse::Util::TypeConstraints ();
+
+sub export_type_constraints_as_functions { # TEST ONLY
+ my $into = caller;
+
+ foreach my $type( list_all_type_constraints() ) {
+ my $tc = find_type_constraint($type)->_compiled_type_constraint;
+ my $as = $into . '::' . $type;
+
+ no strict 'refs';
+ *{$as} = sub{ &{$tc} || undef };
+ }
+ return;
+}
+
+package
+ Mouse::Meta::Attribute;
+
+sub applied_traits{ $_[0]->{traits} } # TEST ONLY
+sub has_applied_traits{ exists $_[0]->{traits} } # TEST ONLY
+
+1;
+++ /dev/null
-package Test::Mouse;
-
-use strict;
-use warnings;
-use Carp qw(croak);
-use Mouse::Util qw(find_meta does_role);
-
-use base qw(Test::Builder::Module);
-
-our @EXPORT = qw(meta_ok does_ok has_attribute_ok);
-
-sub meta_ok ($;$) {
- my ($class_or_obj, $message) = @_;
-
- $message ||= "The object has a meta";
-
- if (find_meta($class_or_obj)) {
- return __PACKAGE__->builder->ok(1, $message)
- }
- else {
- return __PACKAGE__->builder->ok(0, $message);
- }
-}
-
-sub does_ok ($$;$) {
- my ($class_or_obj, $does, $message) = @_;
-
- if(!defined $does){
- croak "You must pass a role name";
- }
- $message ||= "The object does $does";
-
- if (does_role($class_or_obj, $does)) {
- return __PACKAGE__->builder->ok(1, $message)
- }
- else {
- return __PACKAGE__->builder->ok(0, $message);
- }
-}
-
-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 __PACKAGE__->builder->ok(1, $message)
- }
- else {
- return __PACKAGE__->builder->ok(0, $message);
- }
-}
-
-# Moose compatible methods/functions
-
-package
- Mouse::Meta::Module;
-
-sub version { no strict 'refs'; ${shift->name.'::VERSION'} }
-sub authority { no strict 'refs'; ${shift->name.'::AUTHORITY'} }
-sub identifier {
- my $self = shift;
- return join '-' => (
- $self->name,
- ($self->version || ()),
- ($self->authority || ()),
- );
-}
-
-package
- Mouse::Meta::Role;
-
-for my $modifier_type (qw/before after around/) {
- my $modifier = "${modifier_type}_method_modifiers";
- my $has_method_modifiers = sub{
- my($self, $method_name) = @_;
- my $m = $self->{$modifier}->{$method_name};
- return $m && @{$m} != 0;
- };
-
- no strict 'refs';
- *{ 'has_' . $modifier_type . '_method_modifiers' } = $has_method_modifiers;
-}
-
-
-sub has_override_method_modifier {
- my ($self, $method_name) = @_;
- return exists $self->{override_method_modifiers}->{$method_name};
-}
-
-sub get_method_modifier_list {
- my($self, $modifier_type) = @_;
-
- return keys %{ $self->{$modifier_type . '_method_modifiers'} };
-}
-
-package
- Mouse::Util::TypeConstraints;
-
-use Mouse::Util::TypeConstraints ();
-
-sub export_type_constraints_as_functions { # TEST ONLY
- my $into = caller;
-
- foreach my $type( list_all_type_constraints() ) {
- my $tc = find_type_constraint($type)->_compiled_type_constraint;
- my $as = $into . '::' . $type;
-
- no strict 'refs';
- *{$as} = sub{ &{$tc} || undef };
- }
- return;
-}
-
-package
- Mouse::Meta::Attribute;
-
-sub applied_traits{ $_[0]->{traits} } # TEST ONLY
-sub has_applied_traits{ exists $_[0]->{traits} } # TEST ONLY
-
-1;
-
-__END__
-
-=pod
-
-=head1 NAME
-
-Test::Mouse - Test functions for Mouse specific features
-
-=head1 SYNOPSIS
-
- use Test::More plan => 1;
- use Test::Mouse;
-
- 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");
-
-=cut
-