70 lines
1.8 KiB
Nim
70 lines
1.8 KiB
Nim
# Copyright (c) 2018 Status Research & Development GmbH
|
|
# Distributed under the MIT License (license terms are at http://opensource.org/licenses/MIT).
|
|
|
|
import ../src/mpint, unittest
|
|
|
|
suite "Testing addition implementation":
|
|
test "In-place addition gives expected result":
|
|
|
|
var a = initMpUint(20182018, uint32)
|
|
let b = initMpUint(20172017, uint32)
|
|
|
|
a += b
|
|
|
|
check: cast[uint64](a) == 20182018'u64 + 20172017'u64
|
|
|
|
test "Addition gives expected result":
|
|
|
|
let a = initMpUint(20182018, uint32)
|
|
let b = initMpUint(20172017, uint32)
|
|
|
|
check: cast[uint64](a+b) == 20182018'u64 + 20172017'u64
|
|
|
|
test "When the low half overflows, it is properly carried":
|
|
# uint8 (low half) overflow at 255
|
|
let a = initMpUint(100, uint8)
|
|
let b = initMpUint(100, uint8)
|
|
|
|
check: cast[uint16](a+b) == 200
|
|
|
|
test "Full overflow is handled like native unsigned types":
|
|
# uint16 overflows after 65535
|
|
let a = initMpUint(100, uint8)
|
|
var z = initMpUint(0, uint8)
|
|
let o = initMpUint(36, uint8)
|
|
|
|
for _ in 0 ..< 655:
|
|
z += a
|
|
|
|
check: cast[uint16](z) == 65500
|
|
check: cast[uint16](z + o) == 0
|
|
|
|
z += a
|
|
check: cast[uint16](z) == 64
|
|
|
|
z += a
|
|
check: cast[uint16](z) == 164
|
|
|
|
suite "Testing substraction implementation":
|
|
test "In-place substraction gives expected result":
|
|
|
|
var a = initMpUint(20182018, uint32)
|
|
let b = initMpUint(20172017, uint32)
|
|
|
|
a -= b
|
|
|
|
check: cast[uint64](a) == 20182018'u64 - 20172017'u64
|
|
|
|
test "Substraction gives expected result":
|
|
|
|
let a = initMpUint(20182018, uint32)
|
|
let b = initMpUint(20172017, uint32)
|
|
|
|
check: cast[uint64](a-b) == 20182018'u64 - 20172017'u64
|
|
|
|
test "Full overflow is handled like native unsigned types":
|
|
# uint16 overflows after 65535
|
|
let a = initMpUint(100, uint8)
|
|
let b = initMpUint(101, uint8)
|
|
|
|
check: cast[uint16](a-b) == high(uint16) |