188 lines
5.9 KiB
Go
188 lines
5.9 KiB
Go
|
// 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.
|
||
|
|
||
|
package btcjson_test
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"encoding/json"
|
||
|
"fmt"
|
||
|
"reflect"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/btcsuite/btcd/btcjson"
|
||
|
)
|
||
|
|
||
|
// TestWalletSvrWsNtfns tests all of the chain server websocket-specific
|
||
|
// notifications marshal and unmarshal into valid results include handling of
|
||
|
// optional fields being omitted in the marshalled command, while optional
|
||
|
// fields with defaults have the default assigned on unmarshalled commands.
|
||
|
func TestWalletSvrWsNtfns(t *testing.T) {
|
||
|
t.Parallel()
|
||
|
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
newNtfn func() (interface{}, error)
|
||
|
staticNtfn func() interface{}
|
||
|
marshalled string
|
||
|
unmarshalled interface{}
|
||
|
}{
|
||
|
{
|
||
|
name: "accountbalance",
|
||
|
newNtfn: func() (interface{}, error) {
|
||
|
return btcjson.NewCmd("accountbalance", "acct", 1.25, true)
|
||
|
},
|
||
|
staticNtfn: func() interface{} {
|
||
|
return btcjson.NewAccountBalanceNtfn("acct", 1.25, true)
|
||
|
},
|
||
|
marshalled: `{"jsonrpc":"1.0","method":"accountbalance","params":["acct",1.25,true],"id":null}`,
|
||
|
unmarshalled: &btcjson.AccountBalanceNtfn{
|
||
|
Account: "acct",
|
||
|
Balance: 1.25,
|
||
|
Confirmed: true,
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "btcdconnected",
|
||
|
newNtfn: func() (interface{}, error) {
|
||
|
return btcjson.NewCmd("btcdconnected", true)
|
||
|
},
|
||
|
staticNtfn: func() interface{} {
|
||
|
return btcjson.NewBtcdConnectedNtfn(true)
|
||
|
},
|
||
|
marshalled: `{"jsonrpc":"1.0","method":"btcdconnected","params":[true],"id":null}`,
|
||
|
unmarshalled: &btcjson.BtcdConnectedNtfn{
|
||
|
Connected: true,
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "walletlockstate",
|
||
|
newNtfn: func() (interface{}, error) {
|
||
|
return btcjson.NewCmd("walletlockstate", true)
|
||
|
},
|
||
|
staticNtfn: func() interface{} {
|
||
|
return btcjson.NewWalletLockStateNtfn(true)
|
||
|
},
|
||
|
marshalled: `{"jsonrpc":"1.0","method":"walletlockstate","params":[true],"id":null}`,
|
||
|
unmarshalled: &btcjson.WalletLockStateNtfn{
|
||
|
Locked: true,
|
||
|
},
|
||
|
},
|
||
|
{
|
||
|
name: "newtx",
|
||
|
newNtfn: func() (interface{}, error) {
|
||
|
return btcjson.NewCmd("newtx", "acct", `{"account":"acct","address":"1Address","category":"send","amount":1.5,"bip125-replaceable":"unknown","fee":0.0001,"confirmations":1,"trusted":true,"txid":"456","walletconflicts":[],"time":12345678,"timereceived":12345876,"vout":789,"otheraccount":"otheracct"}`)
|
||
|
},
|
||
|
staticNtfn: func() interface{} {
|
||
|
result := btcjson.ListTransactionsResult{
|
||
|
Abandoned: false,
|
||
|
Account: "acct",
|
||
|
Address: "1Address",
|
||
|
BIP125Replaceable: "unknown",
|
||
|
Category: "send",
|
||
|
Amount: 1.5,
|
||
|
Fee: btcjson.Float64(0.0001),
|
||
|
Confirmations: 1,
|
||
|
TxID: "456",
|
||
|
WalletConflicts: []string{},
|
||
|
Time: 12345678,
|
||
|
TimeReceived: 12345876,
|
||
|
Trusted: true,
|
||
|
Vout: 789,
|
||
|
OtherAccount: "otheracct",
|
||
|
}
|
||
|
return btcjson.NewNewTxNtfn("acct", result)
|
||
|
},
|
||
|
marshalled: `{"jsonrpc":"1.0","method":"newtx","params":["acct",{"abandoned":false,"account":"acct","address":"1Address","amount":1.5,"bip125-replaceable":"unknown","category":"send","confirmations":1,"fee":0.0001,"time":12345678,"timereceived":12345876,"trusted":true,"txid":"456","vout":789,"walletconflicts":[],"otheraccount":"otheracct"}],"id":null}`,
|
||
|
unmarshalled: &btcjson.NewTxNtfn{
|
||
|
Account: "acct",
|
||
|
Details: btcjson.ListTransactionsResult{
|
||
|
Abandoned: false,
|
||
|
Account: "acct",
|
||
|
Address: "1Address",
|
||
|
BIP125Replaceable: "unknown",
|
||
|
Category: "send",
|
||
|
Amount: 1.5,
|
||
|
Fee: btcjson.Float64(0.0001),
|
||
|
Confirmations: 1,
|
||
|
TxID: "456",
|
||
|
WalletConflicts: []string{},
|
||
|
Time: 12345678,
|
||
|
TimeReceived: 12345876,
|
||
|
Trusted: true,
|
||
|
Vout: 789,
|
||
|
OtherAccount: "otheracct",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
|
||
|
t.Logf("Running %d tests", len(tests))
|
||
|
for i, test := range tests {
|
||
|
// Marshal the notification as created by the new static
|
||
|
// creation function. The ID is nil for notifications.
|
||
|
marshalled, err := btcjson.MarshalCmd(nil, test.staticNtfn())
|
||
|
if err != nil {
|
||
|
t.Errorf("MarshalCmd #%d (%s) unexpected error: %v", i,
|
||
|
test.name, err)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
if !bytes.Equal(marshalled, []byte(test.marshalled)) {
|
||
|
t.Errorf("Test #%d (%s) unexpected marshalled data - "+
|
||
|
"got %s, want %s", i, test.name, marshalled,
|
||
|
test.marshalled)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
// Ensure the notification is created without error via the
|
||
|
// generic new notification creation function.
|
||
|
cmd, err := test.newNtfn()
|
||
|
if err != nil {
|
||
|
t.Errorf("Test #%d (%s) unexpected NewCmd error: %v ",
|
||
|
i, test.name, err)
|
||
|
}
|
||
|
|
||
|
// Marshal the notification as created by the generic new
|
||
|
// notification creation function. The ID is nil for
|
||
|
// notifications.
|
||
|
marshalled, err = btcjson.MarshalCmd(nil, cmd)
|
||
|
if err != nil {
|
||
|
t.Errorf("MarshalCmd #%d (%s) unexpected error: %v", i,
|
||
|
test.name, err)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
if !bytes.Equal(marshalled, []byte(test.marshalled)) {
|
||
|
t.Errorf("Test #%d (%s) unexpected marshalled data - "+
|
||
|
"got %s, want %s", i, test.name, marshalled,
|
||
|
test.marshalled)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
var request btcjson.Request
|
||
|
if err := json.Unmarshal(marshalled, &request); err != nil {
|
||
|
t.Errorf("Test #%d (%s) unexpected error while "+
|
||
|
"unmarshalling JSON-RPC request: %v", i,
|
||
|
test.name, err)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
cmd, err = btcjson.UnmarshalCmd(&request)
|
||
|
if err != nil {
|
||
|
t.Errorf("UnmarshalCmd #%d (%s) unexpected error: %v", i,
|
||
|
test.name, err)
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
if !reflect.DeepEqual(cmd, test.unmarshalled) {
|
||
|
t.Errorf("Test #%d (%s) unexpected unmarshalled command "+
|
||
|
"- got %s, want %s", i, test.name,
|
||
|
fmt.Sprintf("(%T) %+[1]v", cmd),
|
||
|
fmt.Sprintf("(%T) %+[1]v\n", test.unmarshalled))
|
||
|
continue
|
||
|
}
|
||
|
}
|
||
|
}
|