X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fdefaults.t;h=6e29950bd3a37791a2a1596b50faada4caabf0f8;hb=015b91679983f142397cd7172262a5e56f3cd850;hp=d599f200ed4737027bc8222fe877c72e0789cd76;hpb=8055a64173c89e5129f8ec136acf49d6facab65d;p=gitmo%2FMooseX-UndefTolerant.git diff --git a/t/defaults.t b/t/defaults.t index d599f20..6e29950 100644 --- a/t/defaults.t +++ b/t/defaults.t @@ -47,34 +47,19 @@ package main; sub do_tests { note 'Testing class with a single UndefTolerant attribute'; - { - my $obj = Foo->new; - ok($obj->has_attr1, 'attr1 has a value'); - ok($obj->has_attr2, 'attr2 has a value'); - is($obj->attr1, 1, 'attr1\'s value is its default'); - is($obj->attr2, 2, 'attr2\'s value is its default'); - } - - { - my $obj = Foo->new(attr1 => undef); - ok($obj->has_attr1, 'UT attr1 has a value when assigned undef in constructor'); - is($obj->attr1, 1, 'attr1\'s value is its default'); - is($obj->attr2, 2, 'attr2\'s value is its default'); - } - - { - my $obj = Foo->new(attr1 => 1234, attr2 => 5678); - is($obj->attr1, 1234, 'assigning a defined value during construction works as normal'); - ok($obj->has_attr1, '...and the predicate returns true as normal'); - is($obj->attr2, 5678, 'assigning a defined value during construction works as normal'); - ok($obj->has_attr2, '...and the predicate returns true as normal'); - } - + do_tests_with_class('Foo'); note ''; note 'Testing class with the entire class being UndefTolerant'; + do_tests_with_class('Bar'); +} + +sub do_tests_with_class +{ + my $class = shift; + { - my $obj = Bar->new; + my $obj = $class->new; ok($obj->has_attr1, 'attr1 has a value'); ok($obj->has_attr2, 'attr2 has a value'); is($obj->attr1, 1, 'attr1\'s value is its default'); @@ -82,14 +67,14 @@ sub do_tests } { - my $obj = Bar->new(attr1 => undef); + my $obj = $class->new(attr1 => undef); ok($obj->has_attr1, 'UT attr1 has a value when assigned undef in constructor'); is($obj->attr1, 1, 'attr1\'s value is its default'); is($obj->attr2, 2, 'attr2\'s value is its default'); } { - my $obj = Bar->new(attr1 => 1234, attr2 => 5678); + my $obj = $class->new(attr1 => 1234, attr2 => 5678); is($obj->attr1, 1234, 'assigning a defined value during construction works as normal'); ok($obj->has_attr1, '...and the predicate returns true as normal'); is($obj->attr2, 5678, 'assigning a defined value during construction works as normal'); @@ -110,7 +95,7 @@ Bar->meta->make_immutable; TODO: { local $TODO = 'some immutable cases are not handled yet'; # for now, catch errors - ok(! exception { do_tests }, 'tests do not die'); + is (exception { do_tests }, undef, 'tests do not die'); is(Test::More->builder->current_test, 44, 'if we got here, we can declare victory!'); }