X-Git-Url: http://git.maemo.org/git/?p=dh-make-perl;a=blobdiff_plain;f=dev%2Fi386%2Flibperl-critic-perl%2Flibperl-critic-perl-1.088%2Ft%2F14_policy_parameter_behavior_integer.t;fp=dev%2Fi386%2Flibperl-critic-perl%2Flibperl-critic-perl-1.088%2Ft%2F14_policy_parameter_behavior_integer.t;h=bd275f6ee895784cae9f4b3183ec160523818b04;hp=0000000000000000000000000000000000000000;hb=da95c414033799c3a62606f299c3c00b5c77ca11;hpb=2d38e14bacbb15b98e539843a40b3c52a225f493 diff --git a/dev/i386/libperl-critic-perl/libperl-critic-perl-1.088/t/14_policy_parameter_behavior_integer.t b/dev/i386/libperl-critic-perl/libperl-critic-perl-1.088/t/14_policy_parameter_behavior_integer.t new file mode 100644 index 0000000..bd275f6 --- /dev/null +++ b/dev/i386/libperl-critic-perl/libperl-critic-perl-1.088/t/14_policy_parameter_behavior_integer.t @@ -0,0 +1,170 @@ +#!perl + +############################################################################## +# $URL: http://perlcritic.tigris.org/svn/perlcritic/trunk/Perl-Critic/t/14_policy_parameter_behavior_integer.t $ +# $Date: 2008-06-06 00:48:04 -0500 (Fri, 06 Jun 2008) $ +# $Author: clonezone $ +# $Revision: 2416 $ +############################################################################## + +use 5.006001; +use strict; +use warnings; + +use Test::More tests => 22; +use English qw(-no_match_vars); + +use Perl::Critic::Policy; +use Perl::Critic::PolicyParameter; +use Perl::Critic::Utils qw{ :booleans }; + +my $specification; +my $parameter; +my %config; +my $policy; + +$specification = + { + name => 'test', + description => 'An integer parameter for testing', + behavior => 'integer', + }; + + +$parameter = Perl::Critic::PolicyParameter->new($specification); +$policy = Perl::Critic::Policy->new(); +$parameter->parse_and_validate_config_value($policy, \%config); +is($policy->{_test}, undef, q{no value, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '2943'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 2943, q{2943, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '+2943'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 2943, q{+2943, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '-2943'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', -2943, q{-2943, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '29_43'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 2943, q{29_43, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '+29_43'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 2943, q{+29_43, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '-29_43'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', -2943, q{-29_43, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '0'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 0, q{0, no default}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '1.5'; +eval { $parameter->parse_and_validate_config_value($policy, \%config); }; +ok($EVAL_ERROR, q{not an integer}); + + +$specification->{default_string} = '0'; +delete $config{test}; + +$parameter = Perl::Critic::PolicyParameter->new($specification); +$policy = Perl::Critic::Policy->new(); +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 0, q{no value, default 0}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '5'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 5, q{5, default 0}); + + +$specification->{integer_minimum} = 0; + +$parameter = Perl::Critic::PolicyParameter->new($specification); +$policy = Perl::Critic::Policy->new(); +$config{test} = '5'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 5, q{5, minimum 0}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '0'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 0, q{0, minimum 0}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '-5'; +eval { $parameter->parse_and_validate_config_value($policy, \%config); }; +ok($EVAL_ERROR, q{below minimum}); + + +delete $specification->{integer_minimum}; +$specification->{integer_maximum} = 0; + +$parameter = Perl::Critic::PolicyParameter->new($specification); +$policy = Perl::Critic::Policy->new(); +$config{test} = '-5'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', -5, q{-5, maximum 0}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '0'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 0, q{0, maximum 0}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '5'; +eval { $parameter->parse_and_validate_config_value($policy, \%config); }; +ok($EVAL_ERROR, q{above maximum}); + + +$specification->{integer_minimum} = 0; +$specification->{integer_maximum} = 5; + +$parameter = Perl::Critic::PolicyParameter->new($specification); +$policy = Perl::Critic::Policy->new(); +$config{test} = '-5'; +eval { $parameter->parse_and_validate_config_value($policy, \%config); }; +ok($EVAL_ERROR, q{below minimum of range}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '0'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 0, q{0, minimum 0, maximum 5}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '3'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 3, q{3, minimum 0, maximum 5}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '5'; +$parameter->parse_and_validate_config_value($policy, \%config); +cmp_ok($policy->{_test}, '==', 5, q{5, minimum 0, maximum 5}); + +$policy = Perl::Critic::Policy->new(); +$config{test} = '10'; +eval { $parameter->parse_and_validate_config_value($policy, \%config); }; +ok($EVAL_ERROR, q{above maximum of range}); + +############################################################################### +# Local Variables: +# mode: cperl +# cperl-indent-level: 4 +# fill-column: 78 +# indent-tabs-mode: nil +# c-indentation-style: bsd +# End: +# ex: set ts=8 sts=4 sw=4 tw=78 ft=perl expandtab shiftround :