rollback some stuff to reset my brain a bit
[gitmo/MooseX-Types-Structured.git] / t / 01-basic.t
index 45e7351..a4c3f74 100755 (executable)
 BEGIN {
        use strict;
        use warnings;
-       use Test::More tests=>10;
+       use Test::More tests=>37;
        use Test::Exception;
        
        use_ok 'Moose::Util::TypeConstraints';
-       use_ok 'MooseX::Meta::TypeConstraint::Structured::Structurable';
+       use_ok 'MooseX::Meta::TypeConstraint::Structured::Generator';
        use_ok 'MooseX::Meta::TypeConstraint::Structured::Positional';
+       use_ok 'MooseX::Meta::TypeConstraint::Structured::Optional';    
        use_ok 'MooseX::Meta::TypeConstraint::Structured::Named';
 }
 
-my $tuple = MooseX::Meta::TypeConstraint::Structured::Structurable->new(
+my $optional = MooseX::Meta::TypeConstraint::Structured::Generator->new(
+               name => 'Optional',
+               structured_type => 'MooseX::Meta::TypeConstraint::Structured::Optional',
+               package_defined_in => __PACKAGE__,
+               parent => find_type_constraint('ArrayRef'),
+       );
+
+my $tuple = MooseX::Meta::TypeConstraint::Structured::Generator->new(
                name => 'Tuple',
                structured_type => 'MooseX::Meta::TypeConstraint::Structured::Positional',
                package_defined_in => __PACKAGE__,
                parent => find_type_constraint('ArrayRef'),
        );
+       
+my $dict = MooseX::Meta::TypeConstraint::Structured::Generator->new(
+               name => 'Dict',
+               structured_type => 'MooseX::Meta::TypeConstraint::Structured::Named',
+               package_defined_in => __PACKAGE__,
+               parent => find_type_constraint('HashRef'),
+       );
 
+Moose::Util::TypeConstraints::register_type_constraint($optional);
 Moose::Util::TypeConstraints::register_type_constraint($tuple);
+Moose::Util::TypeConstraints::register_type_constraint($dict);
 
 ## Make sure the new type constraints have been registered
 
 ok Moose::Util::TypeConstraints::find_type_constraint('Tuple')
  => 'Found the Tuple Type';
+ok Moose::Util::TypeConstraints::find_type_constraint('Dict')
+ => 'Found the Tuple Type';
+ok Moose::Util::TypeConstraints::find_type_constraint('Optional')
+ => 'Found the Tuple Type';
 
 {
-       package Test::MooseX::Types::Structured::Positionable;
+       package Test::MooseX::Types::Structured::BasicAttributes;
        
        use Moose;
        use Moose::Util::TypeConstraints;
        
        has 'tuple' => (is=>'rw', isa=>'Tuple[Int,Str,Int]');
+       has 'tuple_with_parameterized' => (is=>'rw', isa=>'Tuple[Int,Str,Int,ArrayRef[Int]]');
+       has 'tuple_with_optional' => (is=>'rw', isa=>'Tuple[Int,Str,Int,Optional[Int,Int]]');
+       has 'tuple_with_union' => (is=>'rw', isa=>'Tuple[Int,Str,Int|Object,Optional[Int|Object,Int]]');
+       
+       has 'dict' => (is=>'rw', isa=>'Dict[name=>Str,age=>Int]');
+       has 'dict_with_parameterized' => (is=>'rw', isa=>'Dict[name=>Str, age=>Int, telephone=>ArrayRef[Int]]');
+       has 'dict_with_optional' => (is=>'rw', isa=>'Dict[name=>Str, age=>Int, Optional[opt1=>Str,opt2=>Object]]');
+
 }
 
 
-ok my $positioned_obj = Test::MooseX::Types::Structured::Positionable->new,
+ok my $obj = Test::MooseX::Types::Structured::BasicAttributes->new,
  => 'Got a good object';
 
-ok $positioned_obj->tuple([1,'hello',3])
+ok Moose::Util::TypeConstraints::find_type_constraint('Tuple[Int,Str,Int]')
+ => 'Found expected type constraint';
+
+ok Moose::Util::TypeConstraints::find_type_constraint('Tuple[Int,Str,Int,Optional[Int,Int]]')
+ => 'Found expected type constraint';
+## dict Dict[name=>Str, Age=>Int]
+
+ok $obj->dict({name=>'John', age=>39})
+ => 'Dict[name=>Str, Age=>Int] properly succeeds';
+## Test tuple (Tuple[Int,Str,Int])
+
+ok $obj->tuple([1,'hello',3])
  => "[1,'hello',3] properly suceeds";
 
 throws_ok sub {
-       $positioned_obj->tuple([1,2,'world']);
+       $obj->tuple([1,2,'world']);
 }, qr/Validation failed for 'Int' failed with value world/ => "[1,2,'world'] properly fails";
 
 throws_ok sub {
-       $positioned_obj->tuple(['hello1',2,3]);
+       $obj->tuple(['hello1',2,3]);
 }, qr/Validation failed for 'Int' failed with value hello1/ => "['hello',2,3] properly fails";
 
 throws_ok sub {
-       $positioned_obj->tuple(['hello2',2,'world']);
+       $obj->tuple(['hello2',2,'world']);
 }, qr/Validation failed for 'Int' failed with value hello2/ => "['hello',2,'world'] properly fails";
 
 
+## Test tuple_with_parameterized (Tuple[Int,Str,Int,ArrayRef[Int]])
 
+ok $obj->tuple_with_parameterized([1,'hello',3,[1,2,3]])
+ => "[1,'hello',3,[1,2,3]] properly suceeds";
+
+throws_ok sub {
+       $obj->tuple_with_parameterized([1,2,'world']);
+}, qr/Validation failed for 'Int' failed with value world/ => "[1,2,'world'] properly fails";
+
+throws_ok sub {
+       $obj->tuple_with_parameterized(['hello1',2,3]);
+}, qr/Validation failed for 'Int' failed with value hello1/ => "['hello',2,3] properly fails";
+
+throws_ok sub {
+       $obj->tuple_with_parameterized(['hello2',2,'world']);
+}, qr/Validation failed for 'Int' failed with value hello2/ => "['hello',2,'world'] properly fails";
+
+throws_ok sub {
+       $obj->tuple_with_parameterized([1,'hello',3,[1,2,'world']]);
+}, qr/Validation failed for 'ArrayRef\[Int\]'/ => "[1,'hello',3,[1,2,'world']] properly fails";
+
+
+## Test tuple_with_optional (Tuple[Int,Str,Int,Optional[Int,Int]])
+
+ok $obj->tuple_with_optional([1,'hello',3])
+ => "[1,'hello',3] properly suceeds";
+
+ok $obj->tuple_with_optional([1,'hello',3,1])
+ => "[1,'hello',3,1] properly suceeds";
+
+ok $obj->tuple_with_optional([1,'hello',3,4])
+ => "[1,'hello',3,4] properly suceeds";
+
+ok $obj->tuple_with_optional([1,'hello',3,4,5])
+ => "[1,'hello',3,4,5] properly suceeds";
+
+throws_ok sub {
+       $obj->tuple_with_optional([1,'hello',3,4,5,6]);
+}, qr/Too Many arguments for the available type constraints/ => "[1,'hello',3,4,5,6] properly fails";
+
+throws_ok sub {
+       $obj->tuple_with_optional([1,2,'world']);
+}, qr/Validation failed for 'Int' failed with value world/ => "[1,2,'world'] properly fails";
+
+throws_ok sub {
+       $obj->tuple_with_optional(['hello1',2,3]);
+}, qr/Validation failed for 'Int' failed with value hello1/ => "['hello',2,3] properly fails";
+
+throws_ok sub {
+       $obj->tuple_with_optional(['hello2',2,'world']);
+}, qr/Validation failed for 'Int' failed with value hello2/ => "['hello',2,'world'] properly fails";
+
+## tuple_with_union Tuple[Int,Str,Int|Object,Optional[Int|Object,Int]]
+
+SKIP: {
+
+       skip "Unions not supported for string parsed type constraints" => 8;
+
+       ok $obj->tuple_with_union([1,'hello',3])
+        => "[1,'hello',3] properly suceeds";
+
+       ok $obj->tuple_with_union([1,'hello',3,1])
+        => "[1,'hello',3,1] properly suceeds";
+
+       ok $obj->tuple_with_union([1,'hello',3,4])
+        => "[1,'hello',3,4] properly suceeds";
+
+       ok $obj->tuple_with_union([1,'hello',3,4,5])
+        => "[1,'hello',3,4,5] properly suceeds";
+
+       throws_ok sub {
+               $obj->tuple_with_union([1,'hello',3,4,5,6]);
+       }, qr/Too Many arguments for the available type constraints/ => "[1,'hello',3,4,5,6] properly fails";
+
+       throws_ok sub {
+               $obj->tuple_with_union([1,2,'world']);
+       }, qr/Validation failed for 'Int' failed with value world/ => "[1,2,'world'] properly fails";
+
+       throws_ok sub {
+               $obj->tuple_with_union(['hello1',2,3]);
+       }, qr/Validation failed for 'Int' failed with value hello1/ => "['hello',2,3] properly fails";
+
+       throws_ok sub {
+               $obj->tuple_with_union(['hello2',2,'world']);
+       }, qr/Validation failed for 'Int' failed with value hello2/ => "['hello',2,'world'] properly fails";
+}
 
-#ok Moose::Util::TypeConstraints::_detect_parameterized_type_constraint('HashRef[key1 => Int, key2=>Int, key3=>ArrayRef[Int]]')
-# => 'detected correctly';
-#is_deeply 
-#      [Moose::Util::TypeConstraints::_parse_parameterized_type_constraint('HashRef[key1 => Int, key2=>Int, key3=>ArrayRef[Int]]')],
-#      ["HashRef", "key1", "Int", "key2", "Int", "key3", "ArrayRef[Int]"]
-# => 'Correctly parsed HashRef[key1 => Int, key2=>Int, key3=>ArrayRef[Int]]';
\ No newline at end of file