2018-03-22 15:51:09 +01:00
|
|
|
#!perl
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use Test::More;
|
|
|
|
|
|
|
|
BEGIN {
|
|
|
|
plan skip_all => "requires Math::BigFloat 1.999715+" unless eval { require Math::BigFloat && eval($Math::BigFloat::VERSION) >= 1.999715 };
|
|
|
|
plan tests => 2409 # tests in require'd file
|
|
|
|
+ 5; # tests in this file
|
|
|
|
}
|
|
|
|
|
|
|
|
use Math::BigInt lib => 'LTM';
|
|
|
|
use Math::BigFloat;
|
|
|
|
|
|
|
|
our $CLASS = "Math::BigFloat";
|
|
|
|
our $CALC = "Math::BigInt::LTM"; # backend
|
|
|
|
|
|
|
|
is($CLASS->config()->{class}, $CLASS, "$CLASS->config()->{class}");
|
|
|
|
is($CLASS->config()->{with}, $CALC, "$CLASS->config()->{with}");
|
|
|
|
|
|
|
|
# bug #17447: Can't call method Math::BigFloat->bsub, not a valid method
|
|
|
|
my $c = Math::BigFloat->new('123.3');
|
|
|
|
is($c->bsub(123), '0.3',
|
|
|
|
qq|\$c = Math::BigFloat -> new("123.3"); \$y = \$c -> bsub("123")|);
|
|
|
|
|
|
|
|
# Bug until Math::BigInt v1.86, the scale wasn't treated as a scalar:
|
|
|
|
$c = Math::BigFloat->new('0.008');
|
|
|
|
my $d = Math::BigFloat->new(3);
|
|
|
|
my $e = $c->bdiv(Math::BigFloat->new(3), $d);
|
|
|
|
|
|
|
|
is($e, '0.00267', '0.008 / 3 = 0.0027');
|
|
|
|
|
|
|
|
SKIP: {
|
|
|
|
skip("skipping test which is not for this backend", 1)
|
|
|
|
unless $CALC eq 'Math::BigInt::Calc';
|
|
|
|
is(ref($e->{_e}->[0]), '', '$e->{_e}->[0] is a scalar');
|
|
|
|
}
|
|
|
|
|
2018-03-22 15:54:03 +01:00
|
|
|
require './t/mbi_ltm/bigfltpm.inc'; # all tests here for sharing
|