2014-03-11 22:33:56 -04:00
|
|
|
// Copyright (c) 2014 Conformal Systems LLC.
|
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package btcchain_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math/big"
|
|
|
|
"testing"
|
2014-07-02 18:04:59 +02:00
|
|
|
|
|
|
|
"github.com/conformal/btcchain"
|
2014-03-11 22:33:56 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestBigToCompact(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
in int64
|
|
|
|
out uint32
|
|
|
|
}{
|
|
|
|
{0, 0},
|
|
|
|
{-1, 25231360},
|
|
|
|
}
|
|
|
|
|
|
|
|
for x, test := range tests {
|
|
|
|
n := big.NewInt(test.in)
|
|
|
|
r := btcchain.BigToCompact(n)
|
|
|
|
if r != test.out {
|
|
|
|
t.Errorf("TestBigToCompact test #%d failed: got %d want %d\n",
|
|
|
|
x, r, test.out)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCompactToBig(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
in uint32
|
|
|
|
out int64
|
|
|
|
}{
|
|
|
|
{10000000, 0},
|
|
|
|
}
|
|
|
|
|
|
|
|
for x, test := range tests {
|
|
|
|
n := btcchain.CompactToBig(test.in)
|
|
|
|
want := big.NewInt(test.out)
|
|
|
|
if n.Cmp(want) != 0 {
|
|
|
|
t.Errorf("TestCompactToBig test #%d failed: got %d want %d\n",
|
|
|
|
x, n.Int64(), want.Int64())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCalcWork(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
in uint32
|
|
|
|
out int64
|
|
|
|
}{
|
|
|
|
{10000000, 0},
|
|
|
|
}
|
|
|
|
|
|
|
|
for x, test := range tests {
|
|
|
|
bits := uint32(test.in)
|
|
|
|
|
|
|
|
r := btcchain.CalcWork(bits)
|
|
|
|
if r.Int64() != test.out {
|
|
|
|
t.Errorf("TestCalcWork test #%d failed: got %v want %d\n",
|
|
|
|
x, r.Int64(), test.out)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|