2015-12-01 19:44:58 +01:00
|
|
|
// Copyright (c) 2014 The btcsuite developers
|
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
2014-11-04 18:22:13 +01:00
|
|
|
|
|
|
|
package votingpool
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
2015-02-23 17:07:12 +01:00
|
|
|
"reflect"
|
2014-11-04 18:22:13 +01:00
|
|
|
"runtime"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/btcsuite/btclog"
|
2017-06-06 02:54:35 +02:00
|
|
|
"github.com/roasbeef/btcwallet/waddrmgr"
|
|
|
|
"github.com/roasbeef/btcwallet/walletdb"
|
2014-11-04 18:22:13 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
runtime.GOMAXPROCS(runtime.NumCPU())
|
|
|
|
|
|
|
|
// Enable logging (Debug level) to aid debugging failing tests.
|
2017-06-20 14:59:42 +02:00
|
|
|
logger := btclog.NewBackend(os.Stdout).Logger("TEST")
|
|
|
|
logger.SetLevel(btclog.LevelDebug)
|
2014-11-04 18:22:13 +01:00
|
|
|
UseLogger(logger)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TstCheckError ensures the passed error is a votingpool.Error with an error
|
|
|
|
// code that matches the passed error code.
|
|
|
|
func TstCheckError(t *testing.T, testName string, gotErr error, wantErrCode ErrorCode) {
|
|
|
|
vpErr, ok := gotErr.(Error)
|
|
|
|
if !ok {
|
|
|
|
t.Errorf("%s: unexpected error type - got %T (%s), want %T",
|
|
|
|
testName, gotErr, gotErr, Error{})
|
|
|
|
}
|
|
|
|
if vpErr.ErrorCode != wantErrCode {
|
|
|
|
t.Errorf("%s: unexpected error code - got %s (%s), want %s",
|
|
|
|
testName, vpErr.ErrorCode, vpErr, wantErrCode)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TstRunWithManagerUnlocked calls the given callback with the manager unlocked,
|
|
|
|
// and locks it again before returning.
|
2017-01-19 21:24:57 +01:00
|
|
|
func TstRunWithManagerUnlocked(t *testing.T, mgr *waddrmgr.Manager, addrmgrNs walletdb.ReadBucket, callback func()) {
|
|
|
|
if err := mgr.Unlock(addrmgrNs, privPassphrase); err != nil {
|
2014-11-04 18:22:13 +01:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer mgr.Lock()
|
|
|
|
callback()
|
|
|
|
}
|
|
|
|
|
2015-02-23 17:07:12 +01:00
|
|
|
// TstCheckWithdrawalStatusMatches compares s1 and s2 using reflect.DeepEqual
|
|
|
|
// and calls t.Fatal() if they're not identical.
|
|
|
|
func TstCheckWithdrawalStatusMatches(t *testing.T, s1, s2 WithdrawalStatus) {
|
|
|
|
if s1.Fees() != s2.Fees() {
|
|
|
|
t.Fatalf("Wrong amount of network fees; want %d, got %d", s1.Fees(), s2.Fees())
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(s1.Sigs(), s2.Sigs()) {
|
|
|
|
t.Fatalf("Wrong tx signatures; got %x, want %x", s1.Sigs(), s2.Sigs())
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(s1.NextInputAddr(), s2.NextInputAddr()) {
|
|
|
|
t.Fatalf("Wrong NextInputAddr; got %v, want %v", s1.NextInputAddr(), s2.NextInputAddr())
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(s1.NextChangeAddr(), s2.NextChangeAddr()) {
|
|
|
|
t.Fatalf("Wrong NextChangeAddr; got %v, want %v", s1.NextChangeAddr(), s2.NextChangeAddr())
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(s1.Outputs(), s2.Outputs()) {
|
|
|
|
t.Fatalf("Wrong WithdrawalOutputs; got %v, want %v", s1.Outputs(), s2.Outputs())
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(s1.transactions, s2.transactions) {
|
|
|
|
t.Fatalf("Wrong transactions; got %v, want %v", s1.transactions, s2.transactions)
|
|
|
|
}
|
|
|
|
|
|
|
|
// The above checks could be replaced by this one, but when they fail the
|
|
|
|
// failure msg wouldn't give us much clue as to what is not equal, so we do
|
|
|
|
// the individual checks above and use this one as a catch-all check in case
|
|
|
|
// we forget to check any of the individual fields.
|
|
|
|
if !reflect.DeepEqual(s1, s2) {
|
|
|
|
t.Fatalf("Wrong WithdrawalStatus; got %v, want %v", s1, s2)
|
|
|
|
}
|
|
|
|
}
|