summaryrefslogtreecommitdiff
path: root/t/20-modules/Type-Params/coerce.t
blob: 0c9aa74f5d120c129da9aa8b5ae00314279d5e00 (plain)
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
=pod

=encoding utf-8

=head1 PURPOSE

Test L<Type::Params> usage of types with coercions.

=head1 AUTHOR

Toby Inkster E<lt>tobyink@cpan.orgE<gt>.

=head1 COPYRIGHT AND LICENCE

This software is copyright (c) 2013-2014, 2017-2023 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";
use Type::Utils;
use Scalar::Util qw(refaddr);

my $RoundedInt = declare as Int;
coerce $RoundedInt, from Num, q{ int($_) };

my $chk = compile(Int, $RoundedInt, Num);

is_deeply(
	[ $chk->(1, 2, 3.3) ],
	[ 1, 2, 3.3 ]
);

is_deeply(
	[ $chk->(1, 2.2, 3.3) ],
	[ 1, 2, 3.3 ]
);

like(
	exception { $chk->(1.1, 2.2, 3.3) },
	qr{^Value "1\.1" did not pass type constraint "Int" \(in \$_\[0\]\)},
);

my $chk2 = compile(ArrayRef[$RoundedInt]);

is_deeply(
	[ $chk2->([1, 2, 3]) ],
	[ [1, 2, 3] ]
);

is_deeply(
	[ $chk2->([1.1, 2.2, 3.3]) ],
	[ [1, 2, 3] ]
);

is_deeply(
	[ $chk2->([1.1, 2, 3.3]) ],
	[ [1, 2, 3] ]
);

my $arr  = [ 1 ];
my $arr2 = [ 1.1 ];

is(
	refaddr( [$chk2->($arr)]->[0] ),
	refaddr($arr),
	'if value passes type constraint; no need to clone arrayref'
);

isnt(
	refaddr( [$chk2->($arr2)]->[0] ),
	refaddr($arr2),
	'if value fails type constraint; need to clone arrayref'
);

my $chk3 = compile($RoundedInt->no_coercions);

like(
	exception { $chk3->(1.1) },
	qr{^Value "1\.1" did not pass type constraint},
);

done_testing;