d26aaffb2b
Create GenerateCmd in btcjson v2. Update tests to check GenerateCmd. Update chaincfg/params.go with a new bool in Params, GenerateSupported, with true values in SimNetParams and RegressionNetParams and false in the others. Create new flag, discreteMining, in CPUMiner struct. Add GenerateNBlocks function to cpuminer.go and handleGenerate function to rpcserver.go. Update documentation for the RPC calls.
205 lines
5.8 KiB
Go
205 lines
5.8 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"
|
|
)
|
|
|
|
// TestBtcdExtCmds tests all of the btcd extended commands 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 TestBtcdExtCmds(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testID := int(1)
|
|
tests := []struct {
|
|
name string
|
|
newCmd func() (interface{}, error)
|
|
staticCmd func() interface{}
|
|
marshalled string
|
|
unmarshalled interface{}
|
|
}{
|
|
{
|
|
name: "debuglevel",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("debuglevel", "trace")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewDebugLevelCmd("trace")
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"debuglevel","params":["trace"],"id":1}`,
|
|
unmarshalled: &btcjson.DebugLevelCmd{
|
|
LevelSpec: "trace",
|
|
},
|
|
},
|
|
{
|
|
name: "node",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("node", btcjson.NRemove, "1.1.1.1")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewNodeCmd("remove", "1.1.1.1", nil)
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"node","params":["remove","1.1.1.1"],"id":1}`,
|
|
unmarshalled: &btcjson.NodeCmd{
|
|
SubCmd: btcjson.NRemove,
|
|
Target: "1.1.1.1",
|
|
},
|
|
},
|
|
{
|
|
name: "node",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("node", btcjson.NDisconnect, "1.1.1.1")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewNodeCmd("disconnect", "1.1.1.1", nil)
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"node","params":["disconnect","1.1.1.1"],"id":1}`,
|
|
unmarshalled: &btcjson.NodeCmd{
|
|
SubCmd: btcjson.NDisconnect,
|
|
Target: "1.1.1.1",
|
|
},
|
|
},
|
|
{
|
|
name: "node",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("node", btcjson.NConnect, "1.1.1.1", "perm")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewNodeCmd("connect", "1.1.1.1", btcjson.String("perm"))
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"node","params":["connect","1.1.1.1","perm"],"id":1}`,
|
|
unmarshalled: &btcjson.NodeCmd{
|
|
SubCmd: btcjson.NConnect,
|
|
Target: "1.1.1.1",
|
|
ConnectSubCmd: btcjson.String("perm"),
|
|
},
|
|
},
|
|
{
|
|
name: "node",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("node", btcjson.NConnect, "1.1.1.1", "temp")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewNodeCmd("connect", "1.1.1.1", btcjson.String("temp"))
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"node","params":["connect","1.1.1.1","temp"],"id":1}`,
|
|
unmarshalled: &btcjson.NodeCmd{
|
|
SubCmd: btcjson.NConnect,
|
|
Target: "1.1.1.1",
|
|
ConnectSubCmd: btcjson.String("temp"),
|
|
},
|
|
},
|
|
{
|
|
name: "generate",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("generate", 1)
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewGenerateCmd(1)
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"generate","params":[1],"id":1}`,
|
|
unmarshalled: &btcjson.GenerateCmd{
|
|
NumBlocks: 1,
|
|
},
|
|
},
|
|
{
|
|
name: "getbestblock",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("getbestblock")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewGetBestBlockCmd()
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"getbestblock","params":[],"id":1}`,
|
|
unmarshalled: &btcjson.GetBestBlockCmd{},
|
|
},
|
|
{
|
|
name: "getcurrentnet",
|
|
newCmd: func() (interface{}, error) {
|
|
return btcjson.NewCmd("getcurrentnet")
|
|
},
|
|
staticCmd: func() interface{} {
|
|
return btcjson.NewGetCurrentNetCmd()
|
|
},
|
|
marshalled: `{"jsonrpc":"1.0","method":"getcurrentnet","params":[],"id":1}`,
|
|
unmarshalled: &btcjson.GetCurrentNetCmd{},
|
|
},
|
|
}
|
|
|
|
t.Logf("Running %d tests", len(tests))
|
|
for i, test := range tests {
|
|
// Marshal the command as created by the new static command
|
|
// creation function.
|
|
marshalled, err := btcjson.MarshalCmd(testID, test.staticCmd())
|
|
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 command is created without error via the generic
|
|
// new command creation function.
|
|
cmd, err := test.newCmd()
|
|
if err != nil {
|
|
t.Errorf("Test #%d (%s) unexpected NewCmd error: %v ",
|
|
i, test.name, err)
|
|
}
|
|
|
|
// Marshal the command as created by the generic new command
|
|
// creation function.
|
|
marshalled, err = btcjson.MarshalCmd(testID, 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
|
|
}
|
|
}
|
|
}
|