You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
205 lines
5.8 KiB
205 lines
5.8 KiB
// 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 |
|
} |
|
} |
|
}
|
|
|