diff options
author | P. J. McDermott <pj@pehjota.net> | 2017-01-05 17:24:28 (EST) |
---|---|---|
committer | P. J. McDermott <pj@pehjota.net> | 2017-01-05 17:24:28 (EST) |
commit | 88f8a42f78b7d010294b26e9130c3ffa12ed46e4 (patch) | |
tree | c9e1811cc5001758f5df7c4c230ade5fb82bae11 /t | |
parent | 6d2e9ac3a2cb526eda50bb3d1a6ab150f6e35c7c (diff) | |
download | Math-Decimal-FastPP-88f8a42f78b7d010294b26e9130c3ffa12ed46e4.zip Math-Decimal-FastPP-88f8a42f78b7d010294b26e9130c3ffa12ed46e4.tar.gz Math-Decimal-FastPP-88f8a42f78b7d010294b26e9130c3ffa12ed46e4.tar.bz2 |
t/13_drhtz-drhfz.t: New file
Diffstat (limited to 't')
-rw-r--r-- | t/13_drhtz-drhfz.t | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/t/13_drhtz-drhfz.t b/t/13_drhtz-drhfz.t new file mode 100644 index 0000000..3cebf7a --- /dev/null +++ b/t/13_drhtz-drhfz.t @@ -0,0 +1,72 @@ +# t/13_drhtz-drhfz.t - drhtz and drhfz tests +# +# Copyright (C) 2017 Patrick McDermott +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +use strict; +use warnings; + +use Test::More; +use B qw(svref_2object); +use Math::Decimal::FastPP; + +my @std_tests; +my @tie_tests; +my $i; +my $a; +my $p; +my $r; +my @funcs; +my $f; + +@std_tests = ( + # a p r functions + [ 23.1 , 0, "23." , \&drhtz, \&drhfz], + [ 23.9 , 0, "24." , \&drhtz, \&drhfz], + [-23.1 , 0, "-23." , \&drhtz, \&drhfz], + [-23.9 , 0, "-24." , \&drhtz, \&drhfz], +); +@tie_tests = ( + [ 23.5 , 0, "23." , \&drhtz ], + [ 23.5 , 0, "24." , \&drhfz], + [ 2.35, 1, "2.3", \&drhtz ], + [ 2.35, 1, "2.4", \&drhfz], + [-23.5 , 0, "-23." , \&drhtz ], + [-23.5 , 0, "-24." , \&drhfz], + [ -2.35, 1, "-2.3", \&drhtz ], + [ -2.35, 1, "-2.4", \&drhfz], +); + +$i = 0; +map({$i += scalar(@{$_}) - 3} @std_tests); +map({$i += scalar(@{$_}) - 3} @tie_tests); +plan("tests" => $i); + +note("Basic tests:"); +foreach (@std_tests) { + ($a, $p, $r, @funcs) = @{$_}; + foreach $f (@funcs) { + is(&$f($a, $p), $r, sprintf("%s(%6.2f, %d) = %5.1f", + svref_2object($f)->GV->NAME, $a, $p, $r)); + } +} +note("Tie-breaking tests:"); +foreach (@tie_tests) { + ($a, $p, $r, @funcs) = @{$_}; + foreach $f (@funcs) { + is(&$f($a, $p), $r, sprintf("%s(%6.2f, %d) = %5.1f", + svref_2object($f)->GV->NAME, $a, $p, $r)); + } +} |