summaryrefslogtreecommitdiff
path: root/cpan/Math-BigInt/t/sub_mbi.t
blob: 10fffd1f06f865a83942ac72cb015e1244df74a0 (plain)
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
# -*- mode: perl; -*-

use strict;
use warnings;

use Test::More tests => 4278            # tests in require'd file
                         + 7;           # tests in this file

use lib 't';

use Math::BigInt::Subclass;

our ($CLASS, $LIB);
$CLASS = "Math::BigInt::Subclass";
$LIB   = "Math::BigInt::Calc";          # backend

require './t/bigintpm.inc';             # perform same tests as bigintpm

###############################################################################
# Now do custom tests for Subclass itself

my $ms = $CLASS->new(23);
is($ms->{_custom}, 1, '$ms has custom attribute \$ms->{_custom}');

# Check that a subclass is still considered a Math::BigInt
isa_ok($ms, 'Math::BigInt');

use Math::BigInt;

my $bi = Math::BigInt->new(23);         # same as other
$ms += $bi;
is($ms, 46, '$ms is 46');
is($ms->{_custom}, 1, '$ms has custom attribute $ms->{_custom}');
is(ref($ms), $CLASS, "\$ms is not an object of class '$CLASS'");

cmp_ok(Math::BigInt::Subclass -> div_scale(), "==", 40,
      "Math::BigInt::Subclass gets 'div_scale' from parent");

is(Math::BigInt::Subclass -> round_mode(), "even",
   "Math::BigInt::Subclass gets 'round_mode' from parent");