1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
=pod
=encoding utf-8
=head1 PURPOSE
Test L<Type::Params> usage with slurpy parameters.
=head1 AUTHOR
Toby Inkster E<lt>tobyink@cpan.orgE<gt>.
=head1 COPYRIGHT AND LICENCE
This software is copyright (c) 2013-2014 by Toby Inkster.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
use strict;
use warnings;
use Test::More;
use Test::Fatal;
use Type::Params qw(compile);
use Types::Standard -types, "slurpy";
my $chk = compile(Str, slurpy HashRef[Int]);
is_deeply(
[ $chk->("Hello", foo => 1, bar => 2) ],
[ "Hello", { foo => 1, bar => 2 } ]
);
like(
exception { $chk->("Hello", foo => 1, bar => 2.1) },
qr{did not pass type constraint "HashRef\[Int\]" \(in \$SLURPY\)},
);
my $chk2 = compile(Str, slurpy HashRef);
is_deeply(
[ $chk2->("Hello", foo => 1, bar => 2) ],
[ "Hello", { foo => 1, bar => 2 } ]
);
like(
exception { $chk2->("Hello", foo => 1, "bar") },
qr{^Odd number of elements in HashRef},
);
my $chk3 = compile(Str, slurpy Map);
like(
exception { $chk3->("Hello", foo => 1, "bar") },
qr{^Odd number of elements in Map},
);
my $chk4 = compile(Str, slurpy Tuple[Str, Int, Str]);
is_deeply(
[ $chk4->("Hello", foo => 1, "bar") ],
[ Hello => [qw/ foo 1 bar /] ],
);
done_testing;
|