remove trailing whitespace
[gitmo/Moose.git] / t / 040_type_constraints / 008_union_types.t
CommitLineData
451c8248 1#!/usr/bin/perl
2
3use strict;
4use warnings;
5
4c015454 6use Test::More tests => 35;
451c8248 7use Test::Exception;
8
9BEGIN {
d03bd989 10 use_ok('Moose::Util::TypeConstraints');
451c8248 11}
12
13my $Str = find_type_constraint('Str');
14isa_ok($Str, 'Moose::Meta::TypeConstraint');
15
16my $Undef = find_type_constraint('Undef');
17isa_ok($Undef, 'Moose::Meta::TypeConstraint');
18
19ok(!$Str->check(undef), '... Str cannot accept an Undef value');
20ok($Str->check('String'), '... Str can accept an String value');
21ok(!$Undef->check('String'), '... Undef cannot accept an Str value');
22ok($Undef->check(undef), '... Undef can accept an Undef value');
23
3726f905 24my $Str_or_Undef = Moose::Meta::TypeConstraint::Union->new(type_constraints => [$Str, $Undef]);
451c8248 25isa_ok($Str_or_Undef, 'Moose::Meta::TypeConstraint::Union');
26
27ok($Str_or_Undef->check(undef), '... (Str | Undef) can accept an Undef value');
28ok($Str_or_Undef->check('String'), '... (Str | Undef) can accept a String value');
29
dabed765 30ok($Str_or_Undef->is_a_type_of($Str), "subtype of Str");
31ok($Str_or_Undef->is_a_type_of($Undef), "subtype of Undef");
32
33ok( !$Str_or_Undef->equals($Str), "not equal to Str" );
34ok( $Str_or_Undef->equals($Str_or_Undef), "equal to self" );
35ok( $Str_or_Undef->equals(Moose::Meta::TypeConstraint::Union->new(type_constraints => [ $Str, $Undef ])), "equal to clone" );
36ok( $Str_or_Undef->equals(Moose::Meta::TypeConstraint::Union->new(type_constraints => [ $Undef, $Str ])), "equal to reversed clone" );
37
4c015454 38ok( !$Str_or_Undef->is_a_type_of("ThisTypeDoesNotExist"), "not type of non existant type" );
39ok( !$Str_or_Undef->is_subtype_of("ThisTypeDoesNotExist"), "not subtype of non existant type" );
40
451c8248 41# another ....
42
43my $ArrayRef = find_type_constraint('ArrayRef');
44isa_ok($ArrayRef, 'Moose::Meta::TypeConstraint');
45
46my $HashRef = find_type_constraint('HashRef');
47isa_ok($HashRef, 'Moose::Meta::TypeConstraint');
48
49ok($ArrayRef->check([]), '... ArrayRef can accept an [] value');
50ok(!$ArrayRef->check({}), '... ArrayRef cannot accept an {} value');
51ok($HashRef->check({}), '... HashRef can accept an {} value');
52ok(!$HashRef->check([]), '... HashRef cannot accept an [] value');
53
3726f905 54my $HashOrArray = Moose::Meta::TypeConstraint::Union->new(type_constraints => [$ArrayRef, $HashRef]);
451c8248 55isa_ok($HashOrArray, 'Moose::Meta::TypeConstraint::Union');
56
57ok($HashOrArray->check([]), '... (ArrayRef | HashRef) can accept []');
58ok($HashOrArray->check({}), '... (ArrayRef | HashRef) can accept {}');
59
60ok(!$HashOrArray->check(\(my $var1)), '... (ArrayRef | HashRef) cannot accept scalar refs');
61ok(!$HashOrArray->check(sub {}), '... (ArrayRef | HashRef) cannot accept code refs');
62ok(!$HashOrArray->check(50), '... (ArrayRef | HashRef) cannot accept Numbers');
63
64diag $HashOrArray->validate([]);
65
66ok(!defined($HashOrArray->validate([])), '... (ArrayRef | HashRef) can accept []');
67ok(!defined($HashOrArray->validate({})), '... (ArrayRef | HashRef) can accept {}');
68
d03bd989 69like($HashOrArray->validate(\(my $var2)),
70qr/Validation failed for \'ArrayRef\' failed with value SCALAR\(0x.+?\) and Validation failed for \'HashRef\' failed with value SCALAR\(0x.+?\) in \(ArrayRef\|HashRef\)/,
688fcdda 71'... (ArrayRef | HashRef) cannot accept scalar refs');
72
d03bd989 73like($HashOrArray->validate(sub {}),
74qr/Validation failed for \'ArrayRef\' failed with value CODE\(0x.+?\) and Validation failed for \'HashRef\' failed with value CODE\(0x.+?\) in \(ArrayRef\|HashRef\)/,
688fcdda 75'... (ArrayRef | HashRef) cannot accept code refs');
76
77is($HashOrArray->validate(50),
d03bd989 78'Validation failed for \'ArrayRef\' failed with value 50 and Validation failed for \'HashRef\' failed with value 50 in (ArrayRef|HashRef)',
688fcdda 79'... (ArrayRef | HashRef) cannot accept Numbers');
451c8248 80