Revision history for MooseX-AlwaysCoerce
+0.09 2010-08-05 03:42:07
+ - support attributes without isa, correctly
+
0.08 2010-08-05 03:14:37
- make a test safer
=head1 VERSION
-Version 0.08
+Version 0.09
=cut
-our $VERSION = '0.08';
+our $VERSION = '0.09';
=head1 SYNOPSIS
return $current_val if defined $current_val;
- return 1 if $self->type_constraint->has_coercion;
+ return 1 if $self->type_constraint && $self->type_constraint->has_coercion;
return 0;
};
my $self = shift;
my ($what, %opts) = @_;
- return unless exists $opts{isa};
-
- my $type = Moose::Util::TypeConstraints::find_or_parse_type_constraint($opts{isa});
- $opts{coerce} = 1 if not exists $opts{coerce} and $type->has_coercion;
+ if (exists $opts{isa}) {
+ my $type = Moose::Util::TypeConstraints::find_or_parse_type_constraint($opts{isa});
+ $opts{coerce} = 1 if not exists $opts{coerce} and $type->has_coercion;
+ }
$self->$next($what, %opts);
};
=cut
1; # End of MooseX::AlwaysCoerce
+# vim:et sts=4 sw=4 tw=0:
use strict;
use warnings;
-use Test::More tests => 8;
+use Test::More tests => 10;
use Test::Exception;
use Test::NoWarnings;
class_has uncoerced_class_attr => (is => 'rw', isa => 'Uncoerced');
+ has untyped_attr => (is => 'rw');
+
class_has untyped_class_attr => (is => 'rw');
}
ok( (my $instance = MyClass->new), 'instance' );
-lives_ok { $instance->foo('bar') } 'attribute coercion ran';
+lives_and {
+ $instance->foo('bar');
+ is $instance->foo, 3;
+} 'attribute coercion ran';
-lives_ok { $instance->bar('baz') } 'class attribute coercion ran';
+lives_and {
+ $instance->bar('baz');
+ is $instance->bar, 3;
+} 'class attribute coercion ran';
dies_ok { $instance->baz('quux') }
'class attribute coercion did not run with coerce => 0';
dies_ok { $instance->quux('mtfnpy') }
'attribute coercion did not run with coerce => 0';
-lives_ok { $instance->uncoerced_attr(10) }
- 'set attribute having type with no coercion and no coerce=0';
-
-lives_ok { $instance->uncoerced_class_attr(10) }
- 'set class attribute having type with no coercion and no coerce=0';
+lives_and {
+ $instance->uncoerced_attr(10);
+ is $instance->uncoerced_attr(10), 10;
+} 'set attribute having type with no coercion and no coerce=0';
+
+lives_and {
+ $instance->uncoerced_class_attr(10);
+ is $instance->uncoerced_class_attr(10), 10;
+} 'set class attribute having type with no coercion and no coerce=0';
+
+lives_and {
+ $instance->untyped_attr(10);
+ is $instance->untyped_attr, 10;
+} 'set untyped attribute';
+
+lives_and {
+ $instance->untyped_class_attr(10);
+ is $instance->untyped_class_attr, 10;
+} 'set untyped class attribute';
use strict;
use warnings;
-use Test::More tests => 8;
+use Test::More tests => 10;
use Test::Exception;
use Test::NoWarnings;
has uncoerced_attr => (is => 'rw', isa => 'Uncoerced');
class_has uncoerced_class_attr => (is => 'rw', isa => 'Uncoerced');
+
+ has untyped_attr => (is => 'rw');
+
+ class_has untyped_class_attr => (is => 'rw');
}
{
{
local $TODO = 'waiting on Moose changes for role support';
- lives_ok { $instance->foo('bar') } 'attribute coercion ran';
+ lives_and {
+ $instance->foo('bar');
+ is $instance->foo, 3;
+ } 'attribute coercion ran';
}
-lives_ok { $instance->bar('baz') } 'class attribute coercion ran';
+lives_and {
+ $instance->bar('baz');
+ is $instance->bar, 3;
+} 'class attribute coercion ran';
dies_ok { $instance->baz('quux') }
'class attribute coercion did not run with coerce => 0';
dies_ok { $instance->quux('mtfnpy') }
'attribute coercion did not run with coerce => 0';
-lives_ok { $instance->uncoerced_attr(10) }
- 'set attribute having type with no coercion and no coerce=0';
-
-lives_ok { $instance->uncoerced_class_attr(10) }
- 'set class attribute having type with no coercion and no coerce=0';
-
+lives_and {
+ $instance->uncoerced_attr(10);
+ is $instance->uncoerced_attr(10), 10;
+} 'set attribute having type with no coercion and no coerce=0';
+
+lives_and {
+ $instance->uncoerced_class_attr(10);
+ is $instance->uncoerced_class_attr(10), 10;
+} 'set class attribute having type with no coercion and no coerce=0';
+
+lives_and {
+ $instance->untyped_attr(10);
+ is $instance->untyped_attr, 10;
+} 'set untyped attribute';
+
+lives_and {
+ $instance->untyped_class_attr(10);
+ is $instance->untyped_class_attr, 10;
+} 'set untyped class attribute';
class_has uncoerced_class_attr => (is => 'rw', isa => 'Uncoerced');
+ has untyped_attr => (is => 'rw');
+
+ class_has untyped_class_attr => (is => 'rw');
+
package Foo;
use Moose;
with 'Role';
'MooseX::ClassAttribute is currently incompatible with MooseX::Role::Parameterized';
}
-plan tests => 8;
+plan tests => 10;
eval 'use Test::NoWarnings';
{
local $TODO = 'waiting on Moose changes for role support, and ClassAttribute changes for paramterized role support';
- lives_ok { $instance->foo('bar') } 'attribute coercion ran';
+ lives_and {
+ $instance->foo('bar');
+ is $instance->foo, 3;
+ } 'attribute coercion ran';
}
-lives_ok { $instance->bar('baz') } 'class attribute coercion ran';
+lives_and {
+ $instance->bar('baz');
+ is $instance->bar, 3;
+} 'class attribute coercion ran';
dies_ok { $instance->baz('quux') }
'class attribute coercion did not run with coerce => 0';
dies_ok { $instance->quux('mtfnpy') }
'attribute coercion did not run with coerce => 0';
-lives_ok { $instance->uncoerced_attr(10) }
- 'set attribute having type with no coercion and no coerce=0';
-
-lives_ok { $instance->uncoerced_class_attr(10) }
- 'set class attribute having type with no coercion and no coerce=0';
+lives_and {
+ $instance->uncoerced_attr(10);
+ is $instance->uncoerced_attr(10), 10;
+} 'set attribute having type with no coercion and no coerce=0';
+
+lives_and {
+ $instance->uncoerced_class_attr(10);
+ is $instance->uncoerced_class_attr(10), 10;
+} 'set class attribute having type with no coercion and no coerce=0';
+
+lives_and {
+ $instance->untyped_attr(10);
+ is $instance->untyped_attr, 10;
+} 'set untyped attribute';
+
+lives_and {
+ $instance->untyped_class_attr(10);
+ is $instance->untyped_class_attr, 10;
+} 'set untyped class attribute';