Merge pull request #2674 from nspcc-dev/update-linter-config

Update linter config
This commit is contained in:
Roman Khimov 2022-09-02 20:17:58 +03:00 committed by GitHub
commit 457f904b1b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
26 changed files with 78 additions and 53 deletions

View file

@ -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:

View file

@ -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

View file

@ -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

View file

@ -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
} }

View file

@ -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

View file

@ -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))

View file

@ -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 {

View file

@ -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{

View file

@ -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)

View file

@ -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))

View file

@ -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

View file

@ -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
}

View file

@ -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"}`)

View file

@ -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
} }

View file

@ -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

View file

@ -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 {

View file

@ -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
} }

View file

@ -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 {

View file

@ -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)

View file

@ -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) {

View file

@ -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 {

View file

@ -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
} }

View file

@ -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)
} }

View file

@ -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

View file

@ -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 {

View file

@ -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