|
Packit |
dcde0c |
#!perl
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
use strict;
|
|
Packit |
dcde0c |
use warnings;
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
use Test::More tests => 3913 # tests in require'd file
|
|
Packit |
dcde0c |
+ 20; # tests in this file
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
use Math::BigInt only => 'FastCalc';
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
our ($CLASS, $CALC);
|
|
Packit |
dcde0c |
$CLASS = "Math::BigInt";
|
|
Packit |
dcde0c |
$CALC = Math::BigInt -> config('lib'); # backend library
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
my $x;
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
#############################################################################
|
|
Packit |
dcde0c |
# bgcd() as function, class method and instance method.
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
my $gcd0 = Math::BigInt::bgcd(-12, 18, 27);
|
|
Packit |
dcde0c |
isa_ok($gcd0, "Math::BigInt", "bgcd() as function");
|
|
Packit |
dcde0c |
is($gcd0, 3, "bgcd() as function");
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
my $gcd1 = Math::BigInt->bgcd(-12, 18, 27);
|
|
Packit |
dcde0c |
isa_ok($gcd1, "Math::BigInt", "bgcd() as class method");
|
|
Packit |
dcde0c |
is($gcd1, 3, "bgcd() as class method");
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt -> new(-12);
|
|
Packit |
dcde0c |
my $gcd2 = $x -> bgcd(18, 27);
|
|
Packit |
dcde0c |
isa_ok($gcd2, "Math::BigInt", "bgcd() as instance method");
|
|
Packit |
dcde0c |
is($gcd2, 3, "bgcd() as instance method");
|
|
Packit |
dcde0c |
is($x, -12, "bgcd() does not modify invocand");
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
#############################################################################
|
|
Packit |
dcde0c |
# blcm() as function, class method and instance method.
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
my $lcm0 = Math::BigInt::blcm(-12, 18, 27);
|
|
Packit |
dcde0c |
isa_ok($lcm0, "Math::BigInt", "blcm() as function");
|
|
Packit |
dcde0c |
is($lcm0, 108, "blcm() as function");
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
my $lcm1 = Math::BigInt->blcm(-12, 18, 27);
|
|
Packit |
dcde0c |
isa_ok($lcm1, "Math::BigInt", "blcm() as class method");
|
|
Packit |
dcde0c |
is($lcm1, 108, "blcm() as class method");
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt -> new(-12);
|
|
Packit |
dcde0c |
my $lcm2 = $x -> blcm(18, 27);
|
|
Packit |
dcde0c |
isa_ok($lcm2, "Math::BigInt", "blcm() as instance method");
|
|
Packit |
dcde0c |
is($lcm2, 108, "blcm() as instance method");
|
|
Packit |
dcde0c |
is($x, -12, "blcm() does not modify invocand");
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
#############################################################################
|
|
Packit |
dcde0c |
# from_hex(), from_bin() and from_oct() tests
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt->from_hex('0xcafe');
|
|
Packit |
dcde0c |
is($x, "51966",
|
|
Packit |
dcde0c |
qq|Math::BigInt->from_hex("0xcafe")|);
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt->from_hex('0xcafebabedead');
|
|
Packit |
dcde0c |
is($x, "223195403574957",
|
|
Packit |
dcde0c |
qq|Math::BigInt->from_hex("0xcafebabedead")|);
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt->from_bin('0b1001');
|
|
Packit |
dcde0c |
is($x, "9",
|
|
Packit |
dcde0c |
qq|Math::BigInt->from_bin("0b1001")|);
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt->from_bin('0b1001100110011001100110011001');
|
|
Packit |
dcde0c |
is($x, "161061273",
|
|
Packit |
dcde0c |
qq|Math::BigInt->from_bin("0b1001100110011001100110011001");|);
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt->from_oct('0775');
|
|
Packit |
dcde0c |
is($x, "509",
|
|
Packit |
dcde0c |
qq|Math::BigInt->from_oct("0775");|);
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
$x = Math::BigInt->from_oct('07777777777777711111111222222222');
|
|
Packit |
dcde0c |
is($x, "9903520314281112085086151826",
|
|
Packit |
dcde0c |
qq|Math::BigInt->from_oct("07777777777777711111111222222222");|);
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
#############################################################################
|
|
Packit |
dcde0c |
# all the other tests
|
|
Packit |
dcde0c |
|
|
Packit |
dcde0c |
require 't/bigintpm.inc'; # all tests here for sharing
|