bignum-0.12 updates from:
[p5sagit/p5-mst-13.2.git] / lib / bignum / t / bignum.t
1 #!/usr/bin/perl -w
2
3 ###############################################################################
4
5 use Test;
6 use strict;
7
8 BEGIN
9   {
10   $| = 1;
11   chdir 't' if -d 't';
12   unshift @INC, '../lib';
13   plan tests => 21;
14   }
15
16 use bignum;
17
18 ###############################################################################
19 # general tests
20
21 my $x = 5; ok (ref($x) =~ /^Math::BigInt/);             # :constant
22
23 ok (2 + 2.5,4.5);
24 $x = 2 + 3.5; ok (ref($x),'Math::BigFloat');
25 ok (2 * 2.1,4.2);
26 $x = 2 + 2.1; ok (ref($x),'Math::BigFloat');
27
28 $x = 2 ** 255; ok (ref($x) =~ /^Math::BigInt/);
29
30 # see if Math::BigInt constant and upgrading works
31 ok (Math::BigInt::bsqrt('12'),'3.464101615137754587054892683011744733886');
32 ok (sqrt(12),'3.464101615137754587054892683011744733886');
33
34 ok (2/3,"0.6666666666666666666666666666666666666667");
35
36 #ok (2 ** 0.5, 'NaN');  # should be sqrt(2);
37
38 print "huh\n";
39
40 ok (12->bfac(),479001600);
41
42 # see if Math::BigFloat constant works
43
44 #                     0123456789          0123456789    <- default 40
45 #           0123456789          0123456789
46 ok (1/3, '0.3333333333333333333333333333333333333333');
47
48 ###############################################################################
49 # accurarcy and precision
50
51 # this might change!
52
53 ok_undef ($Math::BigInt::accuracy);
54 ok_undef ($Math::BigInt::precision);
55 ok_undef ($Math::BigFloat::accuracy);
56 ok_undef ($Math::BigFloat::precision);
57 bignum->accuracy(5);
58 ok ($Math::BigInt::accuracy,5);
59 ok ($Math::BigFloat::accuracy,5);
60 bignum->precision(-2);
61 ok_undef ($Math::BigInt::accuracy);
62 ok_undef ($Math::BigFloat::accuracy);
63 ok ($Math::BigInt::precision,-2);
64 ok ($Math::BigFloat::precision,-2);
65
66 ###############################################################################
67 ###############################################################################
68 # Perl 5.005 does not like ok ($x,undef)
69
70 sub ok_undef
71   {
72   my $x = shift;
73
74   ok (1,1) and return if !defined $x;
75   ok ($x,'undef');
76   }