kaspad/network/rpc/model/error_test.go
stasatdaglabs 8a4ece1101
[NOD-1223] Reorganize project (#868)
* [NOD-1223] Move all network stuff into a new network package.

* [NOD-1223] Delete the unused package testutil.

* [NOD-1223] Move infrastructure stuff into a new instrastructure package.

* [NOD-1223] Move domain stuff into a new domain package.
2020-08-13 17:27:25 +03:00

81 lines
2.0 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 model_test
import (
"testing"
"github.com/kaspanet/kaspad/network/rpc/model"
)
// TestErrorCodeStringer tests the stringized output for the ErrorCode type.
func TestErrorCodeStringer(t *testing.T) {
t.Parallel()
tests := []struct {
in model.ErrorCode
want string
}{
{model.ErrDuplicateMethod, "ErrDuplicateMethod"},
{model.ErrInvalidUsageFlags, "ErrInvalidUsageFlags"},
{model.ErrInvalidType, "ErrInvalidType"},
{model.ErrEmbeddedType, "ErrEmbeddedType"},
{model.ErrUnexportedField, "ErrUnexportedField"},
{model.ErrUnsupportedFieldType, "ErrUnsupportedFieldType"},
{model.ErrNonOptionalField, "ErrNonOptionalField"},
{model.ErrNonOptionalDefault, "ErrNonOptionalDefault"},
{model.ErrMismatchedDefault, "ErrMismatchedDefault"},
{model.ErrUnregisteredMethod, "ErrUnregisteredMethod"},
{model.ErrNumParams, "ErrNumParams"},
{model.ErrMissingDescription, "ErrMissingDescription"},
{0xffff, "Unknown ErrorCode (65535)"},
}
// Detect additional error codes that don't have the stringer added.
if len(tests)-1 != int(model.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 model.Error
want string
}{
{
model.Error{Description: "some error"},
"some error",
},
{
model.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
}
}
}