forked from TrueCloudLab/neoneo-go
Merge pull request #2674 from nspcc-dev/update-linter-config
Update linter config
This commit is contained in:
commit
457f904b1b
26 changed files with 78 additions and 53 deletions
|
@ -34,7 +34,7 @@ jobs:
|
||||||
- run:
|
- run:
|
||||||
name: go-lint
|
name: go-lint
|
||||||
command: |
|
command: |
|
||||||
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.44.2
|
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.49.0
|
||||||
make lint
|
make lint
|
||||||
|
|
||||||
test_1_17:
|
test_1_17:
|
||||||
|
|
|
@ -32,20 +32,32 @@ linters:
|
||||||
- revive
|
- revive
|
||||||
|
|
||||||
# some default golangci-lint linters
|
# some default golangci-lint linters
|
||||||
- deadcode
|
|
||||||
- errcheck
|
- errcheck
|
||||||
- gosimple
|
- gosimple
|
||||||
- godot
|
- godot
|
||||||
- ineffassign
|
- ineffassign
|
||||||
- staticcheck
|
- staticcheck
|
||||||
- structcheck
|
|
||||||
- typecheck
|
- typecheck
|
||||||
- unused
|
- unused
|
||||||
- varcheck
|
|
||||||
|
|
||||||
# extra linters
|
# extra linters
|
||||||
# - exhaustive
|
# - exhaustive
|
||||||
|
# - goconst
|
||||||
|
# - goerr113
|
||||||
|
# - gomnd
|
||||||
|
# - nonamedreturns
|
||||||
|
# - unparam
|
||||||
|
- bidichk
|
||||||
|
- bodyclose
|
||||||
|
- contextcheck
|
||||||
|
- decorder
|
||||||
|
- durationcheck
|
||||||
|
- errorlint
|
||||||
|
- exportloopref
|
||||||
- gofmt
|
- gofmt
|
||||||
|
- misspell
|
||||||
|
- predeclared
|
||||||
|
- reassign
|
||||||
- whitespace
|
- whitespace
|
||||||
- goimports
|
- goimports
|
||||||
disable-all: true
|
disable-all: true
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
@ -110,7 +111,7 @@ func TestServerStart(t *testing.T) {
|
||||||
var line string
|
var line string
|
||||||
require.Eventually(t, func() bool {
|
require.Eventually(t, func() bool {
|
||||||
line, err = e.Out.ReadString('\n')
|
line, err = e.Out.ReadString('\n')
|
||||||
if err != nil && err != io.EOF {
|
if err != nil && !errors.Is(err, io.EOF) {
|
||||||
t.Fatalf("unexpected error while reading CLI output: %s", err)
|
t.Fatalf("unexpected error while reading CLI output: %s", err)
|
||||||
}
|
}
|
||||||
return err == nil
|
return err == nil
|
||||||
|
|
|
@ -947,7 +947,7 @@ func readWallet(ctx *cli.Context) (*wallet.Wallet, *string, error) {
|
||||||
if path == "-" {
|
if path == "-" {
|
||||||
w := &wallet.Wallet{}
|
w := &wallet.Wallet{}
|
||||||
if err := json.NewDecoder(os.Stdin).Decode(w); err != nil {
|
if err := json.NewDecoder(os.Stdin).Decode(w); err != nil {
|
||||||
return nil, nil, fmt.Errorf("js %s", err)
|
return nil, nil, fmt.Errorf("js %w", err)
|
||||||
}
|
}
|
||||||
return w, nil, nil
|
return w, nil, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -693,15 +693,15 @@ func (bc *Blockchain) Run() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (bc *Blockchain) tryRunGC(old uint32) time.Duration {
|
func (bc *Blockchain) tryRunGC(oldHeight uint32) time.Duration {
|
||||||
var dur time.Duration
|
var dur time.Duration
|
||||||
|
|
||||||
new := atomic.LoadUint32(&bc.persistedHeight)
|
newHeight := atomic.LoadUint32(&bc.persistedHeight)
|
||||||
var tgtBlock = int64(new)
|
var tgtBlock = int64(newHeight)
|
||||||
|
|
||||||
tgtBlock -= int64(bc.config.MaxTraceableBlocks)
|
tgtBlock -= int64(bc.config.MaxTraceableBlocks)
|
||||||
if bc.config.P2PStateExchangeExtensions {
|
if bc.config.P2PStateExchangeExtensions {
|
||||||
syncP := new / uint32(bc.config.StateSyncInterval)
|
syncP := newHeight / uint32(bc.config.StateSyncInterval)
|
||||||
syncP--
|
syncP--
|
||||||
syncP *= uint32(bc.config.StateSyncInterval)
|
syncP *= uint32(bc.config.StateSyncInterval)
|
||||||
if tgtBlock > int64(syncP) {
|
if tgtBlock > int64(syncP) {
|
||||||
|
@ -712,9 +712,9 @@ func (bc *Blockchain) tryRunGC(old uint32) time.Duration {
|
||||||
tgtBlock /= int64(bc.config.GarbageCollectionPeriod)
|
tgtBlock /= int64(bc.config.GarbageCollectionPeriod)
|
||||||
tgtBlock *= int64(bc.config.GarbageCollectionPeriod)
|
tgtBlock *= int64(bc.config.GarbageCollectionPeriod)
|
||||||
// Count periods.
|
// Count periods.
|
||||||
old /= bc.config.GarbageCollectionPeriod
|
oldHeight /= bc.config.GarbageCollectionPeriod
|
||||||
new /= bc.config.GarbageCollectionPeriod
|
newHeight /= bc.config.GarbageCollectionPeriod
|
||||||
if tgtBlock > int64(bc.config.GarbageCollectionPeriod) && new != old {
|
if tgtBlock > int64(bc.config.GarbageCollectionPeriod) && newHeight != oldHeight {
|
||||||
tgtBlock /= int64(bc.config.GarbageCollectionPeriod)
|
tgtBlock /= int64(bc.config.GarbageCollectionPeriod)
|
||||||
tgtBlock *= int64(bc.config.GarbageCollectionPeriod)
|
tgtBlock *= int64(bc.config.GarbageCollectionPeriod)
|
||||||
dur = bc.stateRoot.GC(uint32(tgtBlock), bc.store)
|
dur = bc.stateRoot.GC(uint32(tgtBlock), bc.store)
|
||||||
|
@ -1702,7 +1702,7 @@ func (bc *Blockchain) HasTransaction(hash util.Uint256) bool {
|
||||||
if bc.memPool.ContainsKey(hash) {
|
if bc.memPool.ContainsKey(hash) {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
return bc.dao.HasTransaction(hash) == dao.ErrAlreadyExists
|
return errors.Is(bc.dao.HasTransaction(hash), dao.ErrAlreadyExists)
|
||||||
}
|
}
|
||||||
|
|
||||||
// HasBlock returns true if the blockchain contains the given
|
// HasBlock returns true if the blockchain contains the given
|
||||||
|
@ -1761,7 +1761,7 @@ func (bc *Blockchain) HeaderHeight() uint32 {
|
||||||
// GetContractState returns contract by its script hash.
|
// GetContractState returns contract by its script hash.
|
||||||
func (bc *Blockchain) GetContractState(hash util.Uint160) *state.Contract {
|
func (bc *Blockchain) GetContractState(hash util.Uint160) *state.Contract {
|
||||||
contract, err := bc.contracts.Management.GetContract(bc.dao, hash)
|
contract, err := bc.contracts.Management.GetContract(bc.dao, hash)
|
||||||
if contract == nil && err != storage.ErrKeyNotFound {
|
if contract == nil && !errors.Is(err, storage.ErrKeyNotFound) {
|
||||||
bc.log.Warn("failed to get contract state", zap.Error(err))
|
bc.log.Warn("failed to get contract state", zap.Error(err))
|
||||||
}
|
}
|
||||||
return contract
|
return contract
|
||||||
|
|
|
@ -77,7 +77,7 @@ func TestAddBlock(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRemoveOldTransfers(t *testing.T) {
|
func TestRemoveOldTransfers(t *testing.T) {
|
||||||
// Creating proper number of transfers/blocks takes unneccessary time, so emulate
|
// Creating proper number of transfers/blocks takes unnecessary time, so emulate
|
||||||
// some DB with stale entries.
|
// some DB with stale entries.
|
||||||
bc := newTestChain(t)
|
bc := newTestChain(t)
|
||||||
h, err := bc.GetHeader(bc.GetHeaderHash(0))
|
h, err := bc.GetHeader(bc.GetHeaderHash(0))
|
||||||
|
|
|
@ -176,7 +176,7 @@ func (dao *Simple) GetTokenTransferInfo(acc util.Uint160) (*state.TokenTransferI
|
||||||
key := dao.makeTTIKey(acc)
|
key := dao.makeTTIKey(acc)
|
||||||
bs := state.NewTokenTransferInfo()
|
bs := state.NewTokenTransferInfo()
|
||||||
err := dao.GetAndDecode(bs, key)
|
err := dao.GetAndDecode(bs, key)
|
||||||
if err != nil && err != storage.ErrKeyNotFound {
|
if err != nil && !errors.Is(err, storage.ErrKeyNotFound) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return bs, nil
|
return bs, nil
|
||||||
|
@ -257,7 +257,7 @@ func (dao *Simple) GetTokenTransferLog(acc util.Uint160, newestTimestamp uint64,
|
||||||
key := dao.getTokenTransferLogKey(acc, newestTimestamp, index, isNEP11)
|
key := dao.getTokenTransferLogKey(acc, newestTimestamp, index, isNEP11)
|
||||||
value, err := dao.Store.Get(key)
|
value, err := dao.Store.Get(key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err == storage.ErrKeyNotFound {
|
if errors.Is(err, storage.ErrKeyNotFound) {
|
||||||
return new(state.TokenTransferLog), nil
|
return new(state.TokenTransferLog), nil
|
||||||
}
|
}
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -306,7 +306,7 @@ func (dao *Simple) GetAppExecResults(hash util.Uint256, trig trigger.Type) ([]st
|
||||||
aer := new(state.AppExecResult)
|
aer := new(state.AppExecResult)
|
||||||
aer.DecodeBinary(r)
|
aer.DecodeBinary(r)
|
||||||
if r.Err != nil {
|
if r.Err != nil {
|
||||||
if r.Err == iocore.EOF {
|
if errors.Is(r.Err, iocore.EOF) {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
return nil, r.Err
|
return nil, r.Err
|
||||||
|
@ -828,14 +828,14 @@ func (dao *Simple) StoreAsTransaction(tx *transaction.Transaction, index uint32,
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dao *Simple) getKeyBuf(len int) []byte {
|
func (dao *Simple) getKeyBuf(l int) []byte {
|
||||||
if dao.private {
|
if dao.private {
|
||||||
if dao.keyBuf == nil {
|
if dao.keyBuf == nil {
|
||||||
dao.keyBuf = make([]byte, 0, 1+4+limits.MaxStorageKeyLen) // Prefix, uint32, key.
|
dao.keyBuf = make([]byte, 0, 1+4+limits.MaxStorageKeyLen) // Prefix, uint32, key.
|
||||||
}
|
}
|
||||||
return dao.keyBuf[:len] // Should have enough capacity.
|
return dao.keyBuf[:l] // Should have enough capacity.
|
||||||
}
|
}
|
||||||
return make([]byte, len)
|
return make([]byte, l)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dao *Simple) getDataBuf() *io.BufBinWriter {
|
func (dao *Simple) getDataBuf() *io.BufBinWriter {
|
||||||
|
|
|
@ -37,7 +37,7 @@ type Billet struct {
|
||||||
|
|
||||||
// NewBillet returns a new billet for MPT trie restoring. It accepts a MemCachedStore
|
// NewBillet returns a new billet for MPT trie restoring. It accepts a MemCachedStore
|
||||||
// to decouple storage errors from logic errors so that all storage errors are
|
// to decouple storage errors from logic errors so that all storage errors are
|
||||||
// processed during `store.Persist()` at the caller. Another benifit is
|
// processed during `store.Persist()` at the caller. Another benefit is
|
||||||
// that every `Put` can be considered an atomic operation.
|
// that every `Put` can be considered an atomic operation.
|
||||||
func NewBillet(rootHash util.Uint256, mode TrieMode, prefix storage.KeyPrefix, store *storage.MemCachedStore) *Billet {
|
func NewBillet(rootHash util.Uint256, mode TrieMode, prefix storage.KeyPrefix, store *storage.MemCachedStore) *Billet {
|
||||||
return &Billet{
|
return &Billet{
|
||||||
|
|
|
@ -173,7 +173,7 @@ func (m *Management) getContract(ic *interop.Context, args []stackitem.Item) sta
|
||||||
hash := toHash160(args[0])
|
hash := toHash160(args[0])
|
||||||
ctr, err := m.GetContract(ic.DAO, hash)
|
ctr, err := m.GetContract(ic.DAO, hash)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err == storage.ErrKeyNotFound {
|
if errors.Is(err, storage.ErrKeyNotFound) {
|
||||||
return stackitem.Null{}
|
return stackitem.Null{}
|
||||||
}
|
}
|
||||||
panic(err)
|
panic(err)
|
||||||
|
|
|
@ -469,7 +469,7 @@ func (n *Notary) GetDepositFor(dao *dao.Simple, acc util.Uint160) *state.Deposit
|
||||||
if err == nil {
|
if err == nil {
|
||||||
return deposit
|
return deposit
|
||||||
}
|
}
|
||||||
if err == storage.ErrKeyNotFound {
|
if errors.Is(err, storage.ErrKeyNotFound) {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
panic(fmt.Errorf("failed to get deposit for %s from storage: %w", acc.StringBE(), err))
|
panic(fmt.Errorf("failed to get deposit for %s from storage: %w", acc.StringBE(), err))
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
package storage
|
package storage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core/storage/dbconfig"
|
"github.com/nspcc-dev/neo-go/pkg/core/storage/dbconfig"
|
||||||
"github.com/syndtr/goleveldb/leveldb"
|
"github.com/syndtr/goleveldb/leveldb"
|
||||||
"github.com/syndtr/goleveldb/leveldb/filter"
|
"github.com/syndtr/goleveldb/leveldb/filter"
|
||||||
|
@ -35,7 +37,7 @@ func NewLevelDBStore(cfg dbconfig.LevelDBOptions) (*LevelDBStore, error) {
|
||||||
// Get implements the Store interface.
|
// Get implements the Store interface.
|
||||||
func (s *LevelDBStore) Get(key []byte) ([]byte, error) {
|
func (s *LevelDBStore) Get(key []byte) ([]byte, error) {
|
||||||
value, err := s.db.Get(key, nil)
|
value, err := s.db.Get(key, nil)
|
||||||
if err == leveldb.ErrNotFound {
|
if errors.Is(err, leveldb.ErrNotFound) {
|
||||||
err = ErrKeyNotFound
|
err = ErrKeyNotFound
|
||||||
}
|
}
|
||||||
return value, err
|
return value, err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package neorpc
|
package neorpc
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -125,9 +126,9 @@ func (e *Error) Error() string {
|
||||||
|
|
||||||
// Is denotes whether the error matches the target one.
|
// Is denotes whether the error matches the target one.
|
||||||
func (e *Error) Is(target error) bool {
|
func (e *Error) Is(target error) bool {
|
||||||
clTarget, ok := target.(*Error)
|
var clTarget *Error
|
||||||
if !ok {
|
if errors.As(target, &clTarget) {
|
||||||
return false
|
return e.Code == clTarget.Code
|
||||||
}
|
}
|
||||||
return e.Code == clTarget.Code
|
return false
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,8 +13,8 @@ func TestValidatorUnmarshal(t *testing.T) {
|
||||||
require.NoError(t, json.Unmarshal(old, v))
|
require.NoError(t, json.Unmarshal(old, v))
|
||||||
require.Equal(t, int64(100500), v.Votes)
|
require.Equal(t, int64(100500), v.Votes)
|
||||||
|
|
||||||
new := []byte(`{"publickey":"02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62","votes":42}`)
|
newV := []byte(`{"publickey":"02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62","votes":42}`)
|
||||||
require.NoError(t, json.Unmarshal(new, v))
|
require.NoError(t, json.Unmarshal(newV, v))
|
||||||
require.Equal(t, int64(42), v.Votes)
|
require.Equal(t, int64(42), v.Votes)
|
||||||
|
|
||||||
bad := []byte(`{"publickey":"02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62","votes":"notanumber"}`)
|
bad := []byte(`{"publickey":"02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62","votes":"notanumber"}`)
|
||||||
|
|
|
@ -176,7 +176,7 @@ func (m *Message) decodePayload() error {
|
||||||
}
|
}
|
||||||
r := io.NewBinReaderFromBuf(buf)
|
r := io.NewBinReaderFromBuf(buf)
|
||||||
p.DecodeBinary(r)
|
p.DecodeBinary(r)
|
||||||
if r.Err == nil || r.Err == payload.ErrTooManyHeaders {
|
if r.Err == nil || errors.Is(r.Err, payload.ErrTooManyHeaders) {
|
||||||
m.Payload = p
|
m.Payload = p
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -417,9 +417,9 @@ func (s *Server) run() {
|
||||||
zap.Error(drop.reason),
|
zap.Error(drop.reason),
|
||||||
zap.Int("peerCount", s.PeerCount()))
|
zap.Int("peerCount", s.PeerCount()))
|
||||||
addr := drop.peer.PeerAddr().String()
|
addr := drop.peer.PeerAddr().String()
|
||||||
if drop.reason == errIdenticalID {
|
if errors.Is(drop.reason, errIdenticalID) {
|
||||||
s.discovery.RegisterBadAddr(addr)
|
s.discovery.RegisterBadAddr(addr)
|
||||||
} else if drop.reason == errAlreadyConnected {
|
} else if errors.Is(drop.reason, errAlreadyConnected) {
|
||||||
// There is a race condition when peer can be disconnected twice for the this reason
|
// There is a race condition when peer can be disconnected twice for the this reason
|
||||||
// which can lead to no connections to peer at all. Here we check for such a possibility.
|
// which can lead to no connections to peer at all. Here we check for such a possibility.
|
||||||
stillConnected := false
|
stillConnected := false
|
||||||
|
@ -1380,15 +1380,15 @@ func (s *Server) iteratePeersWithSendMsg(msg *Message, send func(Peer, bool, []b
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
err := send(peer, blocking, pkt)
|
err := send(peer, blocking, pkt)
|
||||||
switch err {
|
if err == nil {
|
||||||
case nil:
|
|
||||||
if msg.Command == CMDGetAddr {
|
if msg.Command == CMDGetAddr {
|
||||||
peer.AddGetAddrSent()
|
peer.AddGetAddrSent()
|
||||||
}
|
}
|
||||||
sentN++
|
sentN++
|
||||||
case errBusy: // Can be retried.
|
} else if errors.Is(err, errBusy) {
|
||||||
|
// Can be retried.
|
||||||
continue
|
continue
|
||||||
default:
|
} else {
|
||||||
deadN++
|
deadN++
|
||||||
}
|
}
|
||||||
finished[i] = true
|
finished[i] = true
|
||||||
|
|
|
@ -170,7 +170,7 @@ func (p *TCPPeer) handleConn() {
|
||||||
msg := &Message{StateRootInHeader: p.server.config.StateRootInHeader}
|
msg := &Message{StateRootInHeader: p.server.config.StateRootInHeader}
|
||||||
err = msg.Decode(r)
|
err = msg.Decode(r)
|
||||||
|
|
||||||
if err == payload.ErrTooManyHeaders {
|
if errors.Is(err, payload.ErrTooManyHeaders) {
|
||||||
p.server.log.Warn("not all headers were processed")
|
p.server.log.Warn("not all headers were processed")
|
||||||
r.Err = nil
|
r.Err = nil
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
|
|
|
@ -90,7 +90,10 @@ var errConnClosedByUser = errors.New("connection closed by user")
|
||||||
// operating on.
|
// operating on.
|
||||||
func NewWS(ctx context.Context, endpoint string, opts Options) (*WSClient, error) {
|
func NewWS(ctx context.Context, endpoint string, opts Options) (*WSClient, error) {
|
||||||
dialer := websocket.Dialer{HandshakeTimeout: opts.DialTimeout}
|
dialer := websocket.Dialer{HandshakeTimeout: opts.DialTimeout}
|
||||||
ws, _, err := dialer.Dial(endpoint, nil)
|
ws, resp, err := dialer.DialContext(ctx, endpoint, nil)
|
||||||
|
if resp != nil && resp.Body != nil { // Can be non-nil even with error returned.
|
||||||
|
defer resp.Body.Close() // Not exactly required by websocket, but let's do this for bodyclose checker.
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package metrics
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"errors"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config"
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
||||||
|
@ -21,7 +22,7 @@ func (ms *Service) Start() {
|
||||||
if ms.config.Enabled {
|
if ms.config.Enabled {
|
||||||
ms.log.Info("service is running", zap.String("endpoint", ms.Addr))
|
ms.log.Info("service is running", zap.String("endpoint", ms.Addr))
|
||||||
err := ms.ListenAndServe()
|
err := ms.ListenAndServe()
|
||||||
if err != nil && err != http.ErrServerClosed {
|
if err != nil && !errors.Is(err, http.ErrServerClosed) {
|
||||||
ms.log.Warn("service couldn't start on configured port")
|
ms.log.Warn("service couldn't start on configured port")
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -40,7 +40,7 @@ func TestDefaultClient_RestrictedRedirectErr(t *testing.T) {
|
||||||
}
|
}
|
||||||
for _, c := range testCases {
|
for _, c := range testCases {
|
||||||
t.Run(c, func(t *testing.T) {
|
t.Run(c, func(t *testing.T) {
|
||||||
_, err := cl.Get(c)
|
_, err := cl.Get(c) //nolint:bodyclose // It errors out and it's a test.
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
require.True(t, errors.Is(err, ErrRestrictedRedirect), err)
|
require.True(t, errors.Is(err, ErrRestrictedRedirect), err)
|
||||||
require.True(t, strings.Contains(err.Error(), "IP is not global unicast"), err)
|
require.True(t, strings.Contains(err.Error(), "IP is not global unicast"), err)
|
||||||
|
|
|
@ -138,6 +138,7 @@ func (o *Oracle) processRequest(priv *keys.PrivateKey, req request) error {
|
||||||
o.Log.Warn("oracle request failed", zap.String("url", req.Req.URL), zap.Error(err), zap.Stringer("code", resp.Code))
|
o.Log.Warn("oracle request failed", zap.String("url", req.Req.URL), zap.Error(err), zap.Stringer("code", resp.Code))
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
defer r.Body.Close()
|
||||||
switch r.StatusCode {
|
switch r.StatusCode {
|
||||||
case http.StatusOK:
|
case http.StatusOK:
|
||||||
if !checkMediaType(r.Header.Get("Content-Type"), o.MainCfg.AllowedContentTypes) {
|
if !checkMediaType(r.Header.Get("Content-Type"), o.MainCfg.AllowedContentTypes) {
|
||||||
|
|
|
@ -67,11 +67,9 @@ func (o *Oracle) AddResponse(pub *keys.PublicKey, reqID uint64, txSig []byte) {
|
||||||
var ErrResponseTooLarge = errors.New("too big response")
|
var ErrResponseTooLarge = errors.New("too big response")
|
||||||
|
|
||||||
func readResponse(rc gio.ReadCloser, limit int) ([]byte, error) {
|
func readResponse(rc gio.ReadCloser, limit int) ([]byte, error) {
|
||||||
defer rc.Close()
|
|
||||||
|
|
||||||
buf := make([]byte, limit+1)
|
buf := make([]byte, limit+1)
|
||||||
n, err := gio.ReadFull(rc, buf)
|
n, err := gio.ReadFull(rc, buf)
|
||||||
if err == gio.ErrUnexpectedEOF && n <= limit {
|
if errors.Is(err, gio.ErrUnexpectedEOF) && n <= limit {
|
||||||
return buf[:n], nil
|
return buf[:n], nil
|
||||||
}
|
}
|
||||||
if err == nil || n > limit {
|
if err == nil || n > limit {
|
||||||
|
|
|
@ -340,7 +340,7 @@ func (s *Server) Start() {
|
||||||
}
|
}
|
||||||
s.https.Addr = ln.Addr().String()
|
s.https.Addr = ln.Addr().String()
|
||||||
err = s.https.ServeTLS(ln, cfg.CertFile, cfg.KeyFile)
|
err = s.https.ServeTLS(ln, cfg.CertFile, cfg.KeyFile)
|
||||||
if err != http.ErrServerClosed {
|
if !errors.Is(err, http.ErrServerClosed) {
|
||||||
s.log.Error("failed to start TLS RPC server", zap.Error(err))
|
s.log.Error("failed to start TLS RPC server", zap.Error(err))
|
||||||
s.errChan <- err
|
s.errChan <- err
|
||||||
}
|
}
|
||||||
|
@ -354,7 +354,7 @@ func (s *Server) Start() {
|
||||||
s.Addr = ln.Addr().String() // set Addr to the actual address
|
s.Addr = ln.Addr().String() // set Addr to the actual address
|
||||||
go func() {
|
go func() {
|
||||||
err = s.Serve(ln)
|
err = s.Serve(ln)
|
||||||
if err != http.ErrServerClosed {
|
if !errors.Is(err, http.ErrServerClosed) {
|
||||||
s.log.Error("failed to start RPC server", zap.Error(err))
|
s.log.Error("failed to start RPC server", zap.Error(err))
|
||||||
s.errChan <- err
|
s.errChan <- err
|
||||||
}
|
}
|
||||||
|
|
|
@ -2633,8 +2633,9 @@ func checkErrGetBatchResult(t *testing.T, body []byte, expectingFail bool) json.
|
||||||
func doRPCCallOverWS(rpcCall string, url string, t *testing.T) []byte {
|
func doRPCCallOverWS(rpcCall string, url string, t *testing.T) []byte {
|
||||||
dialer := websocket.Dialer{HandshakeTimeout: time.Second}
|
dialer := websocket.Dialer{HandshakeTimeout: time.Second}
|
||||||
url = "ws" + strings.TrimPrefix(url, "http")
|
url = "ws" + strings.TrimPrefix(url, "http")
|
||||||
c, _, err := dialer.Dial(url+"/ws", nil)
|
c, r, err := dialer.Dial(url+"/ws", nil)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
defer r.Body.Close()
|
||||||
err = c.SetWriteDeadline(time.Now().Add(time.Second))
|
err = c.SetWriteDeadline(time.Now().Add(time.Second))
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NoError(t, c.WriteMessage(1, []byte(rpcCall)))
|
require.NoError(t, c.WriteMessage(1, []byte(rpcCall)))
|
||||||
|
@ -2651,6 +2652,7 @@ func doRPCCallOverHTTP(rpcCall string, url string, t *testing.T) []byte {
|
||||||
resp, err := cl.Post(url, "application/json", strings.NewReader(rpcCall))
|
resp, err := cl.Post(url, "application/json", strings.NewReader(rpcCall))
|
||||||
require.NoErrorf(t, err, "could not make a POST request")
|
require.NoErrorf(t, err, "could not make a POST request")
|
||||||
body, err := gio.ReadAll(resp.Body)
|
body, err := gio.ReadAll(resp.Body)
|
||||||
|
resp.Body.Close()
|
||||||
assert.NoErrorf(t, err, "could not read response from the request: %s", rpcCall)
|
assert.NoErrorf(t, err, "could not read response from the request: %s", rpcCall)
|
||||||
return bytes.TrimSpace(body)
|
return bytes.TrimSpace(body)
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,8 +59,9 @@ func initCleanServerAndWSClient(t *testing.T) (*core.Blockchain, *Server, *webso
|
||||||
|
|
||||||
dialer := websocket.Dialer{HandshakeTimeout: time.Second}
|
dialer := websocket.Dialer{HandshakeTimeout: time.Second}
|
||||||
url := "ws" + strings.TrimPrefix(httpSrv.URL, "http") + "/ws"
|
url := "ws" + strings.TrimPrefix(httpSrv.URL, "http") + "/ws"
|
||||||
ws, _, err := dialer.Dial(url, nil)
|
ws, r, err := dialer.Dial(url, nil)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
defer r.Body.Close()
|
||||||
|
|
||||||
// Use buffered channel to read server's messages and then read expected
|
// Use buffered channel to read server's messages and then read expected
|
||||||
// responses from it.
|
// responses from it.
|
||||||
|
@ -520,7 +521,10 @@ func TestWSClientsLimit(t *testing.T) {
|
||||||
wss := make([]*websocket.Conn, maxSubscribers)
|
wss := make([]*websocket.Conn, maxSubscribers)
|
||||||
|
|
||||||
for i := 0; i < len(wss)+1; i++ {
|
for i := 0; i < len(wss)+1; i++ {
|
||||||
ws, _, err := dialer.Dial(url, nil)
|
ws, r, err := dialer.Dial(url, nil)
|
||||||
|
if r != nil && r.Body != nil {
|
||||||
|
defer r.Body.Close()
|
||||||
|
}
|
||||||
if i < maxSubscribers {
|
if i < maxSubscribers {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
wss[i] = ws
|
wss[i] = ws
|
||||||
|
|
|
@ -678,7 +678,7 @@ func (c *VMCLI) Run() error {
|
||||||
l := getReadlineInstanceFromContext(c.shell)
|
l := getReadlineInstanceFromContext(c.shell)
|
||||||
for {
|
for {
|
||||||
line, err := l.Readline()
|
line, err := l.Readline()
|
||||||
if err == io.EOF || err == readline.ErrInterrupt {
|
if errors.Is(err, io.EOF) || errors.Is(err, readline.ErrInterrupt) {
|
||||||
return nil // OK, stop execution.
|
return nil // OK, stop execution.
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -169,7 +169,7 @@ func FromJSON(data []byte, maxCount int) (Item, error) {
|
||||||
d.UseNumber()
|
d.UseNumber()
|
||||||
if item, err := d.decode(); err != nil {
|
if item, err := d.decode(); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
} else if _, err := d.Token(); err != gio.EOF {
|
} else if _, err := d.Token(); !errors.Is(err, gio.EOF) {
|
||||||
return nil, fmt.Errorf("%w: unexpected items", ErrInvalidValue)
|
return nil, fmt.Errorf("%w: unexpected items", ErrInvalidValue)
|
||||||
} else {
|
} else {
|
||||||
return item, nil
|
return item, nil
|
||||||
|
|
Loading…
Reference in a new issue