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 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191
|
# -*- mode: perl; -*-
use strict;
use warnings;
use Test::More tests => 3997;
###############################################################################
# Read and load configuration file and backend library.
use Config::Tiny ();
my $config_file = 'xt/author/lib.ini';
my $config = Config::Tiny -> read('xt/author/lib.ini')
or die Config::Tiny -> errstr();
# Read the library to test.
our $LIB = $config->{_}->{lib};
die "No library defined in file '$config_file'"
unless defined $LIB;
die "Invalid library name '$LIB' in file '$config_file'"
unless $LIB =~ /^[A-Za-z]\w*(::\w+)*\z/;
# Read the reference type(s) the library uses.
our $REF = $config->{_}->{ref};
die "No reference type defined in file '$config_file'"
unless defined $REF;
die "Invalid reference type '$REF' in file '$config_file'"
unless $REF =~ /^[A-Za-z]\w*(::\w+)*\z/;
# Load the library.
eval "require $LIB";
die $@ if $@;
###############################################################################
my $scalar_util_ok = eval { require Scalar::Util; };
Scalar::Util -> import('refaddr') if $scalar_util_ok;
diag "Skipping some tests since Scalar::Util is not installed."
unless $scalar_util_ok;
can_ok($LIB, '_div');
my @data;
# Small numbers.
for (my $x = 0; $x <= 24 ; ++ $x) {
for (my $y = 1; $y <= 24 ; ++ $y) {
push @data, [ $x, $y, int($x / $y), $x % $y ];
}
}
# Add data in data file.
(my $datafile = $0) =~ s/\.t/.dat/;
open DATAFILE, $datafile or die "$datafile: can't open file for reading: $!";
while (<DATAFILE>) {
s/\s+\z//;
next if /^#/ || ! /\S/;
push @data, [ split /:/ ];
}
close DATAFILE or die "$datafile: can't close file after reading: $!";
# List context.
for (my $i = 0 ; $i <= $#data ; ++ $i) {
my ($in0, $in1, $out0, $out1) = @{ $data[$i] };
my ($x, $y, @got);
my $test = qq|\$x = $LIB->_new("$in0"); |
. qq|\$y = $LIB->_new("$in1"); |
. qq|\@got = $LIB->_div(\$x, \$y);|;
diag("\n$test\n\n") if $ENV{AUTHOR_DEBUGGING};
eval $test;
is($@, "", "'$test' gives emtpy \$\@");
subtest "_div() in list context: $test", sub {
plan tests => 13;
cmp_ok(scalar @got, '==', 2,
"'$test' gives two output args");
is(ref($got[0]), $REF,
"'$test' first output arg is a $REF");
is($LIB->_check($got[0]), 0,
"'$test' first output arg is valid");
is($LIB->_str($got[0]), $out0,
"'$test' first output arg has the right value");
SKIP: {
skip "Scalar::Util not available", 1 unless $scalar_util_ok;
isnt(refaddr($got[0]), refaddr($y),
"'$test' first output arg is not the second input arg");
}
SKIP: {
skip "$LIB doesn't use real objects", 1
if $LIB eq 'Math::BigInt::FastCalc';
is(ref($got[1]), $REF,
"'$test' second output arg is a $REF");
}
is($LIB->_check($got[1]), 0,
"'$test' second output arg is valid");
is($LIB->_str($got[1]), $out1,
"'$test' second output arg has the right value");
SKIP: {
skip "Scalar::Util not available", 1 unless $scalar_util_ok;
isnt(refaddr($got[1]), refaddr($y),
"'$test' second output arg is not the second input arg");
}
is(ref($x), $REF,
"'$test' first input arg is still a $REF");
ok($LIB->_str($x) eq $out0 || $LIB->_str($x) eq $in0,
"'$test' first input arg has the correct value");
is(ref($y), $REF,
"'$test' second input arg is still a $REF");
is($LIB->_str($y), $in1,
"'$test' second input arg is unmodified");
};
}
# Scalar context.
for (my $i = 0 ; $i <= $#data ; ++ $i) {
my ($in0, $in1, $out0, $out1) = @{ $data[$i] };
my ($x, $y, $got);
my $test = qq|\$x = $LIB->_new("$in0"); |
. qq|\$y = $LIB->_new("$in1"); |
. qq|\$got = $LIB->_div(\$x, \$y);|;
diag("\n$test\n\n") if $ENV{AUTHOR_DEBUGGING};
eval $test;
is($@, "", "'$test' gives emtpy \$\@");
subtest "_div() in scalar context: $test", sub {
plan tests => 8;
is(ref($got), $REF,
"'$test' output arg is a $REF");
is($LIB->_check($got), 0,
"'$test' output is valid");
is($LIB->_str($got), $out0,
"'$test' output arg has the right value");
SKIP: {
skip "Scalar::Util not available", 1 unless $scalar_util_ok;
isnt(refaddr($got), refaddr($y),
"'$test' output arg is not the second input arg");
}
is(ref($x), $REF,
"'$test' first input arg is still a $REF");
ok($LIB->_str($x) eq $out0 || $LIB->_str($x) eq $in0,
"'$test' first input arg has the correct value");
is(ref($y), $REF,
"'$test' second input arg is still a $REF");
is($LIB->_str($y), $in1,
"'$test' second input arg is unmodified");
};
}
|