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 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
|
#!perl
use strict;
use warnings;
use Test::More tests => 72;
# test whether Math::BigInt->config() and Math::BigFloat->config() work
use Math::BigInt lib => 'Calc';
use Math::BigFloat;
my $mbi = 'Math::BigInt';
my $mbf = 'Math::BigFloat';
my @defaults =
([ 'lib', 'Math::BigInt::Calc' ],
[ 'lib_version', $Math::BigInt::Calc::VERSION, ],
[ 'upgrade', undef, ],
[ 'div_scale', 40, ],
[ 'precision', undef, ],
[ 'accuracy', undef, ],
[ 'round_mode', 'even', ],
[ 'trap_nan', 0, ],
[ 'trap_inf', 0, ]);
##############################################################################
# Math::BigInt
{
can_ok($mbi, 'config');
my @table = @defaults;
unshift @table, ['class', $mbi ];
# Test getting via the new-style $class->($key):
for (my $i = 0 ; $i <= $#table ; ++ $i) {
my $key = $table[$i][0];
my $val = $table[$i][1];
is($mbi->config($key), $val, qq|$mbi->config("$key")|);
}
# Test getting via the old-style $class->()->{$key}, which is still
# supported:
my $cfg = $mbi->config();
is(ref($cfg), 'HASH', 'ref() of output from $mbi->config()');
for (my $i = 0 ; $i <= $#table ; ++ $i) {
my $key = $table[$i][0];
my $val = $table[$i][1];
is($cfg->{$key}, $val, qq|$mbi->config()->{$key}|);
}
# can set via hash ref?
$cfg = $mbi->config({ trap_nan => 1 });
is($cfg->{trap_nan}, 1, 'can set "trap_nan" via hash ref');
# reset for later
$mbi->config(trap_nan => 0);
}
##############################################################################
# Math::BigFloat
{
can_ok($mbf, 'config');
my @table = @defaults;
unshift @table, ['class', $mbf ];
# Test getting via the new-style $class->($key):
for (my $i = 0 ; $i <= $#table ; ++ $i) {
my $key = $table[$i][0];
my $val = $table[$i][1];
is($mbf->config($key), $val, qq|$mbf->config("$key")|);
}
# Test getting via the old-style $class->()->{$key}, which is still
# supported:
my $cfg = $mbf->config();
is(ref($cfg), 'HASH', 'ref() of output from $mbf->config()');
for (my $i = 0 ; $i <= $#table ; ++ $i) {
my $key = $table[$i][0];
my $val = $table[$i][1];
is($cfg->{$key}, $val, qq|$mbf->config()->{$key}|);
}
# can set via hash ref?
$cfg = $mbf->config({ trap_nan => 1 });
is($cfg->{trap_nan}, 1, 'can set "trap_nan" via hash ref');
# reset for later
$mbf->config(trap_nan => 0);
}
##############################################################################
# test setting values
my $test = {
trap_nan => 1,
trap_inf => 1,
accuracy => 2,
precision => 3,
round_mode => 'zero',
div_scale => '100',
upgrade => 'Math::BigInt::SomeClass',
downgrade => 'Math::BigInt::SomeClass',
};
my $cfg;
foreach my $key (keys %$test) {
# see if setting in MBI works
eval { $mbi->config($key => $test->{$key}); };
$cfg = $mbi->config();
is("$key = $cfg->{$key}", "$key = $test->{$key}", "$key = $test->{$key}");
$cfg = $mbf->config();
# see if setting it in MBI leaves MBF alone
ok(($cfg->{$key} || 0) ne $test->{$key},
"$key ne \$cfg->{$key}");
# see if setting in MBF works
eval { $mbf->config($key => $test->{$key}); };
$cfg = $mbf->config();
is("$key = $cfg->{$key}", "$key = $test->{$key}", "$key = $test->{$key}");
}
##############################################################################
# test setting illegal keys (should croak)
eval { $mbi->config('some_garbage' => 1); };
like($@,
qr/ ^ Illegal \s+ key\(s\) \s+ 'some_garbage' \s+ passed \s+ to \s+
Math::BigInt->config\(\) \s+ at
/x,
'Passing invalid key to Math::BigInt->config() causes an error.');
eval { $mbf->config('some_garbage' => 1); };
like($@,
qr/ ^ Illegal \s+ key\(s\) \s+ 'some_garbage' \s+ passed \s+ to \s+
Math::BigFloat->config\(\) \s+ at
/x,
'Passing invalid key to Math::BigFloat->config() causes an error.');
|