RegressionTests__IntegerTest.st
author Claus Gittinger <cg@exept.de>
Tue, 11 May 1999 17:34:33 +0200
changeset 4 28e927bbc4e6
parent 3 4def69f1ad4a
child 5 f100f290c769
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
Object subclass:#IntegerTest
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
	instanceVariableNames:''
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
	classVariableNames:''
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
	poolDictionaries:''
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
	category:'Tests - Numbers'
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
     9
!IntegerTest class methodsFor:'misc'!
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    10
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    11
testPlus1_a:arg
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    12
    ^ arg + 1
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    13
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    14
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    15
     (self testPlus1_a:SmallInteger maxVal) =   1073741824  
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    16
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    17
!
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    18
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    19
testPlus1_b:arg
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    20
    ^ arg perform:#+ with:1
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    21
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    22
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    23
     (self testPlus1_b:SmallInteger maxVal) ==   1073741824  
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    24
    "
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    25
! !
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    26
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    27
!IntegerTest class methodsFor:'private'!
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
test:aBlock
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    30
    aBlock value == true ifFalse:[
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
        self halt:'test failed'
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
    ]
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
!IntegerTest class methodsFor:'tests'!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
test1
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
    "general conversion & tests"
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    40
    |minVal maxVal maxValPlus1 minValMinus1 halfMin halfMax t t1 t2|
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    41
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    42
    minVal := SmallInteger perform:('minVal' asSymbol).
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    43
    maxVal := SmallInteger perform:('maxVal' asSymbol).
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    44
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    45
    self test:[minVal == SmallInteger minVal].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    46
    self test:[maxVal == SmallInteger maxVal].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    self test:[10 printString = '10'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
    self test:[100 printString = '100'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    self test:[1000 printString = '1000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    self test:[10000 printString = '10000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    self test:[100000 printString = '100000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
    self test:[1000000 printString = '1000000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
    self test:[10000000 printString = '10000000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    self test:[100000000 printString = '100000000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
    self test:[1000000000 printString = '1000000000'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    self test:[10000000000 printString = '10000000000'].
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    58
    self test:[100000000000 printString = '100000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    59
    self test:[1000000000000 printString = '1000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    60
    self test:[10000000000000 printString = '10000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    61
    self test:[100000000000000 printString = '100000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    62
    self test:[1000000000000000 printString = '1000000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    63
    self test:[10000000000000000 printString = '10000000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    64
    self test:[100000000000000000 printString = '100000000000000000'].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
    SmallInteger maxBytes == 4 ifTrue:[
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    67
        self test:[minVal hexPrintString = '-40000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    68
        self test:[maxVal hexPrintString = '3FFFFFFF'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    69
        self test:[minVal == -1073741824].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    70
        self test:[maxVal == 1073741823].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
        maxValPlus1 := 1073741824.
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
        minValMinus1 := -1073741825.
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
        self test:[minValMinus1 hexPrintString = '-40000001'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
        self test:[maxValPlus1 hexPrintString = '40000000'].
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    75
        halfMin := -16r20000000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    76
        halfMax := 16r20000000.
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
    ].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
    SmallInteger maxBytes == 8 ifTrue:[
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    79
        self test:[minVal hexPrintString = '-4000000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    80
        self test:[maxVal hexPrintString = '3FFFFFFFFFFFFFFF'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    81
        self test:[minVal == -4611686018427387904].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    82
        self test:[maxVal == 4611686018427387903].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
        maxValPlus1 := 4611686018427387904.
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
        minValMinus1 := -4611686018427387905.
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
        self test:[minValMinus1 hexPrintString = '-4000000000000001'].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
        self test:[maxValPlus1 hexPrintString = '4000000000000000'].
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    87
        halfMin := -16r2000000000000000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    88
        halfMax := 16r2000000000000000.
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
    ].
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    "arithmetic overFlow checks"
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
    93
"/    self test:[(maxVal + 1) inspect.maxValPlus1 inspect. true].
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    94
    self test:[maxVal + 1 = maxValPlus1].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    95
    self test:[minVal - 1 = minValMinus1].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    96
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    97
    self test:[(halfMax + halfMax) = maxValPlus1].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    98
    self test:[(halfMin + halfMin) == minVal].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
    99
    self test:[(halfMax * 2) = maxValPlus1].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   100
    self test:[(halfMin * 2) == minVal].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   101
    self test:[maxValPlus1 // 2 == halfMax].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   102
    self test:[(halfMax bitShift:1) = maxValPlus1].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   103
    self test:[(halfMin bitShift:1) == minVal].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   104
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   105
    "LargeInt op -> SmallInt result"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   106
    t := maxVal + 1.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   107
    self test:[t - 1 == maxVal].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   108
    t := minVal - 1.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   109
    self test:[t + 1 == minVal].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   110
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   111
    "multiplication"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   112
    t1 := 100.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   113
    self test:[t1 * t1 == 10000].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   114
    t1 := 1000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   115
    self test:[t1 * t1 == 1000000].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   116
    t1 := 10000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   117
    self test:[t1 * t1 == 100000000].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   118
    t1 := 100000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   119
    SmallInteger maxBytes == 4 ifTrue:[
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   120
        self test:[t1 * t1 ~~ 10000000000].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   121
    ].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   122
    SmallInteger maxBytes == 8 ifTrue:[
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   123
        self test:[t1 * t1 == 10000000000].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   124
    ].
4
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   125
28e927bbc4e6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 3
diff changeset
   126
    self test:[(t1 perform:'*' asSymbol with:t1) printString = '10000000000'].
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   127
    self test:[(t1 * t1) printString = '10000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   128
    t1 := 1000000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   129
    self test:[(t1 * t1) printString = '1000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   130
    t1 := 10000000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   131
    self test:[(t1 * t1) printString = '100000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   132
    t1 := 100000000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   133
    self test:[(t1 * t1) printString = '10000000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   134
    t1 := 1000000000.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   135
    self test:[(t1 * t1) printString = '1000000000000000000'].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   137
    "Large * SmallInt multiplication"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   138
    self test:[10 factorial printString = '3628800'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   139
    self test:[20 factorial printString = '2432902008176640000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   140
    self test:[100 factorial printString = '93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   141
    self test:[1000 factorial printString = '402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901323829669944590997424504087073759918823627727188732519779505950995276120874975462497043601418278094646496291056393887437886487337119181045825783647849977012476632889835955735432513185323958463075557409114262417474349347553428646576611667797396668820291207379143853719588249808126867838374559731746136085379534524221586593201928090878297308431392844403281231558611036976801357304216168747609675871348312025478589320767169132448426236131412508780208000261683151027341827977704784635868170164365024153691398281264810213092761244896359928705114964975419909342221566832572080821333186116811553615836546984046708975602900950537616475847728421889679646244945160765353408198901385442487984959953319101723355556602139450399736280750137837615307127761926849034352625200015888535147331611702103968175921510907788019393178114194545257223865541461062892187960223838971476088506276862967146674697562911234082439208160153780889893964518263243671616762179168909779911903754031274622289988005195444414282012187361745992642956581746628302955570299024324153181617210465832036786906117260158783520751516284225540265170483304226143974286933061690897968482590125458327168226458066526769958652682272807075781391858178889652208164348344825993266043367660176999612831860788386150279465955131156552036093988180612138558600301435694527224206344631797460594682573103790084024432438465657245014402821885252470935190620929023136493273497565513958720559654228749774011413346962715422845862377387538230483865688976461927383814900140767310446640259899490222221765904339901886018566526485061799702356193897017860040811889729918311021171229845901641921068884387121855646124960798722908519296819372388642614839657382291123125024186649353143970137428531926649875337218940694281434118520158014123344828015051399694290153483077644569099073152433278288269864602789864321139083506217095002597389863554277196742822248757586765752344220207573630569498825087968928162753848863396909959826280956121450994871701244516461260379029309120889086942028510640182154399457156805941872748998094254742173582401063677404595741785160829230135358081840096996372524230560855903700624271243416909004153690105933983835777939410970027753472000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000'].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
3
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   143
    "Large * Large multiplication"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   144
    self test:[(20 factorial * 20 factorial) printString = '5919012181389927685417441689600000000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   145
    t := 20 factorial.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   146
    t := t // 20.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   147
    self test:[t printString = 19 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   148
    t := t // 19.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   149
    self test:[t printString = 18 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   150
    t := t // 18.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   151
    self test:[t printString = 17 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   152
    t := t // 17.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   153
    self test:[t printString = 16 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   154
    t := t // 16.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   155
    self test:[t printString = 15 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   156
    t := t // 15.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   157
    self test:[t printString = 14 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   158
    t := t // 14.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   159
    self test:[t printString = 13 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   160
    t := t // 13.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   161
    self test:[t printString = 12 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   162
    t := t // 12.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   163
    self test:[t printString = 11 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   164
    t := t // 11.
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   165
    self test:[t printString = 10 factorial printString].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   166
    self test:[t == 10 factorial].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   167
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   168
    "Large // Large division"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   169
    self test:[(20 factorial / 19 factorial) == 20].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   170
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   171
    "Large + Large addition"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   172
    self test:[(20 factorial + 20 factorial) printString = '4865804016353280000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   173
    self test:[(20 factorial + 1) printString = '2432902008176640001'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   174
    self test:[(20 factorial + 1000) printString = '2432902008176641000'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   175
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   176
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   177
    "Large - small subtraction"
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   178
    self test:[(20 factorial + 20 factorial - 1) printString = '4865804016353279999'].
4def69f1ad4a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2
diff changeset
   179
    self test:[(20 factorial - 10 factorial + 3628800) printString = '2432902008176640000'].
2
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
    "
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
     self test1
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
    "
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
! !
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
!IntegerTest class methodsFor:'documentation'!
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
version
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
    ^ '$Header$'
7105b918a4a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
! !