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.
81 lines
2.1 KiB
81 lines
2.1 KiB
9 years ago
|
// 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 (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/btcsuite/btcd/btcjson"
|
||
|
)
|
||
|
|
||
|
// TestErrorCodeStringer tests the stringized output for the ErrorCode type.
|
||
|
func TestErrorCodeStringer(t *testing.T) {
|
||
|
t.Parallel()
|
||
|
|
||
|
tests := []struct {
|
||
|
in btcjson.ErrorCode
|
||
|
want string
|
||
|
}{
|
||
|
{btcjson.ErrDuplicateMethod, "ErrDuplicateMethod"},
|
||
|
{btcjson.ErrInvalidUsageFlags, "ErrInvalidUsageFlags"},
|
||
|
{btcjson.ErrInvalidType, "ErrInvalidType"},
|
||
|
{btcjson.ErrEmbeddedType, "ErrEmbeddedType"},
|
||
|
{btcjson.ErrUnexportedField, "ErrUnexportedField"},
|
||
|
{btcjson.ErrUnsupportedFieldType, "ErrUnsupportedFieldType"},
|
||
|
{btcjson.ErrNonOptionalField, "ErrNonOptionalField"},
|
||
|
{btcjson.ErrNonOptionalDefault, "ErrNonOptionalDefault"},
|
||
|
{btcjson.ErrMismatchedDefault, "ErrMismatchedDefault"},
|
||
|
{btcjson.ErrUnregisteredMethod, "ErrUnregisteredMethod"},
|
||
|
{btcjson.ErrNumParams, "ErrNumParams"},
|
||
|
{btcjson.ErrMissingDescription, "ErrMissingDescription"},
|
||
|
{0xffff, "Unknown ErrorCode (65535)"},
|
||
|
}
|
||
|
|
||
|
// Detect additional error codes that don't have the stringer added.
|
||
|
if len(tests)-1 != int(btcjson.TstNumErrorCodes) {
|
||
|
t.Errorf("It appears an error code was added without adding an " +
|
||
|
"associated stringer test")
|
||
|
}
|
||
|
|
||
|
t.Logf("Running %d tests", len(tests))
|
||
|
for i, test := range tests {
|
||
|
result := test.in.String()
|
||
|
if result != test.want {
|
||
|
t.Errorf("String #%d\n got: %s want: %s", i, result,
|
||
|
test.want)
|
||
|
continue
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// TestError tests the error output for the Error type.
|
||
|
func TestError(t *testing.T) {
|
||
|
t.Parallel()
|
||
|
|
||
|
tests := []struct {
|
||
|
in btcjson.Error
|
||
|
want string
|
||
|
}{
|
||
|
{
|
||
|
btcjson.Error{Description: "some error"},
|
||
|
"some error",
|
||
|
},
|
||
|
{
|
||
|
btcjson.Error{Description: "human-readable error"},
|
||
|
"human-readable error",
|
||
|
},
|
||
|
}
|
||
|
|
||
|
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
|
||
|
}
|
||
|
}
|
||
|
}
|