Blame t/author-lib-convert-number-_num.t

Packit dcde0c
#!perl
Packit dcde0c
Packit dcde0c
BEGIN {
Packit dcde0c
    unless ($ENV{AUTHOR_TESTING}) {
Packit dcde0c
        require Test::More;
Packit dcde0c
        Test::More::plan(skip_all =>
Packit dcde0c
                         'these tests are for testing by the author');
Packit dcde0c
    }
Packit dcde0c
}
Packit dcde0c
Packit dcde0c
use strict;
Packit dcde0c
use warnings;
Packit dcde0c
Packit dcde0c
use Test::More tests => 3397;
Packit dcde0c
Packit dcde0c
###############################################################################
Packit dcde0c
# Read and load configuration file and backend library.
Packit dcde0c
Packit dcde0c
use Config::Tiny ();
Packit dcde0c
Packit dcde0c
my $config_file = 't/author-lib.ini';
Packit dcde0c
my $config = Config::Tiny -> read('t/author-lib.ini')
Packit dcde0c
  or die Config::Tiny -> errstr();
Packit dcde0c
Packit dcde0c
# Read the library to test.
Packit dcde0c
Packit dcde0c
our $LIB = $config->{_}->{lib};
Packit dcde0c
Packit dcde0c
die "No library defined in file '$config_file'"
Packit dcde0c
  unless defined $LIB;
Packit dcde0c
die "Invalid library name '$LIB' in file '$config_file'"
Packit dcde0c
  unless $LIB =~ /^[A-Za-z]\w*(::\w+)*\z/;
Packit dcde0c
Packit dcde0c
# Load the library.
Packit dcde0c
Packit dcde0c
eval "require $LIB";
Packit dcde0c
die $@ if $@;
Packit dcde0c
Packit dcde0c
###############################################################################
Packit dcde0c
Packit dcde0c
can_ok($LIB, "_num");
Packit dcde0c
Packit dcde0c
use lib "t";
Packit dcde0c
use Math::BigInt::Lib::TestUtil qw< randstr >;
Packit dcde0c
Packit dcde0c
# Generate test data.
Packit dcde0c
Packit dcde0c
my @data;
Packit dcde0c
Packit dcde0c
push @data, 0 .. 250;                   # small integers
Packit dcde0c
Packit dcde0c
for (my $n = 3 ; $n <= 300 ; ++ $n) {
Packit dcde0c
    push @data, "1" . ("0" x $n);       # powers of 10
Packit dcde0c
}
Packit dcde0c
Packit dcde0c
for (my $n = 1 ; $n <= 300 ; ++ $n) {
Packit dcde0c
    push @data, randstr($n, 10);        # random big integers
Packit dcde0c
}
Packit dcde0c
Packit dcde0c
# Tolerance for floating point number comparisons.
Packit dcde0c
Packit dcde0c
my $tol = 2e-15;
Packit dcde0c
Packit dcde0c
# List context.
Packit dcde0c
Packit dcde0c
for (my $i = 0 ; $i <= $#data ; ++ $i) {
Packit dcde0c
    my $str = $data[$i];
Packit dcde0c
Packit dcde0c
    my ($x, @got);
Packit dcde0c
Packit dcde0c
    my $test = qq|\$x = $LIB->_new("$str"); |
Packit dcde0c
             . qq|\@got = $LIB->_num(\$x);|;
Packit dcde0c
Packit dcde0c
    diag("\n$test\n\n") if $ENV{AUTHOR_DEBUGGING};
Packit dcde0c
Packit dcde0c
    eval $test;
Packit dcde0c
    is($@, "", "'$test' gives emtpy \$\@");
Packit dcde0c
Packit dcde0c
    subtest "_num() in list context: $test", sub {
Packit dcde0c
        plan tests => 3,
Packit dcde0c
Packit dcde0c
        cmp_ok(scalar @got, "==", 1,
Packit dcde0c
               "'$test' gives one output arg");
Packit dcde0c
Packit dcde0c
        is(ref($got[0]), "",
Packit dcde0c
           "'$test' output arg is a Perl scalar");
Packit dcde0c
Packit dcde0c
        # If output does not use floating point notation, compare the
Packit dcde0c
        # values exactly ...
Packit dcde0c
Packit dcde0c
        if ($got[0] =~ /^\d+\z/) {
Packit dcde0c
            cmp_ok($got[0], "==", $str,
Packit dcde0c
                   "'$test' output value is exactly right");
Packit dcde0c
        }
Packit dcde0c
Packit dcde0c
        # ... otherwise compare them approximatly.
Packit dcde0c
Packit dcde0c
        else {
Packit dcde0c
            my $rel_err = abs($got[0] - $str) / $str;
Packit dcde0c
            cmp_ok($rel_err, "<", $tol,
Packit dcde0c
                   "'$test' output value is correct within" .
Packit dcde0c
                   " a relative error of $tol");
Packit dcde0c
        }
Packit dcde0c
    };
Packit dcde0c
}
Packit dcde0c
Packit dcde0c
# Scalar context.
Packit dcde0c
Packit dcde0c
for (my $i = 0 ; $i <= $#data ; ++ $i) {
Packit dcde0c
    my $str = $data[$i];
Packit dcde0c
Packit dcde0c
    my ($x, $got);
Packit dcde0c
Packit dcde0c
    my $test = qq|\$x = $LIB->_new("$str"); |
Packit dcde0c
             . qq|\$got = $LIB->_num(\$x);|;
Packit dcde0c
Packit dcde0c
    diag("\n$test\n\n") if $ENV{AUTHOR_DEBUGGING};
Packit dcde0c
Packit dcde0c
    eval $test;
Packit dcde0c
    is($@, "", "'$test' gives emtpy \$\@");
Packit dcde0c
Packit dcde0c
    subtest "_num() in scalar context: $test", sub {
Packit dcde0c
        plan tests => 2,
Packit dcde0c
Packit dcde0c
        is(ref($got), "",
Packit dcde0c
           "'$test' output arg is a Perl scalar");
Packit dcde0c
Packit dcde0c
        # If output does not use floating point notation, compare the
Packit dcde0c
        # values exactly ...
Packit dcde0c
Packit dcde0c
        if ($got =~ /^\d+\z/) {
Packit dcde0c
            cmp_ok($got, "==", $str,
Packit dcde0c
                   "'$test' output value is exactly right");
Packit dcde0c
        }
Packit dcde0c
Packit dcde0c
        # ... otherwise compare them approximatly.
Packit dcde0c
Packit dcde0c
        else {
Packit dcde0c
            my $rel_err = abs($got - $str) / $str;
Packit dcde0c
            cmp_ok($rel_err, "<", $tol,
Packit dcde0c
                   "'$test' output value is correct within" .
Packit dcde0c
                   " a relative error of $tol");
Packit dcde0c
        }
Packit dcde0c
    };
Packit dcde0c
}