diff options
author | obscuren <geffobscura@gmail.com> | 2015-02-19 00:18:07 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2015-02-19 00:18:07 +0800 |
commit | 487c5cc294d4c0506e50a026737be7f4cc94436f (patch) | |
tree | 987987fb8cc4298767a594867a1374b22bc62462 /ethutil/number/uint_test.go | |
parent | ee9df32dba5091069cbdad8d00dc15738d676d5b (diff) | |
download | go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.tar go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.tar.gz go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.tar.bz2 go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.tar.lz go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.tar.xz go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.tar.zst go-tangerine-487c5cc294d4c0506e50a026737be7f4cc94436f.zip |
Added WIP number package
Diffstat (limited to 'ethutil/number/uint_test.go')
-rw-r--r-- | ethutil/number/uint_test.go | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/ethutil/number/uint_test.go b/ethutil/number/uint_test.go new file mode 100644 index 000000000..c42989465 --- /dev/null +++ b/ethutil/number/uint_test.go @@ -0,0 +1,92 @@ +package number + +import ( + "math/big" + "testing" + + "github.com/ethereum/go-ethereum/ethutil" +) + +func TestSet(t *testing.T) { + a := Uint(0) + b := Uint(10) + a.Set(b) + if a.num.Cmp(b.num) != 0 { + t.Error("didn't compare", a, b) + } + + c := Uint(0).SetBytes(ethutil.Hex2Bytes("0a")) + if c.num.Cmp(big.NewInt(10)) != 0 { + t.Error("c set bytes failed.") + } +} + +func TestInitialiser(t *testing.T) { + check := false + init := NewInitialiser(func(x *Number) *Number { + check = true + return x + }) + a := init(0).Add(init(1), init(2)) + if a.Cmp(init(3)) != 0 { + t.Error("expected 3. got", a) + } + if !check { + t.Error("expected limiter to be called") + } +} + +func TestGet(t *testing.T) { + a := Uint(10) + if a.Uint64() != 10 { + t.Error("expected to get 10. got", a.Uint64()) + } + + a = Uint(10) + if a.Int64() != 10 { + t.Error("expected to get 10. got", a.Int64()) + } +} + +func TestCmp(t *testing.T) { + a := Uint(10) + b := Uint(10) + c := Uint(11) + + if a.Cmp(b) != 0 { + t.Error("a b == 0 failed", a, b) + } + + if a.Cmp(c) >= 0 { + t.Error("a c < 0 failed", a, c) + } + + if c.Cmp(b) <= 0 { + t.Error("c b > 0 failed", c, b) + } +} + +func TestMaxArith(t *testing.T) { + a := Uint(0).Add(MaxUint256, One) + if a.Cmp(Zero) != 0 { + t.Error("expected max256 + 1 = 0 got", a) + } + + a = Uint(0).Sub(Uint(0), One) + if a.Cmp(MaxUint256) != 0 { + t.Error("expected 0 - 1 = max256 got", a) + } + + a = Int(0).Sub(Int(0), One) + if a.Cmp(MinOne) != 0 { + t.Error("expected 0 - 1 = -1 got", a) + } +} + +func TestConversion(t *testing.T) { + a := Int(-1) + b := a.Uint256() + if b.Cmp(MaxUint256) != 0 { + t.Error("expected -1 => unsigned to return max. got", b) + } +} |