mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-06-06 14:16:43 +00:00

* [NOD-510] Change coinbase flags to kaspad. * [NOD-510] Removed superfluous spaces after periods in comments. * [NOD-510] Rename btcd -> kaspad in the root folder. * [NOD-510] Rename BtcEncode -> KaspaEncode and BtcDecode -> KaspaDecode. * [NOD-510] Rename BtcEncode -> KaspaEncode and BtcDecode -> KaspaDecode. * [NOD-510] Continue renaming btcd -> kaspad. * [NOD-510] Rename btcjson -> kaspajson. * [NOD-510] Rename file names inside kaspajson. * [NOD-510] Rename kaspajson -> jsonrpc. * [NOD-510] Finish renaming in addrmgr. * [NOD-510] Rename package btcec to ecc. * [NOD-510] Finish renaming stuff in blockdag. * [NOD-510] Rename stuff in cmd. * [NOD-510] Rename stuff in config. * [NOD-510] Rename stuff in connmgr. * [NOD-510] Rename stuff in dagconfig. * [NOD-510] Rename stuff in database. * [NOD-510] Rename stuff in docker. * [NOD-510] Rename stuff in integration. * [NOD-510] Rename jsonrpc to rpcmodel. * [NOD-510] Rename stuff in limits. * [NOD-510] Rename stuff in logger. * [NOD-510] Rename stuff in mempool. * [NOD-510] Rename stuff in mining. * [NOD-510] Rename stuff in netsync. * [NOD-510] Rename stuff in peer. * [NOD-510] Rename stuff in release. * [NOD-510] Rename stuff in rpcclient. * [NOD-510] Rename stuff in server. * [NOD-510] Rename stuff in signal. * [NOD-510] Rename stuff in txscript. * [NOD-510] Rename stuff in util. * [NOD-510] Rename stuff in wire. * [NOD-510] Fix failing tests. * [NOD-510] Fix merge errors. * [NOD-510] Fix go vet errors. * [NOD-510] Remove merged file that's no longer relevant. * [NOD-510] Add a comment above Op0. * [NOD-510] Fix some comments referencing Bitcoin Core. * [NOD-510] Fix some more comments referencing Bitcoin Core. * [NOD-510] Fix bitcoin -> kaspa. * [NOD-510] Fix more bitcoin -> kaspa. * [NOD-510] Fix comments, remove DisconnectBlock in addrindex. * [NOD-510] Rename KSPD to KASD. * [NOD-510] Fix comments and user agent.
162 lines
4.1 KiB
Go
162 lines
4.1 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 rpcmodel_test
|
|
|
|
import (
|
|
"encoding/json"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/kaspanet/kaspad/rpcmodel"
|
|
)
|
|
|
|
// TestIsValidIDType ensures the IsValidIDType function behaves as expected.
|
|
func TestIsValidIDType(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
tests := []struct {
|
|
name string
|
|
id interface{}
|
|
isValid bool
|
|
}{
|
|
{"int", int(1), true},
|
|
{"int8", int8(1), true},
|
|
{"int16", int16(1), true},
|
|
{"int32", int32(1), true},
|
|
{"int64", int64(1), true},
|
|
{"uint", uint(1), true},
|
|
{"uint8", uint8(1), true},
|
|
{"uint16", uint16(1), true},
|
|
{"uint32", uint32(1), true},
|
|
{"uint64", uint64(1), true},
|
|
{"string", "1", true},
|
|
{"nil", nil, true},
|
|
{"float32", float32(1), true},
|
|
{"float64", float64(1), true},
|
|
{"bool", true, false},
|
|
{"chan int", make(chan int), false},
|
|
{"complex64", complex64(1), false},
|
|
{"complex128", complex128(1), false},
|
|
{"func", func() {}, false},
|
|
}
|
|
|
|
t.Logf("Running %d tests", len(tests))
|
|
for i, test := range tests {
|
|
if rpcmodel.IsValidIDType(test.id) != test.isValid {
|
|
t.Errorf("Test #%d (%s) valid mismatch - got %v, "+
|
|
"want %v", i, test.name, !test.isValid,
|
|
test.isValid)
|
|
continue
|
|
}
|
|
}
|
|
}
|
|
|
|
// TestMarshalResponse ensures the MarshalResponse function works as expected.
|
|
func TestMarshalResponse(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
testID := 1
|
|
tests := []struct {
|
|
name string
|
|
result interface{}
|
|
jsonErr *rpcmodel.RPCError
|
|
expected []byte
|
|
}{
|
|
{
|
|
name: "ordinary bool result with no error",
|
|
result: true,
|
|
jsonErr: nil,
|
|
expected: []byte(`{"result":true,"error":null,"id":1}`),
|
|
},
|
|
{
|
|
name: "result with error",
|
|
result: nil,
|
|
jsonErr: func() *rpcmodel.RPCError {
|
|
return rpcmodel.NewRPCError(rpcmodel.ErrRPCBlockNotFound, "123 not found")
|
|
}(),
|
|
expected: []byte(`{"result":null,"error":{"code":-5,"message":"123 not found"},"id":1}`),
|
|
},
|
|
}
|
|
|
|
t.Logf("Running %d tests", len(tests))
|
|
for i, test := range tests {
|
|
_, _ = i, test
|
|
marshalled, err := rpcmodel.MarshalResponse(testID, test.result, test.jsonErr)
|
|
if err != nil {
|
|
t.Errorf("Test #%d (%s) unexpected error: %v", i,
|
|
test.name, err)
|
|
continue
|
|
}
|
|
|
|
if !reflect.DeepEqual(marshalled, test.expected) {
|
|
t.Errorf("Test #%d (%s) mismatched result - got %s, "+
|
|
"want %s", i, test.name, marshalled,
|
|
test.expected)
|
|
}
|
|
}
|
|
}
|
|
|
|
// TestMiscErrors tests a few error conditions not covered elsewhere.
|
|
func TestMiscErrors(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
// Force an error in NewRequest by giving it a parameter type that is
|
|
// not supported.
|
|
_, err := rpcmodel.NewRequest(nil, "test", []interface{}{make(chan int)})
|
|
if err == nil {
|
|
t.Error("NewRequest: did not receive error")
|
|
return
|
|
}
|
|
|
|
// Force an error in MarshalResponse by giving it an id type that is not
|
|
// supported.
|
|
wantErr := rpcmodel.Error{ErrorCode: rpcmodel.ErrInvalidType}
|
|
_, err = rpcmodel.MarshalResponse(make(chan int), nil, nil)
|
|
if jerr, ok := err.(rpcmodel.Error); !ok || jerr.ErrorCode != wantErr.ErrorCode {
|
|
t.Errorf("MarshalResult: did not receive expected error - got "+
|
|
"%v (%[1]T), want %v (%[2]T)", err, wantErr)
|
|
return
|
|
}
|
|
|
|
// Force an error in MarshalResponse by giving it a result type that
|
|
// can't be marshalled.
|
|
_, err = rpcmodel.MarshalResponse(1, make(chan int), nil)
|
|
if _, ok := err.(*json.UnsupportedTypeError); !ok {
|
|
wantErr := &json.UnsupportedTypeError{}
|
|
t.Errorf("MarshalResult: did not receive expected error - got "+
|
|
"%v (%[1]T), want %T", err, wantErr)
|
|
return
|
|
}
|
|
}
|
|
|
|
// TestRPCError tests the error output for the RPCError type.
|
|
func TestRPCError(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
tests := []struct {
|
|
in *rpcmodel.RPCError
|
|
want string
|
|
}{
|
|
{
|
|
rpcmodel.ErrRPCInvalidRequest,
|
|
"-32600: Invalid request",
|
|
},
|
|
{
|
|
rpcmodel.ErrRPCMethodNotFound,
|
|
"-32601: Method not found",
|
|
},
|
|
}
|
|
|
|
t.Logf("Running %d tests", len(tests))
|
|
for i, test := range tests {
|
|
result := test.in.Error()
|
|
if result != test.want {
|
|
t.Errorf("Error #%d\n got: %s want: %s", i, result,
|
|
test.want)
|
|
continue
|
|
}
|
|
}
|
|
}
|