From 7790d9b6f0734aab403434824a96e3713df6aa82 Mon Sep 17 00:00:00 2001 From: Adrian Gallagher Date: Thu, 8 Feb 2024 14:13:08 +1100 Subject: [PATCH 1/4] CI/build: Update Go version, linters and fix minor issues --- .github/workflows/arm64.Dockerfile | 2 +- .github/workflows/linter.yml | 4 +- .github/workflows/proto-lint.yml | 2 +- .github/workflows/tests.yml | 2 +- .golangci.yml | 12 ++- Dockerfile | 2 +- Makefile | 2 +- backtester/common/common.go | 4 +- backtester/engine/grpcserver.go | 10 +-- backtester/engine/setup.go | 2 +- cmd/apichecker/apicheck.go | 8 +- cmd/gctcli/commands.go | 14 ++-- common/common_test.go | 12 +-- common/convert/convert.go | 3 +- common/file/file_test.go | 4 +- communications/telegram/telegram.go | 2 +- .../currencylayer/currencylayer_test.go | 4 +- .../exchangeratesapi.io/exchangeratesapi.go | 10 +-- currency/forexprovider/fixer.io/fixer_test.go | 1 - currency/pair_test.go | 6 +- database/repository/audit/audit_test.go | 2 - database/repository/trade/trade_test.go | 5 +- database/repository/withdraw/withdraw_test.go | 1 - engine/database_connection_test.go | 1 - engine/helpers.go | 8 +- engine/order_manager_test.go | 12 +-- engine/rpcserver.go | 16 ++-- exchanges/alphapoint/alphapoint_test.go | 2 +- exchanges/binance/binance.go | 8 +- exchanges/binance/binance_test.go | 2 +- exchanges/binance/binance_wrapper.go | 12 +-- exchanges/binanceus/binanceus.go | 42 +++++----- exchanges/binanceus/binanceus_types.go | 10 +-- exchanges/binanceus/binanceus_wrapper.go | 4 +- exchanges/bitfinex/bitfinex.go | 12 +-- exchanges/bitfinex/bitfinex_wrapper.go | 4 +- exchanges/bithumb/bithumb.go | 6 +- exchanges/bithumb/bithumb_websocket.go | 2 +- exchanges/bitstamp/bitstamp_test.go | 2 +- exchanges/coinbasepro/coinbasepro.go | 6 +- exchanges/gateio/gateio.go | 10 +-- exchanges/gateio/gateio_test.go | 2 +- exchanges/gateio/gateio_types.go | 2 +- exchanges/gateio/gateio_wrapper.go | 2 +- exchanges/gemini/gemini.go | 4 +- exchanges/hitbtc/hitbtc.go | 41 ++++------ exchanges/hitbtc/hitbtc_test.go | 1 - exchanges/huobi/huobi.go | 2 +- exchanges/huobi/huobi_cfutures.go | 65 ++++++++------- exchanges/huobi/huobi_futures.go | 82 +++++++++---------- exchanges/huobi/huobi_test.go | 12 +-- exchanges/huobi/huobi_wrapper.go | 20 ++--- exchanges/kraken/kraken.go | 16 ++-- exchanges/kraken/kraken_websocket.go | 4 +- exchanges/kraken/kraken_wrapper.go | 8 +- exchanges/kucoin/kucoin_test.go | 12 +-- exchanges/kucoin/kucoin_wrapper.go | 2 +- exchanges/okx/okx.go | 8 +- exchanges/okx/okx_test.go | 8 +- exchanges/okx/okx_websocket.go | 4 +- exchanges/okx/okx_wrapper.go | 4 +- exchanges/order/order_test.go | 4 +- exchanges/poloniex/poloniex.go | 18 ++-- exchanges/stream/websocket.go | 6 +- exchanges/stream/websocket_test.go | 14 ++-- exchanges/ticker/ticker.go | 19 +++-- exchanges/ticker/ticker_test.go | 10 +-- exchanges/ticker/ticker_types.go | 7 +- exchanges/yobit/yobit_wrapper.go | 2 +- go.mod | 2 +- 70 files changed, 322 insertions(+), 332 deletions(-) diff --git a/.github/workflows/arm64.Dockerfile b/.github/workflows/arm64.Dockerfile index 6b1a90d6cd6..db9c1f708c8 100644 --- a/.github/workflows/arm64.Dockerfile +++ b/.github/workflows/arm64.Dockerfile @@ -1,4 +1,4 @@ -FROM arm64v8/golang:1.21 +FROM arm64v8/golang:1.22 WORKDIR /app diff --git a/.github/workflows/linter.yml b/.github/workflows/linter.yml index 9c8c73844a0..9f149753713 100644 --- a/.github/workflows/linter.yml +++ b/.github/workflows/linter.yml @@ -8,9 +8,9 @@ jobs: - uses: actions/checkout@v4 - uses: actions/setup-go@v5 with: - go-version: '1.21.x' + go-version: '1.22.x' cache: false - name: golangci-lint uses: golangci/golangci-lint-action@v3 with: - version: v1.54.0 \ No newline at end of file + version: v1.56.0 \ No newline at end of file diff --git a/.github/workflows/proto-lint.yml b/.github/workflows/proto-lint.yml index fde31a452c1..d93e37ef57d 100644 --- a/.github/workflows/proto-lint.yml +++ b/.github/workflows/proto-lint.yml @@ -12,7 +12,7 @@ jobs: - name: Setup Go uses: actions/setup-go@v5 with: - go-version: 1.21.x + go-version: 1.22.x - name: Setup build depends run: | diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 900cffcfeb0..edb3c5959d1 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -1,7 +1,7 @@ on: [push, pull_request] name: CI env: - GO_VERSION: 1.21.x + GO_VERSION: 1.22.x jobs: backend-psql: name: GoCryptoTrader back-end diff --git a/.golangci.yml b/.golangci.yml index 64f25ac984f..585c5ca0f9b 100644 --- a/.golangci.yml +++ b/.golangci.yml @@ -17,7 +17,6 @@ linters: - govet - ineffassign - staticcheck - - typecheck # - unused # disabled by default linters @@ -51,6 +50,7 @@ linters: - gocheckcompilerdirectives # - gochecknoglobals # - gochecknoinits + - gochecksumtype # - gocognit - goconst - gocritic @@ -72,6 +72,7 @@ linters: - grouper # - ifshort // deprecated by its owner # - importas +# - inamedparam # - interfacebloat # - interfacer // deprecated by its owner # - ireturn @@ -94,9 +95,11 @@ linters: # - nosnakecase // deprecated by its owner, replaced by revive 'var-naming' - nosprintfhostport # - paralleltest + - perfsprint - prealloc - predeclared # - promlinter +# - protogetter - reassign - revive - rowserrcheck @@ -104,9 +107,11 @@ linters: - sqlclosecheck # - structcheck // abandoned by its owner, replaced by unused - stylecheck + - tagalign # - tagliatelle - tenv - testableexamples + - testifylint # - testpackage - thelper - tparallel @@ -136,6 +141,11 @@ linters-settings: - importShadow - methodExprCall - evalOrder + testifylint: + enable-all: true + disable: + - require-error + - float-compare issues: max-issues-per-linter: 0 diff --git a/Dockerfile b/Dockerfile index 7c60a1af68b..d4b853c12eb 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM golang:1.21 as build +FROM golang:1.22 as build WORKDIR /go/src/github.com/thrasher-corp/gocryptotrader COPY . . RUN GO111MODULE=on go mod vendor diff --git a/Makefile b/Makefile index 62e994be5f4..03870b96824 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,6 @@ LDFLAGS = -ldflags "-w -s" GCTPKG = github.com/thrasher-corp/gocryptotrader -LINTPKG = github.com/golangci/golangci-lint/cmd/golangci-lint@v1.54.0 +LINTPKG = github.com/golangci/golangci-lint/cmd/golangci-lint@v1.56.0 LINTBIN = $(GOPATH)/bin/golangci-lint GCTLISTENPORT=9050 GCTPROFILERLISTENPORT=8085 diff --git a/backtester/common/common.go b/backtester/common/common.go index 84270ef25f3..9da14f5bf8c 100644 --- a/backtester/common/common.go +++ b/backtester/common/common.go @@ -206,10 +206,10 @@ func Logo() string { sb := strings.Builder{} sb.WriteString(" \n") sb.WriteString(" " + CMDColours.White + "@@@@@@@@@@@@@@@@@ \n") - sb.WriteString(" " + CMDColours.White + "@@@@@@@@@@@@@@@@@@@@@@@ " + CMDColours.Grey + ",,,,,," + CMDColours.White + " \n") + sb.WriteString(" " + CMDColours.White + "@@@@@@@@@@@@@@@@@@@@@@@ " + CMDColours.Grey + ",,,,,," + CMDColours.White + " \n") //nolint:goconst // not needed for this glorious logo sb.WriteString(" " + CMDColours.White + "@@@@@@@@" + CMDColours.Grey + ",,,,, " + CMDColours.White + "@@@@@@@@@" + CMDColours.Grey + ",,,,,,,," + CMDColours.White + " \n") sb.WriteString(" " + CMDColours.White + "@@@@@@@@" + CMDColours.Grey + ",,,,,,, " + CMDColours.White + "@@@@@@@" + CMDColours.Grey + ",,,,,,," + CMDColours.White + " \n") - sb.WriteString(" " + CMDColours.White + "@@@@@@" + CMDColours.Grey + "(,,,,,,,, " + CMDColours.Grey + ",," + CMDColours.White + "@@@@@@@" + CMDColours.Grey + ",,,,,," + CMDColours.White + " \n") + sb.WriteString(" " + CMDColours.White + "@@@@@@" + CMDColours.Grey + "(,,,,,,,, " + CMDColours.Grey + ",," + CMDColours.White + "@@@@@@@" + CMDColours.Grey + ",,,,,," + CMDColours.White + " \n") //nolint:goconst // not needed for this glorious logo sb.WriteString(" " + CMDColours.Grey + ",," + CMDColours.White + "@@@@@@" + CMDColours.Grey + ",,,,,,,,, #,,,,,,,,,,,,,,,,,," + CMDColours.White + " \n") sb.WriteString(" " + CMDColours.Grey + ",,,,*" + CMDColours.White + "@@@@@@" + CMDColours.Grey + ",,,,,,,,,,,,,,,,,,,,,,,,,," + CMDColours.Green + "%%%%%%%" + CMDColours.White + " \n") sb.WriteString(" " + CMDColours.Grey + ",,,,,,,*" + CMDColours.White + "@@@@@@" + CMDColours.Grey + ",,,,,,,,,,,,,," + CMDColours.Green + "%%%%%" + CMDColours.Grey + " ,,,,,," + CMDColours.Grey + "%" + CMDColours.Green + "%%%%%%" + CMDColours.White + " \n") diff --git a/backtester/engine/grpcserver.go b/backtester/engine/grpcserver.go index c072a2d86b7..1ef1b8b3e21 100644 --- a/backtester/engine/grpcserver.go +++ b/backtester/engine/grpcserver.go @@ -141,21 +141,21 @@ func (s *GRPCServer) StartRPCRESTProxy() error { func (s *GRPCServer) authenticateClient(ctx context.Context) (context.Context, error) { md, ok := metadata.FromIncomingContext(ctx) if !ok { - return ctx, fmt.Errorf("unable to extract metadata") + return ctx, errors.New("unable to extract metadata") } authStr, ok := md["authorization"] if !ok { - return ctx, fmt.Errorf("authorization header missing") + return ctx, errors.New("authorization header missing") } if !strings.Contains(authStr[0], "Basic") { - return ctx, fmt.Errorf("basic not found in authorization header") + return ctx, errors.New("basic not found in authorization header") } decoded, err := crypto.Base64Decode(strings.Split(authStr[0], " ")[1]) if err != nil { - return ctx, fmt.Errorf("unable to base64 decode authorization header") + return ctx, errors.New("unable to base64 decode authorization header") } creds := strings.Split(string(decoded), ":") @@ -164,7 +164,7 @@ func (s *GRPCServer) authenticateClient(ctx context.Context) (context.Context, e if username != s.config.GRPC.Username || password != s.config.GRPC.Password { - return ctx, fmt.Errorf("username/password mismatch") + return ctx, errors.New("username/password mismatch") } return ctx, nil } diff --git a/backtester/engine/setup.go b/backtester/engine/setup.go index d0a3c3d0337..ab3a1f3dc2a 100644 --- a/backtester/engine/setup.go +++ b/backtester/engine/setup.go @@ -858,7 +858,7 @@ func (bt *BackTest) loadData(cfg *config.Config, exch gctexchange.IBotExchange, return nil, err } if resp == nil { - return nil, fmt.Errorf("processing error, response returned nil") + return nil, errors.New("processing error, response returned nil") } resp.Item.UnderlyingPair = underlyingPair diff --git a/cmd/apichecker/apicheck.go b/cmd/apichecker/apicheck.go index 10e0da668ac..b3d45e653d1 100644 --- a/cmd/apichecker/apicheck.go +++ b/cmd/apichecker/apicheck.go @@ -550,7 +550,7 @@ func addExch(exchName, checkType string, data interface{}, isUpdate bool) error } if canUpdateTrello() { if !isUpdate { - err := trelloCreateNewCheck(fmt.Sprintf("%s 1", exchName)) + err := trelloCreateNewCheck(exchName + " 1") if err != nil { return err } @@ -1187,7 +1187,7 @@ func nameStateChanges(currentName, currentState string) (string, error) { } name = fmt.Sprintf("%s %s", strings.Split(currentName, " ")[0], strings.Split(currentName, " ")[1]) if !exists { - return fmt.Sprintf("%s 1", name), nil + return name + " 1", nil } num, err = strconv.ParseInt(strings.Split(currentName, " ")[2], 10, 64) if err != nil { @@ -1198,7 +1198,7 @@ func nameStateChanges(currentName, currentState string) (string, error) { exists = true name = strings.Split(currentName, " ")[0] if !exists { - return fmt.Sprintf("%s 1", name), nil + return name + " 1", nil } num, err = strconv.ParseInt(strings.Split(currentName, " ")[1], 10, 64) if err != nil { @@ -1206,7 +1206,7 @@ func nameStateChanges(currentName, currentState string) (string, error) { } } if !exists { - return fmt.Sprintf("%s 1", name), nil + return name + " 1", nil } } diff --git a/cmd/gctcli/commands.go b/cmd/gctcli/commands.go index d4b1889d7c3..b8a05324d85 100644 --- a/cmd/gctcli/commands.go +++ b/cmd/gctcli/commands.go @@ -1775,7 +1775,7 @@ func cancelOrder(c *cli.Context) error { // pair is optional, but if it's set, do a validity check var p currency.Pair - if len(currencyPair) > 0 { + if currencyPair != "" { if !validPair(currencyPair) { return errInvalidPair } @@ -1917,7 +1917,7 @@ func cancelBatchOrders(c *cli.Context) error { // pair is optional, but if it's set, do a validity check var p currency.Pair - if len(currencyPair) > 0 { + if currencyPair != "" { if !validPair(currencyPair) { return errInvalidPair } @@ -2208,19 +2208,19 @@ func addEvent(c *cli.Context) error { if c.IsSet("exchange") { exchangeName = c.String("exchange") } else { - return fmt.Errorf("exchange name is required") + return errors.New("exchange name is required") } if c.IsSet("item") { item = c.String("item") } else { - return fmt.Errorf("item is required") + return errors.New("item is required") } if c.IsSet("condition") { condition = c.String("condition") } else { - return fmt.Errorf("condition is required") + return errors.New("condition is required") } if c.IsSet("price") { @@ -2242,7 +2242,7 @@ func addEvent(c *cli.Context) error { if c.IsSet("pair") { currencyPair = c.String("pair") } else { - return fmt.Errorf("currency pair is required") + return errors.New("currency pair is required") } if !validPair(currencyPair) { @@ -2261,7 +2261,7 @@ func addEvent(c *cli.Context) error { if c.IsSet("action") { action = c.String("action") } else { - return fmt.Errorf("action is required") + return errors.New("action is required") } p, err := currency.NewPairDelimiter(currencyPair, pairDelimiter) diff --git a/common/common_test.go b/common/common_test.go index 272ab79ef5a..fd6d448d4c6 100644 --- a/common/common_test.go +++ b/common/common_test.go @@ -664,7 +664,7 @@ func TestErrors(t *testing.T) { e5 := errors.New("add vodka") // Nil tests - assert.Nil(t, AppendError(nil, nil), "Append nil to nil should nil") + assert.NoError(t, AppendError(nil, nil), "Append nil to nil should nil") assert.Same(t, AppendError(e1, nil), e1, "Append nil to e1 should e1") assert.Same(t, AppendError(nil, e2), e2, "Append e2 to nil should e2") @@ -676,7 +676,7 @@ func TestErrors(t *testing.T) { err = ExcludeError(err, e2) assert.ErrorIs(t, err, e1, "Should still be bored") - assert.False(t, errors.Is(err, e2), "Should not be an e2") + assert.NotErrorIs(t, err, e2, "Should not be an e2") me, ok := err.(*multiError) if assert.True(t, ok, "Should be a multiError") { assert.Len(t, me.errs, 2, "Should only have 2 errors") @@ -690,19 +690,19 @@ func TestErrors(t *testing.T) { err = fmt.Errorf("%w: %w", e3, fmt.Errorf("%w: %w", e4, e5)) assert.ErrorIs(t, ExcludeError(err, e4), e3, "Excluding e4 should retain e3") assert.ErrorIs(t, ExcludeError(err, e4), e5, "Excluding e4 should retain the vanilla co-wrapped e5") - assert.False(t, errors.Is(ExcludeError(err, e4), e4), "e4 should be excluded") + assert.NotErrorIs(t, ExcludeError(err, e4), e4, "e4 should be excluded") assert.ErrorIs(t, ExcludeError(err, e5), e3, "Excluding e5 should retain e3") assert.ErrorIs(t, ExcludeError(err, e5), e4, "Excluding e5 should retain the vanilla co-wrapped e4") - assert.False(t, errors.Is(ExcludeError(err, e5), e5), "e5 should be excluded") + assert.NotErrorIs(t, ExcludeError(err, e5), e5, "e5 should be excluded") // Hybrid tests err = AppendError(fmt.Errorf("%w: %w", e4, e5), e3) assert.ErrorIs(t, ExcludeError(err, e4), e3, "Excluding e4 should retain e3") assert.ErrorIs(t, ExcludeError(err, e4), e5, "Excluding e4 should retain the vanilla co-wrapped e5") - assert.False(t, errors.Is(ExcludeError(err, e4), e4), "e4 should be excluded") + assert.NotErrorIs(t, ExcludeError(err, e4), e4, "e4 should be excluded") assert.ErrorIs(t, ExcludeError(err, e5), e3, "Excluding e5 should retain e3") assert.ErrorIs(t, ExcludeError(err, e5), e4, "Excluding e5 should retain the vanilla co-wrapped e4") - assert.False(t, errors.Is(ExcludeError(err, e5), e5), "e4 should be excluded") + assert.NotErrorIs(t, ExcludeError(err, e5), e5, "e4 should be excluded") } func TestParseStartEndDate(t *testing.T) { diff --git a/common/convert/convert.go b/common/convert/convert.go index 2546826f48d..ccb8294bb27 100644 --- a/common/convert/convert.go +++ b/common/convert/convert.go @@ -94,8 +94,7 @@ func IntToHumanFriendlyString(number int64, thousandsSep string) string { number = -number neg = true } - str := fmt.Sprintf("%v", number) - return numberToHumanFriendlyString(str, 0, "", thousandsSep, neg) + return numberToHumanFriendlyString(strconv.FormatInt(number, 10), 0, "", thousandsSep, neg) } // FloatToHumanFriendlyString converts a float to a comma separated string at the thousand point diff --git a/common/file/file_test.go b/common/file/file_test.go index 4c391957d6e..8a56afc5f96 100644 --- a/common/file/file_test.go +++ b/common/file/file_test.go @@ -1,7 +1,7 @@ package file import ( - "fmt" + "errors" "os" "path/filepath" "runtime" @@ -70,7 +70,7 @@ func TestMove(t *testing.T) { } if !strings.Contains(string(contents), "GoCryptoTrader") { - return fmt.Errorf("unable to find previously written data") + return errors.New("unable to find previously written data") } return os.Remove(out) diff --git a/communications/telegram/telegram.go b/communications/telegram/telegram.go index 1d70f0d5f6f..bb826b94eca 100644 --- a/communications/telegram/telegram.go +++ b/communications/telegram/telegram.go @@ -203,7 +203,7 @@ func (t *Telegram) HandleMessages(text string, chatID int64) error { return t.SendMessage(fmt.Sprintf("%s: %s", talkRoot, cmdHelpReply), chatID) case strings.Contains(text, cmdStart): - return t.SendMessage(fmt.Sprintf("%s: START COMMANDS HERE", talkRoot), chatID) + return t.SendMessage(talkRoot+": START COMMANDS HERE", chatID) case strings.Contains(text, cmdStatus): return t.SendMessage(fmt.Sprintf("%s: %s", talkRoot, t.GetStatus()), chatID) diff --git a/currency/forexprovider/currencylayer/currencylayer_test.go b/currency/forexprovider/currencylayer/currencylayer_test.go index bbcb1f40b3d..2a0803a3f22 100644 --- a/currency/forexprovider/currencylayer/currencylayer_test.go +++ b/currency/forexprovider/currencylayer/currencylayer_test.go @@ -89,7 +89,7 @@ func TestGetHistoricalData(t *testing.T) { r, err := c.GetHistoricalData("2022-09-26", []string{"USD"}, "EUR") if assert.NoError(t, err, "GetHistoricalData should not error") { assert.Contains(t, r, "EURUSD", "Should find rate") - assert.Equal(t, r["EURUSD"], 0.962232, "Rate should be exactly correct") + assert.Equal(t, 0.962232, r["EURUSD"], "Rate should be exactly correct") } } @@ -110,7 +110,7 @@ func TestQueryTimeFrame(t *testing.T) { assert.Len(t, r, 5, "Should get correct number of days") a, ok := r["2020-03-16"].(map[string]any) assert.True(t, ok, "Has final date entry") - assert.Equal(t, a["USDAUD"], 1.6397, "And it was a bad week") + assert.Equal(t, 1.6397, a["USDAUD"], "And it was a bad week") } } diff --git a/currency/forexprovider/exchangeratesapi.io/exchangeratesapi.go b/currency/forexprovider/exchangeratesapi.io/exchangeratesapi.go index 879ce6747c4..d4c853de7a9 100644 --- a/currency/forexprovider/exchangeratesapi.io/exchangeratesapi.go +++ b/currency/forexprovider/exchangeratesapi.io/exchangeratesapi.go @@ -91,13 +91,13 @@ func (e *ExchangeRates) GetSymbols() (map[string]string, error) { // all supported currencies func (e *ExchangeRates) GetLatestRates(baseCurrency, symbols string) (*Rates, error) { vals := url.Values{} - if len(baseCurrency) > 0 && e.APIKeyLvl <= apiKeyFree && !strings.EqualFold("EUR", baseCurrency) { + if baseCurrency != "" && e.APIKeyLvl <= apiKeyFree && !strings.EqualFold("EUR", baseCurrency) { return nil, errCannotSetBaseCurrencyOnFreePlan - } else if len(baseCurrency) > 0 { + } else if baseCurrency != "" { vals.Set("base", baseCurrency) } - if len(symbols) > 0 { + if symbols != "" { symbols = e.cleanCurrencies(baseCurrency, symbols) vals.Set("symbols", symbols) } @@ -120,9 +120,9 @@ func (e *ExchangeRates) GetHistoricalRates(date time.Time, baseCurrency string, var resp HistoricalRates v := url.Values{} - if len(baseCurrency) > 0 && e.APIKeyLvl <= apiKeyFree && !strings.EqualFold("EUR", baseCurrency) { + if baseCurrency != "" && e.APIKeyLvl <= apiKeyFree && !strings.EqualFold("EUR", baseCurrency) { return nil, errCannotSetBaseCurrencyOnFreePlan - } else if len(baseCurrency) > 0 { + } else if baseCurrency != "" { v.Set("base", baseCurrency) } diff --git a/currency/forexprovider/fixer.io/fixer_test.go b/currency/forexprovider/fixer.io/fixer_test.go index 98afc0831f2..49a5ae4eb39 100644 --- a/currency/forexprovider/fixer.io/fixer_test.go +++ b/currency/forexprovider/fixer.io/fixer_test.go @@ -13,7 +13,6 @@ var f Fixer var isSetup bool -//nolint:gocritic // Only used as a testing helper function in this package func setup(t *testing.T) { t.Helper() if !isSetup { diff --git a/currency/pair_test.go b/currency/pair_test.go index 77aefd97845..3d01c66a81a 100644 --- a/currency/pair_test.go +++ b/currency/pair_test.go @@ -3,7 +3,7 @@ package currency import ( "encoding/json" "errors" - "fmt" + "strconv" "testing" "github.com/stretchr/testify/assert" @@ -965,7 +965,7 @@ func TestGetOrderParameters(t *testing.T) { for i, tc := range testCases { tc := tc - t.Run(fmt.Sprintf("%d", i), func(t *testing.T) { + t.Run(strconv.Itoa(i), func(t *testing.T) { t.Parallel() var resp *OrderParameters var err error @@ -1032,7 +1032,7 @@ func TestIsAssociated(t *testing.T) { for x := range testCases { x := x - t.Run(fmt.Sprintf("%d", x), func(t *testing.T) { + t.Run(strconv.Itoa(x), func(t *testing.T) { t.Parallel() if testCases[x].Pair.IsAssociated(testCases[x].associate) != testCases[x].expectedResult { t.Fatalf("Test %d failed. Expected %v, received %v", x, testCases[x].expectedResult, testCases[x].Pair.IsAssociated(testCases[x].associate)) diff --git a/database/repository/audit/audit_test.go b/database/repository/audit/audit_test.go index 24f24d7f3be..222926028e4 100644 --- a/database/repository/audit/audit_test.go +++ b/database/repository/audit/audit_test.go @@ -99,7 +99,6 @@ func TestAudit(t *testing.T) { } } -//nolint:gocritic // Only used as a testing helper function in this package func writeAudit(t *testing.T) { t.Helper() var wg sync.WaitGroup @@ -117,7 +116,6 @@ func writeAudit(t *testing.T) { wg.Wait() } -//nolint:gocritic // Only used as a testing helper function in this package func readHelper(t *testing.T) { t.Helper() diff --git a/database/repository/trade/trade_test.go b/database/repository/trade/trade_test.go index 97c1d5821a7..5cc6f246a7b 100644 --- a/database/repository/trade/trade_test.go +++ b/database/repository/trade/trade_test.go @@ -4,6 +4,7 @@ import ( "fmt" "log" "os" + "strconv" "testing" "time" @@ -120,7 +121,7 @@ func tradeSQLTester(t *testing.T) { Price: float64(i * (i + 3)), Amount: float64(i * (i + 2)), Side: order.Buy.String(), - TID: fmt.Sprintf("%v", i), + TID: strconv.Itoa(i), }) } err := Insert(trades...) @@ -140,7 +141,7 @@ func tradeSQLTester(t *testing.T) { Price: float64(i * (i + 3)), Amount: float64(i * (i + 2)), Side: order.Buy.String(), - TID: fmt.Sprintf("%v", i), + TID: strconv.Itoa(i), }) } err = Insert(trades2...) diff --git a/database/repository/withdraw/withdraw_test.go b/database/repository/withdraw/withdraw_test.go index 09d5f13b71f..c98d05741e9 100644 --- a/database/repository/withdraw/withdraw_test.go +++ b/database/repository/withdraw/withdraw_test.go @@ -154,7 +154,6 @@ func seedWithdrawData() { } } -//nolint:gocritic // Only used as a testing helper function in this package func withdrawHelper(t *testing.T) { t.Helper() seedWithdrawData() diff --git a/engine/database_connection_test.go b/engine/database_connection_test.go index 52a9d77cb84..9418aa4f6f5 100644 --- a/engine/database_connection_test.go +++ b/engine/database_connection_test.go @@ -10,7 +10,6 @@ import ( "github.com/thrasher-corp/gocryptotrader/database/drivers" ) -//nolint:gocritic // Only used as a testing helper function in this package func CreateDatabase(t *testing.T) { t.Helper() // fun workarounds to globals ruining testing diff --git a/engine/helpers.go b/engine/helpers.go index 1700b8cba65..1d538eebcce 100644 --- a/engine/helpers.go +++ b/engine/helpers.go @@ -639,7 +639,7 @@ func GetCollatedExchangeAccountInfoByCoin(accounts []account.Holdings) map[curre func GetExchangeHighestPriceByCurrencyPair(p currency.Pair, a asset.Item) (string, error) { result := stats.SortExchangesByPrice(p, a, true) if len(result) == 0 { - return "", fmt.Errorf("no stats for supplied currency pair and asset type") + return "", errors.New("no stats for supplied currency pair and asset type") } return result[0].Exchange, nil @@ -650,7 +650,7 @@ func GetExchangeHighestPriceByCurrencyPair(p currency.Pair, a asset.Item) (strin func GetExchangeLowestPriceByCurrencyPair(p currency.Pair, assetType asset.Item) (string, error) { result := stats.SortExchangesByPrice(p, assetType, false) if len(result) == 0 { - return "", fmt.Errorf("no stats for supplied currency pair and asset type") + return "", errors.New("no stats for supplied currency pair and asset type") } return result[0].Exchange, nil @@ -962,7 +962,7 @@ func genCert(targetDir string) error { certData := pem.EncodeToMemory(&pem.Block{Type: "CERTIFICATE", Bytes: derBytes}) if certData == nil { - return fmt.Errorf("cert data is nil") + return errors.New("cert data is nil") } b, err := x509.MarshalECPrivateKey(privKey) @@ -972,7 +972,7 @@ func genCert(targetDir string) error { keyData := pem.EncodeToMemory(&pem.Block{Type: "EC PRIVATE KEY", Bytes: b}) if keyData == nil { - return fmt.Errorf("key pem data is nil") + return errors.New("key pem data is nil") } err = file.Write(filepath.Join(targetDir, "key.pem"), keyData) diff --git a/engine/order_manager_test.go b/engine/order_manager_test.go index cbdc7659f32..2d8bd7562e7 100644 --- a/engine/order_manager_test.go +++ b/engine/order_manager_test.go @@ -653,20 +653,20 @@ func TestSubmitOrderAlreadyInStore(t *testing.T) { Exchange: testExchange, } submitResp, err := submitReq.DeriveSubmitResponse("batman.obvs") - assert.Nil(t, err, "Deriving a SubmitResp should not error") + assert.NoError(t, err, "Deriving a SubmitResp should not error") id, err := uuid.NewV4() - assert.Nil(t, err, "uuid should not error") + assert.NoError(t, err, "uuid should not error") d, err := submitResp.DeriveDetail(id) - assert.Nil(t, err, "Derive Detail should not error") + assert.NoError(t, err, "Derive Detail should not error") d.ClientOrderID = "SecretSquirrelSauce" err = m.orderStore.add(d) - assert.Nil(t, err, "Adding an order should not error") + assert.NoError(t, err, "Adding an order should not error") resp, err := m.SubmitFakeOrder(submitReq, submitResp, false) - if assert.Nil(t, err, "SumbitFakeOrder should not error that the order is already in the store") { + if assert.NoError(t, err, "SumbitFakeOrder should not error that the order is already in the store") { assert.Equal(t, d.ClientOrderID, resp.ClientOrderID, "resp should contain the ClientOrderID from the store") } } @@ -1712,7 +1712,7 @@ func TestGetByDetail(t *testing.T) { } assert.Nil(t, m.orderStore.getByDetail(od), "Fetching a non-stored order should return nil") - assert.Nil(t, m.orderStore.add(od), "Adding the details should not error") + assert.NoError(t, m.orderStore.add(od), "Adding the details should not error") byOrig := m.orderStore.getByDetail(od) byID := m.orderStore.getByDetail(id) diff --git a/engine/rpcserver.go b/engine/rpcserver.go index 41d81669ae1..816898cd69c 100644 --- a/engine/rpcserver.go +++ b/engine/rpcserver.go @@ -91,21 +91,21 @@ type RPCServer struct { func (s *RPCServer) authenticateClient(ctx context.Context) (context.Context, error) { md, ok := metadata.FromIncomingContext(ctx) if !ok { - return ctx, fmt.Errorf("unable to extract metadata") + return ctx, errors.New("unable to extract metadata") } authStr, ok := md["authorization"] if !ok { - return ctx, fmt.Errorf("authorization header missing") + return ctx, errors.New("authorization header missing") } if !strings.Contains(authStr[0], "Basic") { - return ctx, fmt.Errorf("basic not found in authorization header") + return ctx, errors.New("basic not found in authorization header") } decoded, err := crypto.Base64Decode(strings.Split(authStr[0], " ")[1]) if err != nil { - return ctx, fmt.Errorf("unable to base64 decode authorization header") + return ctx, errors.New("unable to base64 decode authorization header") } cred := strings.Split(string(decoded), ":") @@ -114,7 +114,7 @@ func (s *RPCServer) authenticateClient(ctx context.Context) (context.Context, er if username != s.Config.RemoteControl.Username || password != s.Config.RemoteControl.Password { - return ctx, fmt.Errorf("username/password mismatch") + return ctx, errors.New("username/password mismatch") } ctx, err = account.ParseCredentialsMetadata(ctx, md) if err != nil { @@ -878,7 +878,7 @@ func (s *RPCServer) RemovePortfolioAddress(_ context.Context, r *gctrpc.RemovePo func (s *RPCServer) GetForexProviders(_ context.Context, _ *gctrpc.GetForexProvidersRequest) (*gctrpc.GetForexProvidersResponse, error) { providers := s.Config.GetForexProviders() if len(providers) == 0 { - return nil, fmt.Errorf("forex providers is empty") + return nil, errors.New("forex providers is empty") } forexProviders := make([]*gctrpc.ForexProvider, len(providers)) @@ -904,7 +904,7 @@ func (s *RPCServer) GetForexRates(_ context.Context, _ *gctrpc.GetForexRatesRequ } if len(rates) == 0 { - return nil, fmt.Errorf("forex rates is empty") + return nil, errors.New("forex rates is empty") } forexRates := make([]*gctrpc.ForexRatesConversion, 0, len(rates)) @@ -3290,7 +3290,7 @@ func (s *RPCServer) ConvertTradesToCandles(_ context.Context, r *gctrpc.ConvertT return nil, err } if len(klineItem.Candles) == 0 { - return nil, fmt.Errorf("no candles generated from trades") + return nil, errors.New("no candles generated from trades") } resp := &gctrpc.GetHistoricCandlesResponse{ diff --git a/exchanges/alphapoint/alphapoint_test.go b/exchanges/alphapoint/alphapoint_test.go index 4c5b038a071..9630a8bd0f0 100644 --- a/exchanges/alphapoint/alphapoint_test.go +++ b/exchanges/alphapoint/alphapoint_test.go @@ -143,7 +143,7 @@ func TestGetTradesByDate(t *testing.T) { if !trades.IsAccepted { t.Error("Alphapoint trades.IsAccepted value is true") } - if len(trades.RejectReason) > 0 { + if trades.RejectReason != "" { t.Error("Alphapoint trades.IsAccepted value has been returned") } if trades.StartDate < 0 { diff --git a/exchanges/binance/binance.go b/exchanges/binance/binance.go index fa498f5eb74..43b148731d8 100644 --- a/exchanges/binance/binance.go +++ b/exchanges/binance/binance.go @@ -139,7 +139,7 @@ func (b *Binance) GetOrderBook(ctx context.Context, obd OrderBookDataRequestPara return nil, err } params.Set("symbol", symbol) - params.Set("limit", fmt.Sprintf("%d", obd.Limit)) + params.Set("limit", strconv.Itoa(obd.Limit)) var resp OrderBookData if err := b.SendHTTPRequest(ctx, @@ -200,7 +200,7 @@ func (b *Binance) GetMostRecentTrades(ctx context.Context, rtr RecentTradeReques return nil, err } params.Set("symbol", symbol) - params.Set("limit", fmt.Sprintf("%d", rtr.Limit)) + params.Set("limit", strconv.Itoa(rtr.Limit)) path := recentTrades + "?" + params.Encode() @@ -219,10 +219,10 @@ func (b *Binance) GetHistoricalTrades(ctx context.Context, symbol string, limit params := url.Values{} params.Set("symbol", symbol) - params.Set("limit", fmt.Sprintf("%d", limit)) + params.Set("limit", strconv.Itoa(limit)) // else return most recent trades if fromID > 0 { - params.Set("fromId", fmt.Sprintf("%d", fromID)) + params.Set("fromId", strconv.FormatInt(fromID, 10)) } path := historicalTrades + "?" + params.Encode() diff --git a/exchanges/binance/binance_test.go b/exchanges/binance/binance_test.go index df8b2458fea..1086b9126f5 100644 --- a/exchanges/binance/binance_test.go +++ b/exchanges/binance/binance_test.go @@ -1464,7 +1464,7 @@ func TestGetHistoricTrades(t *testing.T) { if mockTests { expected = 1002 } - assert.Equal(t, expected, len(result), "GetHistoricTrades should return correct number of entries") // assert.Len doesn't produce clear messages on result + assert.Equal(t, expected, len(result), "GetHistoricTrades should return correct number of entries") //nolint:testifylint // assert.Len doesn't produce clear messages on result for _, r := range result { if !assert.WithinRange(t, r.Timestamp, start, end, "All trades should be within time range") { break diff --git a/exchanges/binance/binance_wrapper.go b/exchanges/binance/binance_wrapper.go index d981fa4b2f3..0c87bb4211b 100644 --- a/exchanges/binance/binance_wrapper.go +++ b/exchanges/binance/binance_wrapper.go @@ -965,7 +965,7 @@ func (b *Binance) SubmitOrder(ctx context.Context, s *order.Submit) (*order.Subm case order.Sell: reqSide = "SELL" default: - return nil, fmt.Errorf("invalid side") + return nil, errors.New("invalid side") } var ( @@ -1018,7 +1018,7 @@ func (b *Binance) SubmitOrder(ctx context.Context, s *order.Submit) (*order.Subm case order.Sell: reqSide = "SELL" default: - return nil, fmt.Errorf("invalid side") + return nil, errors.New("invalid side") } var oType string switch s.Type { @@ -1549,7 +1549,7 @@ func (b *Binance) GetOrderHistory(ctx context.Context, req *order.MultiOrderRequ return nil, errors.New("endTime cannot be before startTime") } if time.Since(req.StartTime) > time.Hour*24*30 { - return nil, fmt.Errorf("can only fetch orders 30 days out") + return nil, errors.New("can only fetch orders 30 days out") } orderHistory, err = b.GetAllFuturesOrders(ctx, req.Pairs[i], currency.EMPTYPAIR, req.StartTime, req.EndTime, 0, 0) @@ -1567,7 +1567,7 @@ func (b *Binance) GetOrderHistory(ctx context.Context, req *order.MultiOrderRequ return nil, err } default: - return nil, fmt.Errorf("invalid combination of input params") + return nil, errors.New("invalid combination of input params") } for y := range orderHistory { var feeBuilder exchange.FeeBuilder @@ -1607,7 +1607,7 @@ func (b *Binance) GetOrderHistory(ctx context.Context, req *order.MultiOrderRequ return nil, errors.New("endTime cannot be before startTime") } if time.Since(req.StartTime) > time.Hour*24*7 { - return nil, fmt.Errorf("can only fetch orders 7 days out") + return nil, errors.New("can only fetch orders 7 days out") } orderHistory, err = b.UAllAccountOrders(ctx, req.Pairs[i], 0, 0, req.StartTime, req.EndTime) @@ -1625,7 +1625,7 @@ func (b *Binance) GetOrderHistory(ctx context.Context, req *order.MultiOrderRequ return nil, err } default: - return nil, fmt.Errorf("invalid combination of input params") + return nil, errors.New("invalid combination of input params") } for y := range orderHistory { var feeBuilder exchange.FeeBuilder diff --git a/exchanges/binanceus/binanceus.go b/exchanges/binanceus/binanceus.go index 88ca338d13e..53b18ff4249 100644 --- a/exchanges/binanceus/binanceus.go +++ b/exchanges/binanceus/binanceus.go @@ -348,7 +348,7 @@ func (bi *Binanceus) GetOrderBookDepth(ctx context.Context, arg *OrderBookDataRe return nil, err } params.Set("symbol", symbol) - params.Set("limit", fmt.Sprintf("%d", arg.Limit)) + params.Set("limit", strconv.FormatInt(arg.Limit, 10)) var resp OrderBookData if err := bi.SendHTTPRequest(ctx, exchange.RestSpotSupplementary, @@ -955,7 +955,7 @@ func (bi *Binanceus) GetSubaccountAssets(ctx context.Context, email string) (*Su } params := url.Values{} timestamp := time.Now().UnixMilli() - params.Set("timestamp", fmt.Sprintf("%d", timestamp)) + params.Set("timestamp", strconv.FormatInt(timestamp, 10)) params.Set("email", email) // return &resp, bi.SendAuthHTTPRequest(ctx, @@ -1184,7 +1184,7 @@ func (bi *Binanceus) GetTrades(ctx context.Context, arg *GetTradesParams) ([]Tra params.Set("fromId", strconv.Itoa(int(arg.FromID))) } if arg.Limit > 0 && arg.Limit < 1000 { - params.Set("limit", fmt.Sprint(arg.Limit)) + params.Set("limit", strconv.FormatUint(arg.Limit, 10)) } else if arg.Limit > 1000 { params.Set("limit", strconv.Itoa(1000)) } @@ -1244,7 +1244,7 @@ func (bi *Binanceus) CreateNewOCOOrder(ctx context.Context, arg *OCOOrderInputPa // GetOCOOrder to retrieve a specific OCO order based on provided optional parameters. func (bi *Binanceus) GetOCOOrder(ctx context.Context, arg *GetOCOOrderRequestParams) (*OCOOrderResponse, error) { params := url.Values{} - params.Set("timestamp", fmt.Sprint(time.Now().UnixMilli())) + params.Set("timestamp", strconv.FormatInt(time.Now().UnixMilli(), 10)) switch { case arg.OrderListID != "": params.Set("orderListId", arg.OrderListID) @@ -1261,23 +1261,23 @@ func (bi *Binanceus) GetOCOOrder(ctx context.Context, arg *GetOCOOrderRequestPar // GetAllOCOOrder to retrieve all OCO orders based on provided optional parameters. Please note the maximum limit is 1,000 orders. func (bi *Binanceus) GetAllOCOOrder(ctx context.Context, arg *OCOOrdersRequestParams) ([]OCOOrderResponse, error) { params := url.Values{} - params.Set("timestamp", fmt.Sprint(time.Now().UnixMilli())) + params.Set("timestamp", strconv.FormatInt(time.Now().UnixMilli(), 10)) var response []OCOOrderResponse if arg.FromID > 0 { - params.Set("fromId", fmt.Sprint(arg.FromID)) + params.Set("fromId", strconv.FormatUint(arg.FromID, 10)) } else { if arg.StartTime.Unix() > 0 && arg.StartTime.Before(arg.EndTime) { - params.Set("startTime", fmt.Sprint(arg.StartTime.UnixMilli())) - params.Set("endTime", fmt.Sprint(arg.EndTime.UnixMilli())) + params.Set("startTime", strconv.FormatInt(arg.StartTime.UnixMilli(), 10)) + params.Set("endTime", strconv.FormatInt(arg.EndTime.UnixMilli(), 10)) } else if arg.StartTime.Unix() > 0 { - params.Set("startTime", fmt.Sprint(arg.StartTime.UnixMilli())) + params.Set("startTime", strconv.FormatInt(arg.StartTime.UnixMilli(), 10)) } } if arg.Limit > 0 { - params.Set("limit", fmt.Sprint(arg.Limit)) + params.Set("limit", strconv.FormatUint(arg.Limit, 10)) } if arg.RecvWindow > 0 { - params.Set("recvWindow", fmt.Sprint(arg.RecvWindow)) + params.Set("recvWindow", strconv.FormatUint(arg.RecvWindow, 10)) } return response, bi.SendAuthHTTPRequest(ctx, exchange.RestSpotSupplementary, http.MethodGet, ocoAllOrderList, @@ -1286,11 +1286,11 @@ func (bi *Binanceus) GetAllOCOOrder(ctx context.Context, arg *OCOOrdersRequestPa } // GetOpenOCOOrders to query open OCO orders. -func (bi *Binanceus) GetOpenOCOOrders(ctx context.Context, recvWindow uint) ([]OCOOrderResponse, error) { +func (bi *Binanceus) GetOpenOCOOrders(ctx context.Context, recvWindow uint64) ([]OCOOrderResponse, error) { params := url.Values{} - params.Set("timestamp", fmt.Sprint(time.Now().UnixMilli())) + params.Set("timestamp", strconv.FormatInt(time.Now().UnixMilli(), 10)) if recvWindow > 0 { - params.Set("recvWindow", fmt.Sprint(recvWindow)) + params.Set("recvWindow", strconv.FormatUint(recvWindow, 10)) } else { params.Set("recvWindow", "30000") } @@ -1304,7 +1304,7 @@ func (bi *Binanceus) GetOpenOCOOrders(ctx context.Context, recvWindow uint) ([]O func (bi *Binanceus) CancelOCOOrder(ctx context.Context, arg *OCOOrdersDeleteRequestParams) (*OCOFullOrderResponse, error) { var response OCOFullOrderResponse params := url.Values{} - params.Set("timestamp", fmt.Sprint(time.Now().UnixMilli())) + params.Set("timestamp", strconv.FormatInt(time.Now().UnixMilli(), 10)) switch { case arg.OrderListID > 0: params.Set("orderListId", strconv.Itoa(int(arg.OrderListID))) @@ -1314,7 +1314,7 @@ func (bi *Binanceus) CancelOCOOrder(ctx context.Context, arg *OCOOrdersDeleteReq return nil, errIncompleteArguments } if arg.RecvWindow > 0 { - params.Set("recvWindow", fmt.Sprint(arg.RecvWindow)) + params.Set("recvWindow", strconv.FormatUint(arg.RecvWindow, 10)) } return &response, bi.SendAuthHTTPRequest(ctx, exchange.RestSpotSupplementary, http.MethodGet, ocoOrderList, @@ -1389,7 +1389,7 @@ func (bi *Binanceus) GetOTCTradeOrder(ctx context.Context, orderID uint64) (*OTC } orderIDStr := strconv.FormatUint(orderID, 10) params.Set("orderId", orderIDStr) - params.Set("timestamp", fmt.Sprint(time.Now().UnixMilli())) + params.Set("timestamp", strconv.FormatInt(time.Now().UnixMilli(), 10)) path := otcTradeOrders + orderIDStr return &response, bi.SendAuthHTTPRequest(ctx, exchange.RestSpotSupplementary, @@ -1679,16 +1679,16 @@ func (bi *Binanceus) DepositHistory(ctx context.Context, c currency.Code, status func (bi *Binanceus) FiatDepositHistory(ctx context.Context, arg *FiatWithdrawalRequestParams) (FiatAssetsHistory, error) { params := url.Values{} if !(arg.EndTime.IsZero()) && !(arg.EndTime.Before(time.Now())) { - params.Set("endTime", fmt.Sprint(arg.EndTime.UnixMilli())) + params.Set("endTime", strconv.FormatInt(arg.EndTime.UnixMilli(), 10)) } if !(arg.StartTime.IsZero()) && !(arg.StartTime.After(time.Now())) { - params.Set("startTime", fmt.Sprint(arg.StartTime.UnixMilli())) + params.Set("startTime", strconv.FormatInt(arg.StartTime.UnixMilli(), 10)) } if arg.FiatCurrency != "" { params.Set("fiatCurrency", arg.FiatCurrency) } if arg.Offset > 0 { - params.Set("offset", fmt.Sprint(arg.Offset)) + params.Set("offset", strconv.FormatInt(arg.Offset, 10)) } if arg.PaymentChannel != "" { params.Set("paymentChannel", arg.PaymentChannel) @@ -1696,7 +1696,7 @@ func (bi *Binanceus) FiatDepositHistory(ctx context.Context, arg *FiatWithdrawal if arg.PaymentMethod != "" { params.Set("paymentMethod", arg.PaymentMethod) } - params.Set("timestamp", fmt.Sprint(time.Now().UnixMilli())) + params.Set("timestamp", strconv.FormatInt(time.Now().UnixMilli(), 10)) var response FiatAssetsHistory return response, bi.SendAuthHTTPRequest(ctx, exchange.RestSpotSupplementary, http.MethodGet, diff --git a/exchanges/binanceus/binanceus_types.go b/exchanges/binanceus/binanceus_types.go index 810f96a4d1f..f3e352f15f2 100644 --- a/exchanges/binanceus/binanceus_types.go +++ b/exchanges/binanceus/binanceus_types.go @@ -524,8 +524,8 @@ type GetTradesParams struct { StartTime *time.Time `json:"startTime"` EndTime *time.Time `json:"endTime"` FromID uint64 `json:"fromId"` - Limit uint `json:"limit"` - RecvWindow uint `json:"recvWindow"` + Limit uint64 `json:"limit"` + RecvWindow uint64 `json:"recvWindow"` } // Trade this struct represents a trade response. @@ -599,8 +599,8 @@ type OCOOrdersRequestParams struct { FromID uint64 StartTime time.Time EndTime time.Time - Limit uint - RecvWindow uint + Limit uint64 + RecvWindow uint64 } // OCOOrdersDeleteRequestParams holds the params to delete a new order @@ -609,7 +609,7 @@ type OCOOrdersDeleteRequestParams struct { OrderListID uint64 ListClientOrderID string NewClientOrderID string - RecvWindow uint + RecvWindow uint64 } // OTC endpoints diff --git a/exchanges/binanceus/binanceus_wrapper.go b/exchanges/binanceus/binanceus_wrapper.go index c11ad1ad4f4..3f078ede7a8 100644 --- a/exchanges/binanceus/binanceus_wrapper.go +++ b/exchanges/binanceus/binanceus_wrapper.go @@ -471,7 +471,7 @@ func (bi *Binanceus) GetWithdrawalsHistory(ctx context.Context, c currency.Code, return nil, err } resp[i] = exchange.WithdrawalHistory{ - Status: fmt.Sprint(withdrawals[i].Status), + Status: strconv.FormatInt(withdrawals[i].Status, 10), TransferID: withdrawals[i].ID, Currency: withdrawals[i].Coin, Amount: withdrawals[i].Amount, @@ -501,7 +501,7 @@ func (bi *Binanceus) GetRecentTrades(ctx context.Context, p currency.Pair, asset resp := make([]trade.Data, len(tradeData)) for i := range tradeData { resp[i] = trade.Data{ - TID: fmt.Sprint(tradeData[i].ID), + TID: strconv.FormatInt(tradeData[i].ID, 10), Exchange: bi.Name, AssetType: assetType, CurrencyPair: p, diff --git a/exchanges/bitfinex/bitfinex.go b/exchanges/bitfinex/bitfinex.go index e76a23ad721..6d3e4a4dc0b 100644 --- a/exchanges/bitfinex/bitfinex.go +++ b/exchanges/bitfinex/bitfinex.go @@ -1814,7 +1814,7 @@ func (b *Bitfinex) GetBalanceHistory(ctx context.Context, symbol string, timeSin if limit > 0 { req["limit"] = limit } - if len(wallet) > 0 { + if wallet != "" { req["wallet"] = wallet } @@ -1831,7 +1831,7 @@ func (b *Bitfinex) GetMovementHistory(ctx context.Context, symbol, method string req := make(map[string]interface{}) req["currency"] = symbol - if len(method) > 0 { + if method != "" { req["method"] = method } if !timeSince.IsZero() { @@ -2301,22 +2301,22 @@ func (b *Bitfinex) PopulateAcceptableMethods(ctx context.Context) error { storeData := make(map[string][]string) for x := range data { if len(data[x]) == 0 { - return fmt.Errorf("data should not be empty") + return errors.New("data should not be empty") } name, ok := data[x][0].(string) if !ok { - return fmt.Errorf("unable to type assert name") + return errors.New("unable to type assert name") } var availOptions []string options, ok := data[x][1].([]interface{}) if !ok { - return fmt.Errorf("unable to type assert options") + return errors.New("unable to type assert options") } for x := range options { o, ok := options[x].(string) if !ok { - return fmt.Errorf("unable to type assert option to string") + return errors.New("unable to type assert option to string") } availOptions = append(availOptions, o) } diff --git a/exchanges/bitfinex/bitfinex_wrapper.go b/exchanges/bitfinex/bitfinex_wrapper.go index de10d725518..7e1ef64c766 100644 --- a/exchanges/bitfinex/bitfinex_wrapper.go +++ b/exchanges/bitfinex/bitfinex_wrapper.go @@ -1082,7 +1082,7 @@ func (b *Bitfinex) AuthenticateWebsocket(ctx context.Context) error { // appendOptionalDelimiter ensures that a delimiter is present for long character currencies func (b *Bitfinex) appendOptionalDelimiter(p *currency.Pair) { - if (len(p.Base.String()) > 3 && len(p.Quote.String()) > 0) || + if (len(p.Base.String()) > 3 && !p.Quote.IsEmpty()) || len(p.Quote.String()) > 3 { p.Delimiter = ":" } @@ -1247,7 +1247,7 @@ func (b *Bitfinex) GetAvailableTransferChains(ctx context.Context, cryptocurrenc availChains := acceptableMethods.lookup(cryptocurrency) if len(availChains) == 0 { - return nil, fmt.Errorf("unable to find any available chains") + return nil, errors.New("unable to find any available chains") } return availChains, nil } diff --git a/exchanges/bithumb/bithumb.go b/exchanges/bithumb/bithumb.go index b5cdd4f2e0c..c9cd426c8c3 100644 --- a/exchanges/bithumb/bithumb.go +++ b/exchanges/bithumb/bithumb.go @@ -342,11 +342,11 @@ func (b *Bithumb) GetOrders(ctx context.Context, orderID, transactionType string params.Set("order_currency", orderCurrency.Upper().String()) - if len(orderID) > 0 { + if orderID != "" { params.Set("order_id", orderID) } - if len(transactionType) > 0 { + if transactionType != "" { params.Set("type", transactionType) } @@ -454,7 +454,7 @@ func (b *Bithumb) WithdrawCrypto(ctx context.Context, address, destination, curr params := url.Values{} params.Set("address", address) - if len(destination) > 0 { + if destination != "" { params.Set("destination", destination) } params.Set("currency", strings.ToUpper(currency)) diff --git a/exchanges/bithumb/bithumb_websocket.go b/exchanges/bithumb/bithumb_websocket.go index 0f4627ce785..3005f42359c 100644 --- a/exchanges/bithumb/bithumb_websocket.go +++ b/exchanges/bithumb/bithumb_websocket.go @@ -78,7 +78,7 @@ func (b *Bithumb) wsHandleData(respRaw []byte) error { return err } - if len(resp.Status) > 0 { + if resp.Status != "" { if resp.Status == "0000" { return nil } diff --git a/exchanges/bitstamp/bitstamp_test.go b/exchanges/bitstamp/bitstamp_test.go index 53d772d9f35..caad04a8df7 100644 --- a/exchanges/bitstamp/bitstamp_test.go +++ b/exchanges/bitstamp/bitstamp_test.go @@ -142,7 +142,7 @@ func TestGetAccountTradingFee(t *testing.T) { assert.Positive(t, fee.Fees.Taker, "Taker should be positive") } assert.NotEmpty(t, fee.Symbol, "Symbol should not be empty") - assert.Equal(t, fee.Symbol, "ltcbtc", "Symbol should be correct") + assert.Equal(t, "ltcbtc", fee.Symbol, "Symbol should be correct") } _, err = b.GetAccountTradingFee(context.Background(), currency.EMPTYPAIR) diff --git a/exchanges/coinbasepro/coinbasepro.go b/exchanges/coinbasepro/coinbasepro.go index e7667fba793..6398745ea20 100644 --- a/exchanges/coinbasepro/coinbasepro.go +++ b/exchanges/coinbasepro/coinbasepro.go @@ -211,13 +211,13 @@ func (c *CoinbasePro) GetTrades(ctx context.Context, currencyPair string) ([]Tra func (c *CoinbasePro) GetHistoricRates(ctx context.Context, currencyPair, start, end string, granularity int64) ([]History, error) { values := url.Values{} - if len(start) > 0 { + if start != "" { values.Set("start", start) } else { values.Set("start", "") } - if len(end) > 0 { + if end != "" { values.Set("end", end) } else { values.Set("end", "") @@ -469,7 +469,7 @@ func (c *CoinbasePro) CancelAllExistingOrders(ctx context.Context, currencyPair var resp []string req := make(map[string]interface{}) - if len(currencyPair) > 0 { + if currencyPair != "" { req["product_id"] = currencyPair } return resp, c.SendAuthenticatedHTTPRequest(ctx, exchange.RestSpot, http.MethodDelete, coinbaseproOrders, req, &resp) diff --git a/exchanges/gateio/gateio.go b/exchanges/gateio/gateio.go index 35a9e10163f..c60bf0e91b9 100644 --- a/exchanges/gateio/gateio.go +++ b/exchanges/gateio/gateio.go @@ -2275,7 +2275,7 @@ func (g *Gateio) UpdatePositionMarginInDualMode(ctx context.Context, settle stri params := url.Values{} params.Set("change", strconv.FormatFloat(change, 'f', -1, 64)) if dualSide != "dual_long" && dualSide != "dual_short" { - return nil, fmt.Errorf("invalid 'dual_side' should be 'dual_short' or 'dual_long'") + return nil, errors.New("invalid 'dual_side' should be 'dual_short' or 'dual_long'") } params.Set("dual_side", dualSide) var response []Position @@ -3204,13 +3204,13 @@ func (g *Gateio) GetDeliveryPriceTriggeredOrder(ctx context.Context, settle stri return nil, fmt.Errorf("%w, only time in force value 'gtc' and 'ioc' are supported", errInvalidTimeInForce) } if arg.Trigger.StrategyType != 0 && arg.Trigger.StrategyType != 1 { - return nil, fmt.Errorf("strategy type must be 0 or 1, 0: by price, and 1: by price gap") + return nil, errors.New("strategy type must be 0 or 1, 0: by price, and 1: by price gap") } if arg.Trigger.Rule != 1 && arg.Trigger.Rule != 2 { - return nil, fmt.Errorf("invalid trigger condition('rule') value, rule must be 1 or 2") + return nil, errors.New("invalid trigger condition('rule') value, rule must be 1 or 2") } if arg.Trigger.PriceType != 0 && arg.Trigger.PriceType != 1 && arg.Trigger.PriceType != 2 { - return nil, fmt.Errorf("price type must be 0 or 1 or 2") + return nil, errors.New("price type must be 0 or 1 or 2") } if arg.Trigger.Price <= 0 { return nil, errors.New("invalid argument: trigger.price") @@ -3482,7 +3482,7 @@ func (g *Gateio) GetUsersLiquidationHistoryForSpecifiedUnderlying(ctx context.Co } // PlaceOptionOrder creates an options order -func (g *Gateio) PlaceOptionOrder(ctx context.Context, arg OptionOrderParam) (*OptionOrderResponse, error) { +func (g *Gateio) PlaceOptionOrder(ctx context.Context, arg *OptionOrderParam) (*OptionOrderResponse, error) { if arg.Contract == "" { return nil, errInvalidOrMissingContractParam } diff --git a/exchanges/gateio/gateio_test.go b/exchanges/gateio/gateio_test.go index 18429265826..0aa5076e6cc 100644 --- a/exchanges/gateio/gateio_test.go +++ b/exchanges/gateio/gateio_test.go @@ -1858,7 +1858,7 @@ func TestGetUsersLiquidationHistoryForSpecifiedUnderlying(t *testing.T) { func TestPlaceOptionOrder(t *testing.T) { t.Parallel() sharedtestvalues.SkipTestIfCredentialsUnset(t, g, canManipulateRealOrders) - _, err := g.PlaceOptionOrder(context.Background(), OptionOrderParam{ + _, err := g.PlaceOptionOrder(context.Background(), &OptionOrderParam{ Contract: getPair(t, asset.Options).String(), OrderSize: -1, Iceberg: 0, diff --git a/exchanges/gateio/gateio_types.go b/exchanges/gateio/gateio_types.go index ec3626d10a5..28ed099819c 100644 --- a/exchanges/gateio/gateio_types.go +++ b/exchanges/gateio/gateio_types.go @@ -1938,7 +1938,7 @@ type SettlementHistoryItem struct { // SubAccountParams represents subaccount creation parameters type SubAccountParams struct { - LoginName string `json:"login_name,"` + LoginName string `json:"login_name"` Remark string `json:"remark,omitempty"` Email string `json:"email,omitempty"` // The sub-account's password. Password string `json:"password,omitempty"` // The sub-account's email address. diff --git a/exchanges/gateio/gateio_wrapper.go b/exchanges/gateio/gateio_wrapper.go index 924da1dcbc4..3026efc0608 100644 --- a/exchanges/gateio/gateio_wrapper.go +++ b/exchanges/gateio/gateio_wrapper.go @@ -1130,7 +1130,7 @@ func (g *Gateio) SubmitOrder(ctx context.Context, s *order.Submit) (*order.Submi response.Price = newOrder.OrderPrice.Float64() return response, nil case asset.Options: - optionOrder, err := g.PlaceOptionOrder(ctx, OptionOrderParam{ + optionOrder, err := g.PlaceOptionOrder(ctx, &OptionOrderParam{ Contract: s.Pair.String(), OrderSize: s.Amount, Price: types.Number(s.Price), diff --git a/exchanges/gemini/gemini.go b/exchanges/gemini/gemini.go index f650ebf43fd..bb9ed7565b8 100644 --- a/exchanges/gemini/gemini.go +++ b/exchanges/gemini/gemini.go @@ -80,7 +80,7 @@ func (g *Gemini) GetSymbolDetails(ctx context.Context, symbol string) ([]SymbolD // GetTicker returns information about recent trading activity for the symbol func (g *Gemini) GetTicker(ctx context.Context, currencyPair string) (TickerV2, error) { ticker := TickerV2{} - path := fmt.Sprintf("/v2/ticker/%s", currencyPair) + path := "/v2/ticker/" + currencyPair err := g.SendHTTPRequest(ctx, exchange.RestSpot, path, &ticker) if err != nil { return ticker, err @@ -334,7 +334,7 @@ func (g *Gemini) GetCryptoDepositAddress(ctx context.Context, depositAddlabel, c response := DepositAddress{} req := make(map[string]interface{}) - if len(depositAddlabel) > 0 { + if depositAddlabel != "" { req["label"] = depositAddlabel } diff --git a/exchanges/hitbtc/hitbtc.go b/exchanges/hitbtc/hitbtc.go index b68a33ffaaa..d284b036141 100644 --- a/exchanges/hitbtc/hitbtc.go +++ b/exchanges/hitbtc/hitbtc.go @@ -10,6 +10,7 @@ import ( "strconv" "time" + "github.com/thrasher-corp/gocryptotrader/common" "github.com/thrasher-corp/gocryptotrader/common/crypto" "github.com/thrasher-corp/gocryptotrader/currency" exchange "github.com/thrasher-corp/gocryptotrader/exchanges" @@ -21,12 +22,12 @@ const ( apiURL = "https://api.hitbtc.com" // Public - apiV2Trades = "api/2/public/trades" - apiV2Currency = "api/2/public/currency" - apiV2Symbol = "api/2/public/symbol" - apiV2Ticker = "api/2/public/ticker" - apiV2Orderbook = "api/2/public/orderbook" - apiV2Candles = "api/2/public/candles" + apiV2Trades = "/api/2/public/trades" + apiV2Currency = "/api/2/public/currency" + apiV2Symbol = "/api/2/public/symbol" + apiV2Ticker = "/api/2/public/ticker" + apiV2Orderbook = "/api/2/public/orderbook" + apiV2Candles = "/api/2/public/candles" // Authenticated apiV2Balance = "api/2/trading/balance" @@ -58,10 +59,8 @@ func (h *HitBTC) GetCurrencies(ctx context.Context) (map[string]Currencies, erro Data []Currencies } resp := Response{} - path := fmt.Sprintf("/%s", apiV2Currency) - ret := make(map[string]Currencies) - err := h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp.Data) + err := h.SendHTTPRequest(ctx, exchange.RestSpot, apiV2Currency, &resp.Data) if err != nil { return ret, err } @@ -79,7 +78,7 @@ func (h *HitBTC) GetCurrency(ctx context.Context, currency string) (Currencies, Data Currencies } resp := Response{} - path := fmt.Sprintf("/%s/%s", apiV2Currency, currency) + path := apiV2Currency + "/" + currency return resp.Data, h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp.Data) } @@ -91,7 +90,7 @@ func (h *HitBTC) GetCurrency(ctx context.Context, currency string) (Currencies, // of the base currency. func (h *HitBTC) GetSymbols(ctx context.Context, symbol string) ([]string, error) { var resp []Symbol - path := fmt.Sprintf("/%s/%s", apiV2Symbol, symbol) + path := apiV2Symbol + "/" + symbol ret := make([]string, 0, len(resp)) err := h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) @@ -109,22 +108,20 @@ func (h *HitBTC) GetSymbols(ctx context.Context, symbol string) ([]string, error // all their details. func (h *HitBTC) GetSymbolsDetailed(ctx context.Context) ([]Symbol, error) { var resp []Symbol - path := fmt.Sprintf("/%s", apiV2Symbol) - return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) + return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, apiV2Symbol, &resp) } // GetTicker returns ticker information func (h *HitBTC) GetTicker(ctx context.Context, symbol string) (TickerResponse, error) { var resp TickerResponse - path := fmt.Sprintf("/%s/%s", apiV2Ticker, symbol) + path := apiV2Ticker + "/" + symbol return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) } // GetTickers returns ticker information func (h *HitBTC) GetTickers(ctx context.Context) ([]TickerResponse, error) { var resp []TickerResponse - path := fmt.Sprintf("/%s/", apiV2Ticker) - return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) + return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, apiV2Ticker, &resp) } // GetTrades returns trades from hitbtc @@ -150,10 +147,7 @@ func (h *HitBTC) GetTrades(ctx context.Context, currencyPair, by, sort string, f } var resp []TradeHistory - path := fmt.Sprintf("/%s/%s?%s", - apiV2Trades, - currencyPair, - urlValues.Encode()) + path := common.EncodeURLValues(apiV2Trades+"/"+currencyPair, urlValues) return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) } @@ -168,10 +162,7 @@ func (h *HitBTC) GetOrderbook(ctx context.Context, currencyPair string, limit in } var resp Orderbook - path := fmt.Sprintf("/%s/%s?%s", - apiV2Orderbook, - currencyPair, - vals.Encode()) + path := common.EncodeURLValues(apiV2Orderbook+"/"+currencyPair, vals) err := h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) if err != nil { return nil, err @@ -206,7 +197,7 @@ func (h *HitBTC) GetCandles(ctx context.Context, currencyPair, limit, period str } var resp []ChartData - path := "/" + apiV2Candles + "/" + currencyPair + "?" + vals.Encode() + path := common.EncodeURLValues(apiV2Candles+"/"+currencyPair, vals) return resp, h.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) } diff --git a/exchanges/hitbtc/hitbtc_test.go b/exchanges/hitbtc/hitbtc_test.go index d2c6a6c9e83..3e629d0a654 100644 --- a/exchanges/hitbtc/hitbtc_test.go +++ b/exchanges/hitbtc/hitbtc_test.go @@ -460,7 +460,6 @@ func TestGetDepositAddress(t *testing.T) { } } -//nolint:gocritic // Only used as a testing helper function in this package func setupWsAuth(t *testing.T) { t.Helper() if wsSetupRan { diff --git a/exchanges/huobi/huobi.go b/exchanges/huobi/huobi.go index d1511cde370..ad3cad6c826 100644 --- a/exchanges/huobi/huobi.go +++ b/exchanges/huobi/huobi.go @@ -583,7 +583,7 @@ func (h *HUOBI) GetOpenOrders(ctx context.Context, symbol currency.Pair, account } vals.Set("symbol", symbolValue) vals.Set("accountID", accountID) - if len(side) > 0 { + if side != "" { vals.Set("side", side) } vals.Set("size", strconv.FormatInt(size, 10)) diff --git a/exchanges/huobi/huobi_cfutures.go b/exchanges/huobi/huobi_cfutures.go index 22488ffd069..d72733b6a0b 100644 --- a/exchanges/huobi/huobi_cfutures.go +++ b/exchanges/huobi/huobi_cfutures.go @@ -3,7 +3,6 @@ package huobi import ( "context" "errors" - "fmt" "net/http" "net/url" "strconv" @@ -138,7 +137,7 @@ func (h *HUOBI) GetSwapKlineData(ctx context.Context, code currency.Pair, period return resp, err } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params := url.Values{} params.Set("contract_code", codeValue) @@ -250,14 +249,14 @@ func (h *HUOBI) GetOpenInterestInfo(ctx context.Context, code currency.Pair, per return resp, err } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } if size <= 0 || size > 1200 { - return resp, fmt.Errorf("invalid size provided, only values between 1-1200 are supported") + return resp, errors.New("invalid size provided, only values between 1-1200 are supported") } aType, ok := validAmountType[amountType] if !ok { - return resp, fmt.Errorf("invalid trade type") + return resp, errors.New("invalid trade type") } params := url.Values{} params.Set("contract_code", codeValue) @@ -289,7 +288,7 @@ func (h *HUOBI) GetTraderSentimentIndexAccount(ctx context.Context, code currenc return resp, err } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params := url.Values{} params.Set("contract_code", codeValue) @@ -307,7 +306,7 @@ func (h *HUOBI) GetTraderSentimentIndexPosition(ctx context.Context, code curren } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params := url.Values{} params.Set("contract_code", codeValue) @@ -325,7 +324,7 @@ func (h *HUOBI) GetLiquidationOrders(ctx context.Context, contract currency.Pair } tType, ok := validTradeTypes[tradeType] if !ok { - return resp, fmt.Errorf("invalid trade type") + return resp, errors.New("invalid trade type") } params := url.Values{} params.Set("contract", formattedContract) @@ -374,10 +373,10 @@ func (h *HUOBI) GetPremiumIndexKlineData(ctx context.Context, code currency.Pair return resp, err } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } if size <= 0 || size > 1200 { - return resp, fmt.Errorf("invalid size provided, only values between 1-1200 are supported") + return resp, errors.New("invalid size provided, only values between 1-1200 are supported") } params := url.Values{} params.Set("contract_code", codeValue) @@ -395,10 +394,10 @@ func (h *HUOBI) GetEstimatedFundingRates(ctx context.Context, code currency.Pair return resp, err } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } if size <= 0 || size > 1200 { - return resp, fmt.Errorf("invalid size provided, only values between 1-1200 are supported") + return resp, errors.New("invalid size provided, only values between 1-1200 are supported") } params := url.Values{} params.Set("contract_code", codeValue) @@ -416,13 +415,13 @@ func (h *HUOBI) GetBasisData(ctx context.Context, code currency.Pair, period, ba return resp, err } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } if size <= 0 || size > 1200 { - return resp, fmt.Errorf("invalid size provided, only values between 1-1200 are supported") + return resp, errors.New("invalid size provided, only values between 1-1200 are supported") } if !common.StringDataCompareInsensitive(validBasisPriceTypes, basisPriceType) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params := url.Values{} params.Set("contract_code", codeValue) @@ -583,7 +582,7 @@ func (h *HUOBI) GetSwapOrderLimitInfo(ctx context.Context, code currency.Pair, o } req["contract_code"] = codeValue if !common.StringDataCompareInsensitive(validOrderTypes, orderType) { - return resp, fmt.Errorf("invalid ordertype provided") + return resp, errors.New("invalid ordertype provided") } req["order_price_type"] = orderType return resp, h.FuturesAuthenticatedHTTPRequest(ctx, exchange.RestFutures, http.MethodPost, huobiSwapOrderLimitInfo, nil, req, &resp) @@ -637,7 +636,7 @@ func (h *HUOBI) AccountTransferData(ctx context.Context, code currency.Pair, sub req["subUid"] = subUID req["amount"] = amount if !common.StringDataCompareInsensitive(validTransferType, transferType) { - return resp, fmt.Errorf("invalid transferType received") + return resp, errors.New("invalid transferType received") } req["type"] = transferType return resp, h.FuturesAuthenticatedHTTPRequest(ctx, exchange.RestFutures, http.MethodPost, huobiSwapInternalTransferData, nil, req, &resp) @@ -653,11 +652,11 @@ func (h *HUOBI) AccountTransferRecords(ctx context.Context, code currency.Pair, } req["contract_code"] = codeValue if !common.StringDataCompareInsensitive(validTransferType, transferType) { - return resp, fmt.Errorf("invalid transferType received") + return resp, errors.New("invalid transferType received") } req["type"] = transferType if createDate > 90 { - return resp, fmt.Errorf("invalid create date value: only supports up to 90 days") + return resp, errors.New("invalid create date value: only supports up to 90 days") } req["create_date"] = strconv.FormatInt(createDate, 10) if pageIndex != 0 { @@ -684,7 +683,7 @@ func (h *HUOBI) PlaceSwapOrders(ctx context.Context, code currency.Pair, clientO req["direction"] = direction req["offset"] = offset if !common.StringDataCompareInsensitive(validOrderTypes, orderPriceType) { - return resp, fmt.Errorf("invalid ordertype provided") + return resp, errors.New("invalid ordertype provided") } req["order_price_type"] = orderPriceType req["price"] = price @@ -698,7 +697,7 @@ func (h *HUOBI) PlaceSwapBatchOrders(ctx context.Context, data BatchOrderRequest var resp BatchOrderData req := make(map[string]interface{}) if len(data.Data) > 10 || len(data.Data) == 0 { - return resp, fmt.Errorf("invalid data provided: maximum of 10 batch orders supported") + return resp, errors.New("invalid data provided: maximum of 10 batch orders supported") } for x := range data.Data { if data.Data[x].ContractCode == "" { @@ -752,7 +751,7 @@ func (h *HUOBI) PlaceLightningCloseOrder(ctx context.Context, contractCode curre } if orderPriceType != "" { if !common.StringDataCompareInsensitive(validLightningOrderPriceType, orderPriceType) { - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } req["order_price_type"] = orderPriceType } @@ -768,7 +767,7 @@ func (h *HUOBI) GetSwapOrderDetails(ctx context.Context, contractCode currency.P req["created_at"] = createdAt oType, ok := validOrderType[orderType] if !ok { - return resp, fmt.Errorf("invalid ordertype") + return resp, errors.New("invalid ordertype") } req["order_type"] = oType if pageIndex != 0 { @@ -829,12 +828,12 @@ func (h *HUOBI) GetSwapOrderHistory(ctx context.Context, contractCode currency.P req["contract_code"] = codeValue tType, ok := validFuturesTradeType[tradeType] if !ok { - return resp, fmt.Errorf("invalid tradeType") + return resp, errors.New("invalid tradeType") } req["trade_type"] = tType rType, ok := validFuturesReqType[reqType] if !ok { - return resp, fmt.Errorf("invalid reqType") + return resp, errors.New("invalid reqType") } req["type"] = rType reqStatus := "0" @@ -843,7 +842,7 @@ func (h *HUOBI) GetSwapOrderHistory(ctx context.Context, contractCode currency.P for x := range status { sType, ok := validOrderStatus[status[x]] if !ok { - return resp, fmt.Errorf("invalid status") + return resp, errors.New("invalid status") } if firstTime { firstTime = false @@ -855,7 +854,7 @@ func (h *HUOBI) GetSwapOrderHistory(ctx context.Context, contractCode currency.P } req["status"] = reqStatus if createDate < 0 || createDate > 90 { - return resp, fmt.Errorf("invalid createDate") + return resp, errors.New("invalid createDate") } req["create_date"] = createDate if pageIndex != 0 { @@ -877,11 +876,11 @@ func (h *HUOBI) GetSwapTradeHistory(ctx context.Context, contractCode currency.P } req["contract_code"] = codeValue if createDate > 90 { - return resp, fmt.Errorf("invalid create date value: only supports up to 90 days") + return resp, errors.New("invalid create date value: only supports up to 90 days") } tType, ok := validTradeType[tradeType] if !ok { - return resp, fmt.Errorf("invalid trade type") + return resp, errors.New("invalid trade type") } req["trade_type"] = tType req["create_date"] = strconv.FormatInt(createDate, 10) @@ -905,7 +904,7 @@ func (h *HUOBI) PlaceSwapTriggerOrder(ctx context.Context, contractCode currency req["contract_code"] = codeValue tType, ok := validTriggerType[triggerType] if !ok { - return resp, fmt.Errorf("invalid trigger type") + return resp, errors.New("invalid trigger type") } req["trigger_type"] = tType req["direction"] = direction @@ -915,7 +914,7 @@ func (h *HUOBI) PlaceSwapTriggerOrder(ctx context.Context, contractCode currency req["lever_rate"] = leverageRate req["order_price"] = orderPrice if !common.StringDataCompareInsensitive(validOrderPriceType, orderPriceType) { - return resp, fmt.Errorf("invalid order price type") + return resp, errors.New("invalid order price type") } req["order_price_type"] = orderPriceType return resp, h.FuturesAuthenticatedHTTPRequest(ctx, exchange.RestFutures, http.MethodPost, huobiSwapTriggerOrder, nil, req, &resp) @@ -954,11 +953,11 @@ func (h *HUOBI) GetSwapTriggerOrderHistory(ctx context.Context, contractCode cur req["status"] = status tType, ok := validTradeType[tradeType] if !ok { - return resp, fmt.Errorf("invalid trade type") + return resp, errors.New("invalid trade type") } req["trade_type"] = tType if createDate > 90 { - return resp, fmt.Errorf("invalid create date value: only supports up to 90 days") + return resp, errors.New("invalid create date value: only supports up to 90 days") } req["create_date"] = strconv.FormatInt(createDate, 10) if pageIndex != 0 { diff --git a/exchanges/huobi/huobi_futures.go b/exchanges/huobi/huobi_futures.go index a1f1ee18306..36d2a836f0a 100644 --- a/exchanges/huobi/huobi_futures.go +++ b/exchanges/huobi/huobi_futures.go @@ -92,7 +92,7 @@ func (h *HUOBI) FGetContractInfo(ctx context.Context, symbol, contractType strin } if contractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, contractType) { - return resp, fmt.Errorf("invalid contractType") + return resp, errors.New("invalid contractType") } params.Set("contract_type", contractType) } @@ -165,7 +165,7 @@ func (h *HUOBI) ContractOpenInterestUSDT(ctx context.Context, contractCode, pair } if contractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, contractType) { - return nil, fmt.Errorf("invalid contractType") + return nil, errors.New("invalid contractType") } params.Set("contract_type", contractType) } @@ -188,7 +188,7 @@ func (h *HUOBI) FContractOpenInterest(ctx context.Context, symbol, contractType } if contractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, contractType) { - return resp, fmt.Errorf("invalid contractType") + return resp, errors.New("invalid contractType") } params.Set("contract_type", contractType) } @@ -264,7 +264,7 @@ func (h *HUOBI) FGetKlineData(ctx context.Context, symbol currency.Pair, period } params.Set("symbol", symbolValue) if !common.StringDataCompareInsensitive(validFuturesPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params.Set("period", period) if size > 0 { @@ -380,7 +380,7 @@ func (h *HUOBI) FQueryHisOpenInterest(ctx context.Context, symbol, contractType, } params.Set("contract_type", contractType) if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period") + return resp, errors.New("invalid period") } params.Set("period", period) if size > 0 || size <= 200 { @@ -388,7 +388,7 @@ func (h *HUOBI) FQueryHisOpenInterest(ctx context.Context, symbol, contractType, } validAmount, ok := validAmountType[amountType] if !ok { - return resp, fmt.Errorf("invalid amountType") + return resp, errors.New("invalid amountType") } params.Set("amount_type", strconv.FormatInt(validAmount, 10)) path := common.EncodeURLValues(fHisContractOpenInterest, params) @@ -418,7 +418,7 @@ func (h *HUOBI) FQueryTopAccountsRatio(ctx context.Context, symbol, period strin params.Set("symbol", symbol) } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period") + return resp, errors.New("invalid period") } params.Set("period", period) path := common.EncodeURLValues(fTopAccountsSentiment, params) @@ -433,7 +433,7 @@ func (h *HUOBI) FQueryTopPositionsRatio(ctx context.Context, symbol, period stri params.Set("symbol", symbol) } if !common.StringDataCompareInsensitive(validPeriods, period) { - return resp, fmt.Errorf("invalid period") + return resp, errors.New("invalid period") } params.Set("period", period) path := common.EncodeURLValues(fTopPositionsSentiment, params) @@ -445,7 +445,7 @@ func (h *HUOBI) FLiquidationOrders(ctx context.Context, symbol currency.Code, tr var resp LiquidationOrdersData tType, ok := validTradeTypes[tradeType] if !ok { - return resp, fmt.Errorf("invalid trade type") + return resp, errors.New("invalid trade type") } params := url.Values{} params.Set("symbol", symbol.String()) @@ -477,11 +477,11 @@ func (h *HUOBI) FIndexKline(ctx context.Context, symbol currency.Pair, period st } params.Set("symbol", symbolValue) if !common.StringDataCompareInsensitive(validFuturesPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params.Set("period", period) if size <= 0 || size > 2000 { - return resp, fmt.Errorf("invalid size") + return resp, errors.New("invalid size") } params.Set("size", strconv.FormatInt(size, 10)) path := common.EncodeURLValues(fIndexKline, params) @@ -498,7 +498,7 @@ func (h *HUOBI) FGetBasisData(ctx context.Context, symbol currency.Pair, period, } params.Set("symbol", symbolValue) if !common.StringDataCompareInsensitive(validFuturesPeriods, period) { - return resp, fmt.Errorf("invalid period value received") + return resp, errors.New("invalid period value received") } params.Set("period", period) if basisPriceType != "" { @@ -587,7 +587,7 @@ func (h *HUOBI) FGetFinancialRecords(ctx context.Context, symbol, recordType str if recordType != "" { rType, ok := validFuturesRecordTypes[recordType] if !ok { - return resp, fmt.Errorf("invalid recordType") + return resp, errors.New("invalid recordType") } req["type"] = rType } @@ -633,7 +633,7 @@ func (h *HUOBI) FGetOrderLimits(ctx context.Context, symbol, orderPriceType stri } if orderPriceType != "" { if !common.StringDataCompareInsensitive(validFuturesOrderPriceTypes, orderPriceType) { - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } req["order_price_type"] = orderPriceType } @@ -698,7 +698,7 @@ func (h *HUOBI) FTransfer(ctx context.Context, subUID, symbol, transferType stri req["subUid"] = subUID req["amount"] = amount if !common.StringDataCompareInsensitive(validTransferType, transferType) { - return resp, fmt.Errorf("invalid transferType received") + return resp, errors.New("invalid transferType received") } req["type"] = transferType return resp, h.FuturesAuthenticatedHTTPRequest(ctx, exchange.RestFutures, http.MethodPost, fTransfer, nil, req, &resp) @@ -712,11 +712,11 @@ func (h *HUOBI) FGetTransferRecords(ctx context.Context, symbol, transferType st req["symbol"] = symbol } if !common.StringDataCompareInsensitive(validTransferType, transferType) { - return resp, fmt.Errorf("invalid transferType received") + return resp, errors.New("invalid transferType received") } req["type"] = transferType if createDate < 0 || createDate > 90 { - return resp, fmt.Errorf("invalid create date value: only supports up to 90 days") + return resp, errors.New("invalid create date value: only supports up to 90 days") } req["create_date"] = strconv.FormatInt(createDate, 10) if pageIndex != 0 { @@ -751,7 +751,7 @@ func (h *HUOBI) FOrder(ctx context.Context, contractCode currency.Pair, symbol, } if contractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, contractType) { - return resp, fmt.Errorf("invalid contractType") + return resp, errors.New("invalid contractType") } req["contract_type"] = contractType } @@ -774,10 +774,10 @@ func (h *HUOBI) FOrder(ctx context.Context, contractCode currency.Pair, symbol, } req["direction"] = direction if !common.StringDataCompareInsensitive(validOffsetTypes, offset) { - return resp, fmt.Errorf("invalid offset amounts") + return resp, errors.New("invalid offset amounts") } if !common.StringDataCompareInsensitive(validFuturesOrderPriceTypes, orderPriceType) { - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } req["order_price_type"] = orderPriceType req["lever_rate"] = leverageRate @@ -792,7 +792,7 @@ func (h *HUOBI) FPlaceBatchOrder(ctx context.Context, data []fBatchOrderData) (F var resp FBatchOrderResponse req := make(map[string]interface{}) if len(data) > 10 || len(data) == 0 { - return resp, fmt.Errorf("invalid data provided: maximum of 10 batch orders supported") + return resp, errors.New("invalid data provided: maximum of 10 batch orders supported") } for x := range data { if data[x].ContractCode != "" { @@ -808,14 +808,14 @@ func (h *HUOBI) FPlaceBatchOrder(ctx context.Context, data []fBatchOrderData) (F } if data[x].ContractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, data[x].ContractType) { - return resp, fmt.Errorf("invalid contractType") + return resp, errors.New("invalid contractType") } } if !common.StringDataCompareInsensitive(validOffsetTypes, data[x].Offset) { - return resp, fmt.Errorf("invalid offset amounts") + return resp, errors.New("invalid offset amounts") } if !common.StringDataCompareInsensitive(validFuturesOrderPriceTypes, data[x].OrderPriceType) { - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } } req["orders_data"] = data @@ -848,7 +848,7 @@ func (h *HUOBI) FCancelAllOrders(ctx context.Context, contractCode currency.Pair } if contractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, contractType) { - return resp, fmt.Errorf("invalid contractType") + return resp, errors.New("invalid contractType") } req["contract_type"] = contractType } @@ -869,7 +869,7 @@ func (h *HUOBI) FFlashCloseOrder(ctx context.Context, contractCode currency.Pair req["symbol"] = symbol if contractType != "" { if !common.StringDataCompareInsensitive(validContractTypes, contractType) { - return resp, fmt.Errorf("invalid contractType") + return resp, errors.New("invalid contractType") } req["contract_type"] = contractType } @@ -887,7 +887,7 @@ func (h *HUOBI) FFlashCloseOrder(ctx context.Context, contractCode currency.Pair } if orderPriceType != "" { if !common.StringDataCompareInsensitive(validOPTypes, orderPriceType) { - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } req["orderPriceType"] = orderPriceType } @@ -917,7 +917,7 @@ func (h *HUOBI) FOrderDetails(ctx context.Context, symbol, orderID, orderType st req["created_at"] = strconv.FormatInt(createdAt.Unix(), 10) oType, ok := validOrderType[orderType] if !ok { - return resp, fmt.Errorf("invalid orderType") + return resp, errors.New("invalid orderType") } req["order_type"] = oType if pageIndex != 0 { @@ -950,12 +950,12 @@ func (h *HUOBI) FGetOrderHistory(ctx context.Context, contractCode currency.Pair req["symbol"] = symbol tType, ok := validFuturesTradeType[tradeType] if !ok { - return resp, fmt.Errorf("invalid tradeType") + return resp, errors.New("invalid tradeType") } req["trade_type"] = tType rType, ok := validFuturesReqType[reqType] if !ok { - return resp, fmt.Errorf("invalid reqType") + return resp, errors.New("invalid reqType") } req["type"] = rType reqStatus := "0" @@ -964,7 +964,7 @@ func (h *HUOBI) FGetOrderHistory(ctx context.Context, contractCode currency.Pair for x := range status { sType, ok := validOrderStatus[status[x]] if !ok { - return resp, fmt.Errorf("invalid status") + return resp, errors.New("invalid status") } if firstTime { firstTime = false @@ -976,7 +976,7 @@ func (h *HUOBI) FGetOrderHistory(ctx context.Context, contractCode currency.Pair } req["status"] = reqStatus if createDate < 0 || createDate > 90 { - return resp, fmt.Errorf("invalid createDate") + return resp, errors.New("invalid createDate") } req["create_date"] = createDate if !contractCode.IsEmpty() { @@ -989,7 +989,7 @@ func (h *HUOBI) FGetOrderHistory(ctx context.Context, contractCode currency.Pair if orderType != "" { oType, ok := validFuturesOrderTypes[orderType] if !ok { - return resp, fmt.Errorf("invalid orderType") + return resp, errors.New("invalid orderType") } req["order_type"] = oType } @@ -1009,7 +1009,7 @@ func (h *HUOBI) FTradeHistory(ctx context.Context, contractCode currency.Pair, s req["symbol"] = symbol tType, ok := validTradeType[tradeType] if !ok { - return resp, fmt.Errorf("invalid tradeType") + return resp, errors.New("invalid tradeType") } req["trade_type"] = tType if !contractCode.IsEmpty() { @@ -1020,7 +1020,7 @@ func (h *HUOBI) FTradeHistory(ctx context.Context, contractCode currency.Pair, s req["contract_code"] = codeValue } if createDate <= 0 || createDate > 90 { - return resp, fmt.Errorf("invalid createDate") + return resp, errors.New("invalid createDate") } req["create_date"] = createDate if pageIndex != 0 { @@ -1054,12 +1054,12 @@ func (h *HUOBI) FPlaceTriggerOrder(ctx context.Context, contractCode currency.Pa } tType, ok := validTriggerType[triggerType] if !ok { - return resp, fmt.Errorf("invalid trigger type") + return resp, errors.New("invalid trigger type") } req["trigger_type"] = tType req["direction"] = direction if !common.StringDataCompareInsensitive(validOffsetTypes, offset) { - return resp, fmt.Errorf("invalid offset") + return resp, errors.New("invalid offset") } req["offset"] = offset req["trigger_price"] = triggerPrice @@ -1067,7 +1067,7 @@ func (h *HUOBI) FPlaceTriggerOrder(ctx context.Context, contractCode currency.Pa req["lever_rate"] = leverageRate req["order_price"] = orderPrice if !common.StringDataCompareInsensitive(validOrderPriceType, orderPriceType) { - return resp, fmt.Errorf("invalid order price type") + return resp, errors.New("invalid order price type") } req["order_price_type"] = orderPriceType return resp, h.FuturesAuthenticatedHTTPRequest(ctx, exchange.RestFutures, http.MethodPost, fTriggerOrder, nil, req, &resp) @@ -1139,17 +1139,17 @@ func (h *HUOBI) FQueryTriggerOrderHistory(ctx context.Context, contractCode curr if tradeType != "" { tType, ok := validTradeType[tradeType] if !ok { - return resp, fmt.Errorf("invalid tradeType") + return resp, errors.New("invalid tradeType") } req["trade_type"] = tType } validStatus, ok := validStatusTypes[status] if !ok { - return resp, fmt.Errorf("invalid status") + return resp, errors.New("invalid status") } req["status"] = validStatus if createDate <= 0 || createDate > 90 { - return resp, fmt.Errorf("invalid createDate") + return resp, errors.New("invalid createDate") } req["create_date"] = createDate if pageIndex != 0 { diff --git a/exchanges/huobi/huobi_test.go b/exchanges/huobi/huobi_test.go index 6f6d9d8ebe0..4aafc7b74a5 100644 --- a/exchanges/huobi/huobi_test.go +++ b/exchanges/huobi/huobi_test.go @@ -2886,7 +2886,7 @@ func TestConvertContractShortHandToExpiry(t *testing.T) { cp := currency.NewPair(currency.BTC, currency.NewCode("CW")) cp, err := h.convertContractShortHandToExpiry(cp, tt) assert.NoError(t, err) - assert.NotEqual(t, cp.Quote.String(), "CW") + assert.NotEqual(t, "CW", cp.Quote.String()) tick, err := h.FetchTicker(context.Background(), cp, asset.Futures) if assert.NoError(t, err) { assert.NotZero(t, tick.Close) @@ -2895,7 +2895,7 @@ func TestConvertContractShortHandToExpiry(t *testing.T) { cp = currency.NewPair(currency.BTC, currency.NewCode("NW")) cp, err = h.convertContractShortHandToExpiry(cp, tt) assert.NoError(t, err) - assert.NotEqual(t, cp.Quote.String(), "NW") + assert.NotEqual(t, "NW", cp.Quote.String()) tick, err = h.FetchTicker(context.Background(), cp, asset.Futures) if assert.NoError(t, err) { assert.NotZero(t, tick.Close) @@ -2904,7 +2904,7 @@ func TestConvertContractShortHandToExpiry(t *testing.T) { cp = currency.NewPair(currency.BTC, currency.NewCode("CQ")) cp, err = h.convertContractShortHandToExpiry(cp, tt) assert.NoError(t, err) - assert.NotEqual(t, cp.Quote.String(), "CQ") + assert.NotEqual(t, "CQ", cp.Quote.String()) tick, err = h.FetchTicker(context.Background(), cp, asset.Futures) if assert.NoError(t, err) { assert.NotZero(t, tick.Close) @@ -2915,12 +2915,12 @@ func TestConvertContractShortHandToExpiry(t *testing.T) { tt = time.Date(2021, 6, 3, 0, 0, 0, 0, time.UTC) cp, err = h.convertContractShortHandToExpiry(cp, tt) assert.NoError(t, err) - assert.Equal(t, cp.Quote.String(), "210625") + assert.Equal(t, "210625", cp.Quote.String()) cp = currency.NewPair(currency.BTC, currency.NewCode("CW")) cp, err = h.convertContractShortHandToExpiry(cp, tt) assert.NoError(t, err) - assert.Equal(t, cp.Quote.String(), "210604") + assert.Equal(t, "210604", cp.Quote.String()) cp = currency.NewPair(currency.BTC, currency.NewCode("CWif hat")) _, err = h.convertContractShortHandToExpiry(cp, tt) @@ -2930,7 +2930,7 @@ func TestConvertContractShortHandToExpiry(t *testing.T) { cp = currency.NewPair(currency.BTC, currency.NewCode("NQ")) cp, err = h.convertContractShortHandToExpiry(cp, tt) assert.NoError(t, err) - assert.NotEqual(t, cp.Quote.String(), "NQ") + assert.NotEqual(t, "NQ", cp.Quote.String()) tick, err = h.FetchTicker(context.Background(), cp, asset.Futures) if err != nil { // Huobi doesn't always have a next-quarter contract, return if no data found diff --git a/exchanges/huobi/huobi_wrapper.go b/exchanges/huobi/huobi_wrapper.go index 62cada36bd0..3d1d576b9d2 100644 --- a/exchanges/huobi/huobi_wrapper.go +++ b/exchanges/huobi/huobi_wrapper.go @@ -514,10 +514,10 @@ func (h *HUOBI) UpdateTicker(ctx context.Context, p currency.Pair, a asset.Item) } if len(marketData.Tick.Bid) == 0 { - return nil, fmt.Errorf("invalid data for bid") + return nil, errors.New("invalid data for bid") } if len(marketData.Tick.Ask) == 0 { - return nil, fmt.Errorf("invalid data for Ask") + return nil, errors.New("invalid data for Ask") } err = ticker.ProcessTicker(&ticker.Price{ @@ -1252,7 +1252,7 @@ func (h *HUOBI) CancelAllOrders(ctx context.Context, orderCancellation *order.Ca cancelAllOrdersResponse.Status[split[x]] = "success" } for y := range a.Errors { - cancelAllOrdersResponse.Status[a.Errors[y].OrderID] = fmt.Sprintf("fail: %s", a.Errors[y].ErrMsg) + cancelAllOrdersResponse.Status[a.Errors[y].OrderID] = "fail: " + a.Errors[y].ErrMsg } } } else { @@ -1265,7 +1265,7 @@ func (h *HUOBI) CancelAllOrders(ctx context.Context, orderCancellation *order.Ca cancelAllOrdersResponse.Status[split[x]] = "success" } for y := range a.Errors { - cancelAllOrdersResponse.Status[a.Errors[y].OrderID] = fmt.Sprintf("fail: %s", a.Errors[y].ErrMsg) + cancelAllOrdersResponse.Status[a.Errors[y].OrderID] = "fail: " + a.Errors[y].ErrMsg } } case asset.Futures: @@ -1284,7 +1284,7 @@ func (h *HUOBI) CancelAllOrders(ctx context.Context, orderCancellation *order.Ca cancelAllOrdersResponse.Status[split[x]] = "success" } for y := range a.Data.Errors { - cancelAllOrdersResponse.Status[strconv.FormatInt(a.Data.Errors[y].OrderID, 10)] = fmt.Sprintf("fail: %s", a.Data.Errors[y].ErrMsg) + cancelAllOrdersResponse.Status[strconv.FormatInt(a.Data.Errors[y].OrderID, 10)] = "fail: " + a.Data.Errors[y].ErrMsg } } } else { @@ -1297,7 +1297,7 @@ func (h *HUOBI) CancelAllOrders(ctx context.Context, orderCancellation *order.Ca cancelAllOrdersResponse.Status[split[x]] = "success" } for y := range a.Data.Errors { - cancelAllOrdersResponse.Status[strconv.FormatInt(a.Data.Errors[y].OrderID, 10)] = fmt.Sprintf("fail: %s", a.Data.Errors[y].ErrMsg) + cancelAllOrdersResponse.Status[strconv.FormatInt(a.Data.Errors[y].OrderID, 10)] = "fail: " + a.Data.Errors[y].ErrMsg } } } @@ -1479,7 +1479,7 @@ func (h *HUOBI) GetDepositAddress(ctx context.Context, cryptocurrency currency.C }, nil } } - return nil, fmt.Errorf("unable to match deposit address currency or chain") + return nil, errors.New("unable to match deposit address currency or chain") } // WithdrawCryptocurrencyFunds returns a withdrawal ID when a withdrawal is @@ -2085,7 +2085,7 @@ func compatibleVars(side, orderPriceType string, status int64) (OrderVars, error case "sell": resp.Side = order.Sell default: - return resp, fmt.Errorf("invalid orderSide") + return resp, errors.New("invalid orderSide") } switch orderPriceType { case "limit": @@ -2095,7 +2095,7 @@ func compatibleVars(side, orderPriceType string, status int64) (OrderVars, error case "post_only": resp.OrderType = order.PostOnly default: - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } switch status { case 1, 2, 11: @@ -2111,7 +2111,7 @@ func compatibleVars(side, orderPriceType string, status int64) (OrderVars, error case 7: resp.Status = order.Cancelled default: - return resp, fmt.Errorf("invalid orderStatus") + return resp, errors.New("invalid orderStatus") } return resp, nil } diff --git a/exchanges/kraken/kraken.go b/exchanges/kraken/kraken.go index 126d7ba8b1e..730a61f34f2 100644 --- a/exchanges/kraken/kraken.go +++ b/exchanges/kraken/kraken.go @@ -569,11 +569,11 @@ func (k *Kraken) GetTradeBalance(ctx context.Context, args ...TradeBalanceOption params := url.Values{} if args != nil { - if len(args[0].Aclass) > 0 { + if args[0].Aclass != "" { params.Set("aclass", args[0].Aclass) } - if len(args[0].Asset) > 0 { + if args[0].Asset != "" { params.Set("asset", args[0].Asset) } } @@ -626,11 +626,11 @@ func (k *Kraken) GetClosedOrders(ctx context.Context, args GetClosedOrdersOption params.Set("userref", strconv.FormatInt(int64(args.UserRef), 10)) } - if len(args.Start) > 0 { + if args.Start != "" { params.Set("start", args.Start) } - if len(args.End) > 0 { + if args.End != "" { params.Set("end", args.End) } @@ -638,7 +638,7 @@ func (k *Kraken) GetClosedOrders(ctx context.Context, args GetClosedOrdersOption params.Set("ofs", strconv.FormatInt(args.Ofs, 10)) } - if len(args.CloseTime) > 0 { + if args.CloseTime != "" { params.Set("closetime", args.CloseTime) } @@ -689,7 +689,7 @@ func (k *Kraken) GetTradesHistory(ctx context.Context, args ...GetTradesHistoryO params := url.Values{} if args != nil { - if len(args[0].Type) > 0 { + if args[0].Type != "" { params.Set("type", args[0].Type) } @@ -697,11 +697,11 @@ func (k *Kraken) GetTradesHistory(ctx context.Context, args ...GetTradesHistoryO params.Set("trades", "true") } - if len(args[0].Start) > 0 { + if args[0].Start != "" { params.Set("start", args[0].Start) } - if len(args[0].End) > 0 { + if args[0].End != "" { params.Set("end", args[0].End) } diff --git a/exchanges/kraken/kraken_websocket.go b/exchanges/kraken/kraken_websocket.go index e7913668412..787d52b2c31 100644 --- a/exchanges/kraken/kraken_websocket.go +++ b/exchanges/kraken/kraken_websocket.go @@ -838,7 +838,7 @@ func (k *Kraken) wsProcessOrderBook(channelData *WebsocketChannelData, data map[ if asksExist || bidsExist { checksum, ok := data["c"].(string) if !ok { - return fmt.Errorf("could not process orderbook update checksum not found") + return errors.New("could not process orderbook update checksum not found") } k.wsRequestMtx.Lock() @@ -1414,7 +1414,7 @@ func (k *Kraken) wsCancelOrders(orderIDs []string) error { if cancelOrdersStatus[id].Error != "" || len(orderIDs) != successful { // strange Kraken logic ... var reason string if cancelOrdersStatus[id].Error != "" { - reason = fmt.Sprintf(" Reason: %s", cancelOrdersStatus[id].Error) + reason = " Reason: " + cancelOrdersStatus[id].Error } return fmt.Errorf("%s cancelled %d out of %d orders.%s", k.Name, successful, len(orderIDs), reason) diff --git a/exchanges/kraken/kraken_wrapper.go b/exchanges/kraken/kraken_wrapper.go index f2314180542..9d2503adebc 100644 --- a/exchanges/kraken/kraken_wrapper.go +++ b/exchanges/kraken/kraken_wrapper.go @@ -1474,7 +1474,7 @@ func (k *Kraken) GetOrderHistory(ctx context.Context, getOrdersRequest *order.Mu Pair: pairs[p], }) default: - return orders, fmt.Errorf("invalid orderHistory data") + return orders, errors.New("invalid orderHistory data") } } } @@ -1566,7 +1566,7 @@ func compatibleOrderSide(side string) (order.Side, error) { case strings.EqualFold(order.Sell.String(), side): return order.Sell, nil } - return order.AnySide, fmt.Errorf("invalid side received") + return order.AnySide, errors.New("invalid side received") } func compatibleOrderType(orderType string) (order.Type, error) { @@ -1579,7 +1579,7 @@ func compatibleOrderType(orderType string) (order.Type, error) { case "take_profit": resp = order.TakeProfit default: - return resp, fmt.Errorf("invalid orderType") + return resp, errors.New("invalid orderType") } return resp, nil } @@ -1594,7 +1594,7 @@ func compatibleFillOrderType(fillType string) (order.Type, error) { case "liquidation": resp = order.Liquidation default: - return resp, fmt.Errorf("invalid orderPriceType") + return resp, errors.New("invalid orderPriceType") } return resp, nil } diff --git a/exchanges/kucoin/kucoin_test.go b/exchanges/kucoin/kucoin_test.go index 5518c5a35d5..302af45eb0c 100644 --- a/exchanges/kucoin/kucoin_test.go +++ b/exchanges/kucoin/kucoin_test.go @@ -1995,7 +1995,7 @@ func TestPushData(t *testing.T) { func verifySubs(tb testing.TB, subs []subscription.Subscription, a asset.Item, prefix string, expected ...string) { tb.Helper() var sub *subscription.Subscription - for i, s := range subs { + for i, s := range subs { //nolint:gocritic // prefer convenience over performance here for tests if s.Asset == a && strings.HasPrefix(s.Channel, prefix) { if len(expected) == 1 && !strings.Contains(s.Channel, expected[0]) { continue @@ -2510,7 +2510,7 @@ func TestProcessMarketSnapshot(t *testing.T) { assert.Equal(t, time.UnixMilli(1700555340197), v.LastUpdated, "datetime") assert.Contains(t, []asset.Item{asset.Spot, asset.Margin}, v.AssetType, "AssetType is Spot or Margin") seenAssetTypes[v.AssetType]++ - assert.Equal(t, seenAssetTypes[v.AssetType], 1, "Each Asset Type is sent only once per unique snapshot") + assert.Equal(t, 1, seenAssetTypes[v.AssetType], "Each Asset Type is sent only once per unique snapshot") assert.Equal(t, 0.054846, v.High, "high") assert.Equal(t, 0.053778, v.Last, "lastTradedPrice") assert.Equal(t, 0.05364, v.Low, "low") @@ -2640,7 +2640,7 @@ func TestChangePositionMargin(t *testing.T) { req.NewAllocatedMargin = 1337 _, err = ku.ChangePositionMargin(context.Background(), req) - assert.ErrorIs(t, err, nil) + assert.NoError(t, err) } func TestGetFuturesPositionSummary(t *testing.T) { @@ -2659,7 +2659,7 @@ func TestGetFuturesPositionSummary(t *testing.T) { sharedtestvalues.SkipTestIfCredentialsUnset(t, ku, canManipulateRealOrders) req.Pair = currency.NewPair(currency.XBT, currency.USDTM) _, err = ku.GetFuturesPositionSummary(context.Background(), req) - assert.ErrorIs(t, err, nil) + assert.NoError(t, err) } func TestGetFuturesPositionOrders(t *testing.T) { @@ -2685,7 +2685,7 @@ func TestGetFuturesPositionOrders(t *testing.T) { req.EndDate = time.Now() req.StartDate = req.EndDate.Add(-time.Hour * 24 * 7) _, err = ku.GetFuturesPositionOrders(context.Background(), req) - assert.ErrorIs(t, err, nil) + assert.NoError(t, err) req.StartDate = req.EndDate.Add(-time.Hour * 24 * 30) _, err = ku.GetFuturesPositionOrders(context.Background(), req) @@ -2693,7 +2693,7 @@ func TestGetFuturesPositionOrders(t *testing.T) { req.RespectOrderHistoryLimits = true _, err = ku.GetFuturesPositionOrders(context.Background(), req) - assert.ErrorIs(t, err, nil) + assert.NoError(t, err) } func TestUpdateOrderExecutionLimits(t *testing.T) { diff --git a/exchanges/kucoin/kucoin_wrapper.go b/exchanges/kucoin/kucoin_wrapper.go index e00abb75f92..8a98a77a02d 100644 --- a/exchanges/kucoin/kucoin_wrapper.go +++ b/exchanges/kucoin/kucoin_wrapper.go @@ -1350,7 +1350,7 @@ func (ku *Kucoin) GetFeeByType(ctx context.Context, feeBuilder *exchange.FeeBuil } return feeBuilder.Amount * fee.TakerFeeRate, nil } - return 0, fmt.Errorf("can't construct fee") + return 0, errors.New("can't construct fee") } } diff --git a/exchanges/okx/okx.go b/exchanges/okx/okx.go index 232754c507f..62b55617318 100644 --- a/exchanges/okx/okx.go +++ b/exchanges/okx/okx.go @@ -484,7 +484,7 @@ func (ok *Okx) CancelSingleOrder(ctx context.Context, arg CancelOrderRequestPara return nil, errMissingInstrumentID } if arg.OrderID == "" && arg.ClientOrderID == "" { - return nil, fmt.Errorf("either order id or client id is required") + return nil, errors.New("either order id or client id is required") } var resp []OrderData err := ok.SendHTTPRequest(ctx, exchange.RestSpot, cancelOrderEPL, http.MethodPost, cancelTradeOrder, &arg, &resp, true) @@ -509,7 +509,7 @@ func (ok *Okx) CancelMultipleOrders(ctx context.Context, args []CancelOrderReque return nil, errMissingInstrumentID } if arg.OrderID == "" && arg.ClientOrderID == "" { - return nil, fmt.Errorf("either order id or client id is required") + return nil, errors.New("either order id or client id is required") } } var resp []OrderData @@ -2079,7 +2079,7 @@ func (ok *Okx) GetMaximumAvailableTradableAmount(ctx context.Context, instrument } // IncreaseDecreaseMargin Increase or decrease the margin of the isolated position. Margin reduction may result in the change of the actual leverage. -func (ok *Okx) IncreaseDecreaseMargin(ctx context.Context, arg IncreaseDecreaseMarginInput) (*IncreaseDecreaseMargin, error) { +func (ok *Okx) IncreaseDecreaseMargin(ctx context.Context, arg *IncreaseDecreaseMarginInput) (*IncreaseDecreaseMargin, error) { if arg.InstrumentID == "" { return nil, errMissingInstrumentID } @@ -2499,7 +2499,7 @@ func (ok *Okx) HistoryOfSubaccountTransfer(ctx context.Context, currency, subacc } // MasterAccountsManageTransfersBetweenSubaccounts master accounts manage the transfers between sub-accounts applies to master accounts only -func (ok *Okx) MasterAccountsManageTransfersBetweenSubaccounts(ctx context.Context, arg SubAccountAssetTransferParams) ([]TransferIDInfo, error) { +func (ok *Okx) MasterAccountsManageTransfersBetweenSubaccounts(ctx context.Context, arg *SubAccountAssetTransferParams) ([]TransferIDInfo, error) { if arg.Currency == "" { return nil, errInvalidCurrencyValue } diff --git a/exchanges/okx/okx_test.go b/exchanges/okx/okx_test.go index afae4f275f6..6abe10257be 100644 --- a/exchanges/okx/okx_test.go +++ b/exchanges/okx/okx_test.go @@ -1405,7 +1405,7 @@ func TestIncreaseDecreaseMargin(t *testing.T) { t.Parallel() sharedtestvalues.SkipTestIfCredentialsUnset(t, ok, canManipulateRealOrders) - if _, err := ok.IncreaseDecreaseMargin(contextGenerate(), IncreaseDecreaseMarginInput{ + if _, err := ok.IncreaseDecreaseMargin(contextGenerate(), &IncreaseDecreaseMarginInput{ InstrumentID: "BTC-USDT", PositionSide: "long", Type: "add", @@ -1620,13 +1620,13 @@ func TestMasterAccountsManageTransfersBetweenSubaccounts(t *testing.T) { t.Parallel() sharedtestvalues.SkipTestIfCredentialsUnset(t, ok, canManipulateRealOrders) - if _, err := ok.MasterAccountsManageTransfersBetweenSubaccounts(contextGenerate(), SubAccountAssetTransferParams{Currency: "BTC", Amount: 1200, From: 9, To: 9, FromSubAccount: "", ToSubAccount: "", LoanTransfer: true}); err != nil && !errors.Is(err, errInvalidSubaccount) { + if _, err := ok.MasterAccountsManageTransfersBetweenSubaccounts(contextGenerate(), &SubAccountAssetTransferParams{Currency: "BTC", Amount: 1200, From: 9, To: 9, FromSubAccount: "", ToSubAccount: "", LoanTransfer: true}); err != nil && !errors.Is(err, errInvalidSubaccount) { t.Error("Okx MasterAccountsManageTransfersBetweenSubaccounts() error", err) } - if _, err := ok.MasterAccountsManageTransfersBetweenSubaccounts(contextGenerate(), SubAccountAssetTransferParams{Currency: "BTC", Amount: 1200, From: 8, To: 8, FromSubAccount: "", ToSubAccount: "", LoanTransfer: true}); err != nil && !errors.Is(err, errInvalidSubaccount) { + if _, err := ok.MasterAccountsManageTransfersBetweenSubaccounts(contextGenerate(), &SubAccountAssetTransferParams{Currency: "BTC", Amount: 1200, From: 8, To: 8, FromSubAccount: "", ToSubAccount: "", LoanTransfer: true}); err != nil && !errors.Is(err, errInvalidSubaccount) { t.Error("Okx MasterAccountsManageTransfersBetweenSubaccounts() error", err) } - if _, err := ok.MasterAccountsManageTransfersBetweenSubaccounts(contextGenerate(), SubAccountAssetTransferParams{Currency: "BTC", Amount: 1200, From: 6, To: 6, FromSubAccount: "test1", ToSubAccount: "test2", LoanTransfer: true}); err != nil && !strings.Contains(err.Error(), "Sub-account test1 does not exists") { + if _, err := ok.MasterAccountsManageTransfersBetweenSubaccounts(contextGenerate(), &SubAccountAssetTransferParams{Currency: "BTC", Amount: 1200, From: 6, To: 6, FromSubAccount: "test1", ToSubAccount: "test2", LoanTransfer: true}); err != nil && !strings.Contains(err.Error(), "Sub-account test1 does not exists") { t.Error("Okx MasterAccountsManageTransfersBetweenSubaccounts() error", err) } } diff --git a/exchanges/okx/okx_websocket.go b/exchanges/okx/okx_websocket.go index af43c2ce922..b4d211eec01 100644 --- a/exchanges/okx/okx_websocket.go +++ b/exchanges/okx/okx_websocket.go @@ -1485,7 +1485,7 @@ func (ok *Okx) WsCancelOrder(arg CancelOrderRequestParam) (*OrderData, error) { return nil, errMissingInstrumentID } if arg.OrderID == "" && arg.ClientOrderID == "" { - return nil, fmt.Errorf("either order id or client supplier id is required") + return nil, errors.New("either order id or client supplier id is required") } randomID, err := common.GenerateRandomString(4, common.NumberCharacters) if err != nil { @@ -1544,7 +1544,7 @@ func (ok *Okx) WsCancelMultipleOrder(args []CancelOrderRequestParam) ([]OrderDat return nil, errMissingInstrumentID } if arg.OrderID == "" && arg.ClientOrderID == "" { - return nil, fmt.Errorf("either order id or client supplier id is required") + return nil, errors.New("either order id or client supplier id is required") } } randomID, err := common.GenerateRandomString(4, common.NumberCharacters) diff --git a/exchanges/okx/okx_wrapper.go b/exchanges/okx/okx_wrapper.go index dbc49b73a12..0b5472b9e65 100644 --- a/exchanges/okx/okx_wrapper.go +++ b/exchanges/okx/okx_wrapper.go @@ -737,7 +737,7 @@ func (ok *Okx) SubmitOrder(ctx context.Context, s *order.Submit) (*order.SubmitR return nil, fmt.Errorf("%w: %v", asset.ErrNotSupported, s.AssetType) } if s.Amount <= 0 { - return nil, fmt.Errorf("amount, or size (sz) of quantity to buy or sell hast to be greater than zero ") + return nil, errors.New("amount, or size (sz) of quantity to buy or sell hast to be greater than zero") } pairFormat, err := ok.GetPairFormat(s.AssetType, true) if err != nil { @@ -1784,7 +1784,7 @@ func (ok *Okx) ChangePositionMargin(ctx context.Context, req *margin.PositionCha if req.MarginSide == "" { req.MarginSide = "net" } - r := IncreaseDecreaseMarginInput{ + r := &IncreaseDecreaseMarginInput{ InstrumentID: fPair.String(), PositionSide: req.MarginSide, Type: marginType, diff --git a/exchanges/order/order_test.go b/exchanges/order/order_test.go index 544ae9c23d7..31e5b8c739f 100644 --- a/exchanges/order/order_test.go +++ b/exchanges/order/order_test.go @@ -1513,7 +1513,7 @@ func TestMatchFilter(t *testing.T) { for num, tt := range tests { num := num tt := tt - t.Run(fmt.Sprintf("%v", num), func(t *testing.T) { + t.Run(strconv.Itoa(num), func(t *testing.T) { t.Parallel() if tt.o.MatchFilter(tt.f) != tt.expectedResult { t.Errorf("tests[%v] failed", num) @@ -2056,7 +2056,7 @@ func TestAdjustQuoteAmount(t *testing.T) { func TestSideUnmarshal(t *testing.T) { t.Parallel() var s Side - assert.Nil(t, s.UnmarshalJSON([]byte(`"SELL"`)), "Quoted valid side okay") + assert.NoError(t, s.UnmarshalJSON([]byte(`"SELL"`)), "Quoted valid side okay") assert.Equal(t, Sell, s, "Correctly set order Side") assert.ErrorIs(t, s.UnmarshalJSON([]byte(`"STEAL"`)), ErrSideIsInvalid, "Quoted invalid side errors") var jErr *json.UnmarshalTypeError diff --git a/exchanges/poloniex/poloniex.go b/exchanges/poloniex/poloniex.go index 8bf865ccae4..4183b5a6b61 100644 --- a/exchanges/poloniex/poloniex.go +++ b/exchanges/poloniex/poloniex.go @@ -96,7 +96,7 @@ func (p *Poloniex) GetOrderbook(ctx context.Context, currencyPair string, depth if currencyPair != "" { vals.Set("currencyPair", currencyPair) resp := OrderbookResponse{} - path := fmt.Sprintf("/public?command=returnOrderBook&%s", vals.Encode()) + path := "/public?command=returnOrderBook&" + vals.Encode() err := p.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) if err != nil { return oba, err @@ -141,7 +141,7 @@ func (p *Poloniex) GetOrderbook(ctx context.Context, currencyPair string, depth } else { vals.Set("currencyPair", "all") resp := OrderbookResponseAll{} - path := fmt.Sprintf("/public?command=returnOrderBook&%s", vals.Encode()) + path := "/public?command=returnOrderBook&" + vals.Encode() err := p.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp.Data) if err != nil { return oba, err @@ -199,8 +199,7 @@ func (p *Poloniex) GetTradeHistory(ctx context.Context, currencyPair string, sta } var resp []TradeHistory - path := fmt.Sprintf("/public?command=returnTradeHistory&%s", vals.Encode()) - + path := "/public?command=returnTradeHistory&" + vals.Encode() return resp, p.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) } @@ -277,8 +276,7 @@ func (p *Poloniex) GetTimestamp(ctx context.Context) (time.Time, error) { // currency, specified by the "currency" GET parameter. func (p *Poloniex) GetLoanOrders(ctx context.Context, currency string) (LoanOrders, error) { resp := LoanOrders{} - path := fmt.Sprintf("/public?command=returnLoanOrders¤cy=%s", currency) - + path := "/public?command=returnLoanOrders¤cy=" + currency return resp, p.SendHTTPRequest(ctx, exchange.RestSpot, path, &resp) } @@ -463,7 +461,7 @@ func (p *Poloniex) GetAuthenticatedOrderStatus(ctx context.Context, orderID stri values := url.Values{} if orderID == "" { - return o, fmt.Errorf("no orderID passed") + return o, errors.New("no orderID passed") } values.Set("orderNumber", orderID) @@ -501,7 +499,7 @@ func (p *Poloniex) GetAuthenticatedOrderTrades(ctx context.Context, orderID stri values := url.Values{} if orderID == "" { - return nil, fmt.Errorf("no orderId passed") + return nil, errors.New("no orderID passed") } values.Set("orderNumber", orderID) @@ -512,7 +510,7 @@ func (p *Poloniex) GetAuthenticatedOrderTrades(ctx context.Context, orderID stri } if len(result) == 0 { - return nil, fmt.Errorf("received unexpected response") + return nil, errors.New("received unexpected response") } switch result[0] { @@ -528,7 +526,7 @@ func (p *Poloniex) GetAuthenticatedOrderTrades(ctx context.Context, orderID stri case '[': // data received err = json.Unmarshal(result, &o) default: - return nil, fmt.Errorf("received unexpected response") + return nil, errors.New("received unexpected response") } return o, err diff --git a/exchanges/stream/websocket.go b/exchanges/stream/websocket.go index 373b8dbd2b1..aefc3400f60 100644 --- a/exchanges/stream/websocket.go +++ b/exchanges/stream/websocket.go @@ -893,8 +893,8 @@ func (w *Websocket) GetChannelDifference(genSubs []subscription.Subscription) (s } } - for _, c := range unsubMap { - unsub = append(unsub, c) + for x := range unsubMap { + unsub = append(unsub, unsubMap[x]) } return @@ -988,7 +988,7 @@ func (w *Websocket) AddSuccessfulSubscriptions(channels ...subscription.Subscrip if w.subscriptions == nil { w.subscriptions = subscriptionMap{} } - for _, cN := range channels { + for _, cN := range channels { //nolint:gocritic // See below comment c := cN // cN is an iteration var; Not safe to make a pointer to key := c.EnsureKeyed() c.State = subscription.SubscribedState diff --git a/exchanges/stream/websocket_test.go b/exchanges/stream/websocket_test.go index 752b63124c7..7fb9f9f6ab7 100644 --- a/exchanges/stream/websocket_test.go +++ b/exchanges/stream/websocket_test.go @@ -593,11 +593,11 @@ func TestSubscriptionState(t *testing.T) { ws.AddSuccessfulSubscriptions(*c) found = ws.GetSubscription(42) assert.NotNil(t, found, "Should find the subscription") - assert.Equal(t, found.State, subscription.SubscribedState, "Subscription should be subscribed state") + assert.Equal(t, subscription.SubscribedState, found.State, "Subscription should be subscribed state") assert.NoError(t, ws.SetSubscriptionState(c, subscription.UnsubscribingState), "Setting Unsub state should not error") found = ws.GetSubscription(42) - assert.Equal(t, found.State, subscription.UnsubscribingState, "Subscription should be unsubscribing state") + assert.Equal(t, subscription.UnsubscribingState, found.State, "Subscription should be unsubscribing state") } // TestRemoveSubscriptions tests removing a subscription @@ -1060,7 +1060,7 @@ func TestGetChannelDifference(t *testing.T) { } subs, unsubs := web.GetChannelDifference(newChans) assert.Len(t, subs, 3, "Should get the correct number of subs") - assert.Len(t, unsubs, 0, "Should get the correct number of unsubs") + assert.Empty(t, unsubs, "Should get the correct number of unsubs") web.AddSuccessfulSubscriptions(subs...) @@ -1071,7 +1071,7 @@ func TestGetChannelDifference(t *testing.T) { } subs, unsubs = web.GetChannelDifference(flushedSubs) - assert.Len(t, subs, 0, "Should get the correct number of subs") + assert.Empty(t, subs, "Should get the correct number of subs") assert.Len(t, unsubs, 2, "Should get the correct number of unsubs") flushedSubs = []subscription.Subscription{ @@ -1085,12 +1085,12 @@ func TestGetChannelDifference(t *testing.T) { subs, unsubs = web.GetChannelDifference(flushedSubs) if assert.Len(t, subs, 1, "Should get the correct number of subs") { - assert.Equal(t, subs[0].Channel, "Test4", "Should subscribe to the right channel") + assert.Equal(t, "Test4", subs[0].Channel, "Should subscribe to the right channel") } if assert.Len(t, unsubs, 2, "Should get the correct number of unsubs") { sort.Slice(unsubs, func(i, j int) bool { return unsubs[i].Channel <= unsubs[j].Channel }) - assert.Equal(t, unsubs[0].Channel, "Test1", "Should unsubscribe from the right channels") - assert.Equal(t, unsubs[1].Channel, "Test3", "Should unsubscribe from the right channels") + assert.Equal(t, "Test1", unsubs[0].Channel, "Should unsubscribe from the right channels") + assert.Equal(t, "Test3", unsubs[1].Channel, "Should unsubscribe from the right channels") } } diff --git a/exchanges/ticker/ticker.go b/exchanges/ticker/ticker.go index ef49e3bff9c..ebcad9f786a 100644 --- a/exchanges/ticker/ticker.go +++ b/exchanges/ticker/ticker.go @@ -18,12 +18,13 @@ var ( ErrNoTickerFound = errors.New("no ticker found") // ErrBidEqualsAsk error for locked markets ErrBidEqualsAsk = errors.New("bid equals ask this is a crossed or locked market") + // ErrExchangeNameIsEmpty is an error for when an exchange name is empty + ErrExchangeNameIsEmpty = errors.New("exchange name is empty") - errInvalidTicker = errors.New("invalid ticker") - errTickerNotFound = errors.New("ticker not found") - errExchangeNameIsEmpty = errors.New("exchange name is empty") - errBidGreaterThanAsk = errors.New("bid greater than ask this is a crossed or locked market") - errExchangeNotFound = errors.New("exchange not found") + errInvalidTicker = errors.New("invalid ticker") + errTickerNotFound = errors.New("ticker not found") + errBidGreaterThanAsk = errors.New("bid greater than ask this is a crossed or locked market") + errExchangeNotFound = errors.New("exchange not found") ) func init() { @@ -71,7 +72,7 @@ func SubscribeToExchangeTickers(exchange string) (dispatch.Pipe, error) { // GetTicker checks and returns a requested ticker if it exists func GetTicker(exchange string, p currency.Pair, a asset.Item) (*Price, error) { if exchange == "" { - return nil, errExchangeNameIsEmpty + return nil, ErrExchangeNameIsEmpty } if p.IsEmpty() { return nil, currency.ErrCurrencyPairEmpty @@ -104,7 +105,7 @@ func GetExchangeTickers(exchange string) ([]*Price, error) { func (s *Service) getExchangeTickers(exchange string) ([]*Price, error) { if exchange == "" { - return nil, errExchangeNameIsEmpty + return nil, ErrExchangeNameIsEmpty } exchange = strings.ToLower(exchange) s.mu.Lock() @@ -148,7 +149,7 @@ func ProcessTicker(p *Price) error { } if p.ExchangeName == "" { - return fmt.Errorf(ErrExchangeNameUnset) + return ErrExchangeNameIsEmpty } if p.Pair.IsEmpty() { @@ -240,7 +241,7 @@ func (s *Service) setItemID(t *Ticker, p *Price, exch string) error { // getAssociations links a singular book with its dispatch associations func (s *Service) getAssociations(exch string) ([]uuid.UUID, error) { if exch == "" { - return nil, errExchangeNameIsEmpty + return nil, ErrExchangeNameIsEmpty } var ids []uuid.UUID exchangeID, ok := s.Exchange[exch] diff --git a/exchanges/ticker/ticker_test.go b/exchanges/ticker/ticker_test.go index f16fbd66f22..7a86cd49f83 100644 --- a/exchanges/ticker/ticker_test.go +++ b/exchanges/ticker/ticker_test.go @@ -437,9 +437,7 @@ func TestProcessTicker(t *testing.T) { // non-appending function to tickers func TestGetAssociation(t *testing.T) { _, err := service.getAssociations("") - if !errors.Is(err, errExchangeNameIsEmpty) { - t.Errorf("received: %v but expected: %v", err, errExchangeNameIsEmpty) - } + assert.ErrorIs(t, err, ErrExchangeNameIsEmpty) service.mux = nil @@ -453,7 +451,7 @@ func TestGetAssociation(t *testing.T) { func TestGetExchangeTickersPublic(t *testing.T) { _, err := GetExchangeTickers("") - assert.ErrorIs(t, err, errExchangeNameIsEmpty) + assert.ErrorIs(t, err, ErrExchangeNameIsEmpty) } func TestGetExchangeTickers(t *testing.T) { @@ -464,7 +462,7 @@ func TestGetExchangeTickers(t *testing.T) { } _, err := s.getExchangeTickers("") - assert.ErrorIs(t, err, errExchangeNameIsEmpty) + assert.ErrorIs(t, err, ErrExchangeNameIsEmpty) _, err = s.getExchangeTickers("test") assert.ErrorIs(t, err, errExchangeNotFound) @@ -489,5 +487,5 @@ func TestGetExchangeTickers(t *testing.T) { if len(resp) != 1 { t.Fatal("unexpected length") } - assert.Equal(t, resp[0].OpenInterest, 1337.0) + assert.Equal(t, 1337.0, resp[0].OpenInterest) } diff --git a/exchanges/ticker/ticker_types.go b/exchanges/ticker/ticker_types.go index 4f2bd91032c..0a62d6c4622 100644 --- a/exchanges/ticker/ticker_types.go +++ b/exchanges/ticker/ticker_types.go @@ -13,10 +13,9 @@ import ( // const values for the ticker package const ( - ErrExchangeNameUnset = "ticker exchange name not set" - errPairNotSet = "ticker currency pair not set" - errAssetTypeNotSet = "ticker asset type not set" - errTickerPriceIsNil = "ticker price is nil" + errPairNotSet = "ticker currency pair not set" + errAssetTypeNotSet = "ticker asset type not set" + errTickerPriceIsNil = "ticker price is nil" ) // Vars for the ticker package diff --git a/exchanges/yobit/yobit_wrapper.go b/exchanges/yobit/yobit_wrapper.go index 553cb81f8fd..8cdf89a5171 100644 --- a/exchanges/yobit/yobit_wrapper.go +++ b/exchanges/yobit/yobit_wrapper.go @@ -555,7 +555,7 @@ func (y *Yobit) WithdrawCryptocurrencyFunds(ctx context.Context, withdrawRequest if err != nil { return nil, err } - if len(resp.Error) > 0 { + if resp.Error != "" { return nil, errors.New(resp.Error) } return &withdraw.ExchangeResponse{}, nil diff --git a/go.mod b/go.mod index d6e1cc5a2e5..0b01e29dc9e 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/thrasher-corp/gocryptotrader -go 1.21 +go 1.22 require ( github.com/buger/jsonparser v1.1.1 From 8333bd86fd7351a1d4a7c1c0126578af054ad5a5 Mon Sep 17 00:00:00 2001 From: Adrian Gallagher Date: Mon, 12 Feb 2024 09:21:18 +1100 Subject: [PATCH 2/4] Bump golangci-lint to v1.56.1 --- .github/workflows/linter.yml | 2 +- Makefile | 2 +- engine/apiserver.go | 2 +- engine/rpcserver.go | 4 ++-- engine/rpcserver_test.go | 2 +- exchanges/bybit/bybit.go | 10 +++++----- exchanges/bybit/bybit_types.go | 6 +++--- exchanges/exchange_test.go | 4 ++-- exchanges/kraken/kraken_types.go | 2 +- exchanges/kraken/kraken_wrapper.go | 4 ++-- exchanges/mock/server.go | 2 +- exchanges/request/request_test.go | 18 +++++++++--------- exchanges/stream/buffer/buffer_test.go | 4 ++-- exchanges/stream/websocket_test.go | 2 +- 14 files changed, 32 insertions(+), 32 deletions(-) diff --git a/.github/workflows/linter.yml b/.github/workflows/linter.yml index 9f149753713..74dc6ba750b 100644 --- a/.github/workflows/linter.yml +++ b/.github/workflows/linter.yml @@ -13,4 +13,4 @@ jobs: - name: golangci-lint uses: golangci/golangci-lint-action@v3 with: - version: v1.56.0 \ No newline at end of file + version: v1.56.1 \ No newline at end of file diff --git a/Makefile b/Makefile index 03870b96824..cde53004470 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,6 @@ LDFLAGS = -ldflags "-w -s" GCTPKG = github.com/thrasher-corp/gocryptotrader -LINTPKG = github.com/golangci/golangci-lint/cmd/golangci-lint@v1.56.0 +LINTPKG = github.com/golangci/golangci-lint/cmd/golangci-lint@v1.56.1 LINTBIN = $(GOPATH)/bin/golangci-lint GCTLISTENPORT=9050 GCTPROFILERLISTENPORT=8085 diff --git a/engine/apiserver.go b/engine/apiserver.go index f342dc829a5..40f4efaec40 100644 --- a/engine/apiserver.go +++ b/engine/apiserver.go @@ -656,7 +656,7 @@ func (m *apiServerManager) WebsocketClientHandler(w http.ResponseWriter, r *http // Allow insecure origin if the Origin request header is present and not // equal to the Host request header. Default to false if m.remoteConfig.WebsocketRPC.AllowInsecureOrigin { - upgrader.CheckOrigin = func(r *http.Request) bool { return true } + upgrader.CheckOrigin = func(_ *http.Request) bool { return true } } conn, err := upgrader.Upgrade(w, r, nil) diff --git a/engine/rpcserver.go b/engine/rpcserver.go index 816898cd69c..1a85412ea03 100644 --- a/engine/rpcserver.go +++ b/engine/rpcserver.go @@ -2604,7 +2604,7 @@ func (s *RPCServer) GCTScriptStatus(_ context.Context, _ *gctrpc.GCTScriptStatus Status: fmt.Sprintf("%v of %v virtual machines running", gctscript.VMSCount.Len(), s.gctScriptManager.GetMaxVirtualMachines()), } - gctscript.AllVMSync.Range(func(k, v interface{}) bool { + gctscript.AllVMSync.Range(func(_, v interface{}) bool { vm, ok := v.(*gctscript.VM) if !ok { log.Errorf(log.GRPCSys, "%v", common.GetTypeAssertError("*gctscript.VM", v)) @@ -2843,7 +2843,7 @@ func (s *RPCServer) GCTScriptListAll(context.Context, *gctrpc.GCTScriptListAllRe resp := &gctrpc.GCTScriptStatusResponse{} err := filepath.Walk(gctscript.ScriptPath, - func(path string, info os.FileInfo, err error) error { + func(path string, _ os.FileInfo, err error) error { if err != nil { return err } diff --git a/engine/rpcserver_test.go b/engine/rpcserver_test.go index 84a15b7f7fb..c5d2afe2ef9 100644 --- a/engine/rpcserver_test.go +++ b/engine/rpcserver_test.go @@ -4252,7 +4252,7 @@ func TestRPCProxyAuthClient(t *testing.T) { }, } - dummyHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + dummyHandler := http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) { w.WriteHeader(http.StatusOK) _, err := w.Write([]byte("MEOW")) require.NoError(t, err, "Write should not error") diff --git a/exchanges/bybit/bybit.go b/exchanges/bybit/bybit.go index ef0a6052b1d..5652c464057 100644 --- a/exchanges/bybit/bybit.go +++ b/exchanges/bybit/bybit.go @@ -1630,12 +1630,12 @@ func (by *Bybit) GetSubUID(ctx context.Context) (*SubUID, error) { // EnableUniversalTransferForSubUID Transfer between sub-sub or main-sub // Use this endpoint to enable a subaccount to take part in a universal transfer. It is a one-time switch which, once thrown, enables a subaccount permanently. // If not set, your subaccount cannot use universal transfers. -func (by *Bybit) EnableUniversalTransferForSubUID(ctx context.Context, subMemberIDS ...string) error { - if len(subMemberIDS) == 0 { +func (by *Bybit) EnableUniversalTransferForSubUID(ctx context.Context, subMemberIDs ...string) error { + if len(subMemberIDs) == 0 { return errMembersIDsNotSet } arg := map[string][]string{ - "subMemberIDs": subMemberIDS, + "subMemberIDs": subMemberIDs, } return by.SendAuthHTTPRequestV5(ctx, exchange.RestSpot, http.MethodPost, "/v5/asset/transfer/save-transfer-sub-member", nil, &arg, &struct{}{}, saveTransferSubMemberEPL) } @@ -1995,8 +1995,8 @@ func (by *Bybit) GetSubAccountAllAPIKeys(ctx context.Context, subMemberID, curso } // GetUIDWalletType retrieves available wallet types for the master account or sub account -func (by *Bybit) GetUIDWalletType(ctx context.Context, memberIDS string) (*WalletType, error) { - if memberIDS == "" { +func (by *Bybit) GetUIDWalletType(ctx context.Context, memberIDs string) (*WalletType, error) { + if memberIDs == "" { return nil, errMembersIDsNotSet } var resp *WalletType diff --git a/exchanges/bybit/bybit_types.go b/exchanges/bybit/bybit_types.go index 739d07d879d..6a2c1b07a1c 100644 --- a/exchanges/bybit/bybit_types.go +++ b/exchanges/bybit/bybit_types.go @@ -1106,8 +1106,8 @@ type TransferResponse struct { // SubUID represents a sub-users ID type SubUID struct { - SubMemberIds []string `json:"subMemberIds"` - TransferableSubMemberIds []string `json:"transferableSubMemberIds"` + SubMemberIDs []string `json:"subMemberIds"` + TransferableSubMemberIDs []string `json:"transferableSubMemberIds"` } // AllowedDepositCoinInfo represents coin deposit information. @@ -1555,7 +1555,7 @@ type CoinRepaymentResponse struct { RepayID string `json:"repayId"` RepayMarginOrderID string `json:"repayMarginOrderId"` RepayTime convert.ExchangeTime `json:"repayTime"` - TransactIds []struct { + TransactIDs []struct { RepaidAmount types.Number `json:"repaidAmount"` RepaidInterest types.Number `json:"repaidInterest"` RepaidPrincipal types.Number `json:"repaidPrincipal"` diff --git a/exchanges/exchange_test.go b/exchanges/exchange_test.go index f048cc344fb..e4b6805116d 100644 --- a/exchanges/exchange_test.go +++ b/exchanges/exchange_test.go @@ -1264,7 +1264,7 @@ func TestSetupDefaults(t *testing.T) { RunningURL: "ws://something.com", Connector: func() error { return nil }, GenerateSubscriptions: func() ([]subscription.Subscription, error) { return []subscription.Subscription{}, nil }, - Subscriber: func(cs []subscription.Subscription) error { return nil }, + Subscriber: func(_ []subscription.Subscription) error { return nil }, }) if err != nil { t.Fatal(err) @@ -1613,7 +1613,7 @@ func TestIsWebsocketEnabled(t *testing.T) { RunningURL: "ws://something.com", Connector: func() error { return nil }, GenerateSubscriptions: func() ([]subscription.Subscription, error) { return nil, nil }, - Subscriber: func(cs []subscription.Subscription) error { return nil }, + Subscriber: func(_ []subscription.Subscription) error { return nil }, }) if err != nil { t.Error(err) diff --git a/exchanges/kraken/kraken_types.go b/exchanges/kraken/kraken_types.go index ebbe7dbf205..dcd51b155d6 100644 --- a/exchanges/kraken/kraken_types.go +++ b/exchanges/kraken/kraken_types.go @@ -396,7 +396,7 @@ type TradeVolumeFee struct { // AddOrderResponse type type AddOrderResponse struct { Description OrderDescription `json:"descr"` - TransactionIds []string `json:"txid"` + TransactionIDs []string `json:"txid"` } // WithdrawInformation Used to check withdrawal fees diff --git a/exchanges/kraken/kraken_wrapper.go b/exchanges/kraken/kraken_wrapper.go index 9d2503adebc..de631e0d904 100644 --- a/exchanges/kraken/kraken_wrapper.go +++ b/exchanges/kraken/kraken_wrapper.go @@ -780,8 +780,8 @@ func (k *Kraken) SubmitOrder(ctx context.Context, s *order.Submit) (*order.Submi if err != nil { return nil, err } - if len(response.TransactionIds) > 0 { - orderID = strings.Join(response.TransactionIds, ", ") + if len(response.TransactionIDs) > 0 { + orderID = strings.Join(response.TransactionIDs, ", ") } } if s.Type == order.Market { diff --git a/exchanges/mock/server.go b/exchanges/mock/server.go index 2ff294b41f2..1881fec7696 100644 --- a/exchanges/mock/server.go +++ b/exchanges/mock/server.go @@ -85,7 +85,7 @@ func NewVCRServer(path string) (string, *http.Client, error) { RegisterHandler(pattern, mockResponses, newMux) } } else { - newMux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { + newMux.HandleFunc("/", func(w http.ResponseWriter, _ *http.Request) { w.WriteHeader(http.StatusNotFound) err := json.NewEncoder(w).Encode("There is no mock data available in file please record a new HTTP response. Please follow README.md in the mock package.") if err != nil { diff --git a/exchanges/request/request_test.go b/exchanges/request/request_test.go index 2cd60ba1b32..bbb86fb3af7 100644 --- a/exchanges/request/request_test.go +++ b/exchanges/request/request_test.go @@ -32,25 +32,25 @@ func TestMain(m *testing.M) { serverLimit = NewRateLimit(serverLimitInterval, 1) serverLimitRetry := NewRateLimit(serverLimitInterval, 1) sm := http.NewServeMux() - sm.HandleFunc("/", func(w http.ResponseWriter, req *http.Request) { + sm.HandleFunc("/", func(w http.ResponseWriter, _ *http.Request) { w.Header().Set("Content-Type", "application/json") _, err := io.WriteString(w, `{"response":true}`) if err != nil { log.Fatal(err) } }) - sm.HandleFunc("/error", func(w http.ResponseWriter, req *http.Request) { + sm.HandleFunc("/error", func(w http.ResponseWriter, _ *http.Request) { w.WriteHeader(http.StatusBadRequest) _, err := io.WriteString(w, `{"error":true}`) if err != nil { log.Fatal(err) } }) - sm.HandleFunc("/timeout", func(w http.ResponseWriter, req *http.Request) { + sm.HandleFunc("/timeout", func(w http.ResponseWriter, _ *http.Request) { time.Sleep(time.Millisecond * 100) w.WriteHeader(http.StatusGatewayTimeout) }) - sm.HandleFunc("/rate", func(w http.ResponseWriter, req *http.Request) { + sm.HandleFunc("/rate", func(w http.ResponseWriter, _ *http.Request) { if !serverLimit.Allow() { http.Error(w, http.StatusText(http.StatusTooManyRequests), @@ -66,7 +66,7 @@ func TestMain(m *testing.M) { log.Fatal(err) } }) - sm.HandleFunc("/rate-retry", func(w http.ResponseWriter, req *http.Request) { + sm.HandleFunc("/rate-retry", func(w http.ResponseWriter, _ *http.Request) { if !serverLimitRetry.Allow() { w.Header().Add("Retry-After", strconv.Itoa(int(math.Round(serverLimitInterval.Seconds())))) http.Error(w, @@ -83,7 +83,7 @@ func TestMain(m *testing.M) { log.Fatal(err) } }) - sm.HandleFunc("/always-retry", func(w http.ResponseWriter, req *http.Request) { + sm.HandleFunc("/always-retry", func(w http.ResponseWriter, _ *http.Request) { w.Header().Add("Retry-After", time.Now().Format(time.RFC1123)) w.WriteHeader(http.StatusTooManyRequests) _, err := io.WriteString(w, `{"response":false}`) @@ -406,7 +406,7 @@ func TestDoRequest(t *testing.T) { func TestDoRequest_Retries(t *testing.T) { t.Parallel() - backoff := func(n int) time.Duration { + backoff := func(_ int) time.Duration { return 0 } r, err := New("test", new(http.Client), WithBackoff(backoff)) @@ -449,7 +449,7 @@ func TestDoRequest_Retries(t *testing.T) { func TestDoRequest_RetryNonRecoverable(t *testing.T) { t.Parallel() - backoff := func(n int) time.Duration { + backoff := func(_ int) time.Duration { return 0 } r, err := New("test", new(http.Client), WithBackoff(backoff)) @@ -471,7 +471,7 @@ func TestDoRequest_NotRetryable(t *testing.T) { t.Parallel() notRetryErr := errors.New("not retryable") - retry := func(resp *http.Response, err error) (bool, error) { + retry := func(_ *http.Response, _ error) (bool, error) { return false, notRetryErr } backoff := func(n int) time.Duration { diff --git a/exchanges/stream/buffer/buffer_test.go b/exchanges/stream/buffer/buffer_test.go index 3378ebe30ba..d61248b41f0 100644 --- a/exchanges/stream/buffer/buffer_test.go +++ b/exchanges/stream/buffer/buffer_test.go @@ -460,7 +460,7 @@ func TestOrderbookLastUpdateID(t *testing.T) { exp, itemArray[1][0].Price) } - holder.checksum = func(state *orderbook.Base, checksum uint32) error { return errors.New("testerino") } + holder.checksum = func(_ *orderbook.Base, _ uint32) error { return errors.New("testerino") } // this update invalidates the book err = holder.Update(&orderbook.Update{ @@ -479,7 +479,7 @@ func TestOrderbookLastUpdateID(t *testing.T) { t.Fatal(err) } - holder.checksum = func(state *orderbook.Base, checksum uint32) error { return nil } + holder.checksum = func(_ *orderbook.Base, _ uint32) error { return nil } holder.updateIDProgression = true for i := range itemArray { diff --git a/exchanges/stream/websocket_test.go b/exchanges/stream/websocket_test.go index 7fb9f9f6ab7..7883457d878 100644 --- a/exchanges/stream/websocket_test.go +++ b/exchanges/stream/websocket_test.go @@ -1283,7 +1283,7 @@ func TestEnable(t *testing.T) { GenerateSubs: func() ([]subscription.Subscription, error) { return []subscription.Subscription{{Channel: "test"}}, nil }, - Subscriber: func(cs []subscription.Subscription) error { return nil }, + Subscriber: func(_ []subscription.Subscription) error { return nil }, } err := web.Enable() From 00b48fbe33b2daa41690fbcbcf0ddbc5747f188c Mon Sep 17 00:00:00 2001 From: Adrian Gallagher Date: Mon, 12 Feb 2024 09:34:56 +1100 Subject: [PATCH 3/4] BinanceUS: Make uint usage consistent --- exchanges/binanceus/binanceus_types.go | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/exchanges/binanceus/binanceus_types.go b/exchanges/binanceus/binanceus_types.go index f3e352f15f2..1cab9043173 100644 --- a/exchanges/binanceus/binanceus_types.go +++ b/exchanges/binanceus/binanceus_types.go @@ -300,8 +300,8 @@ type AccountStatusResponse struct { // TradeStatus represents trade status and holds list of trade status indicator Item instances. type TradeStatus struct { IsLocked bool `json:"isLocked"` - PlannedRecoverTime uint `json:"plannedRecoverTime"` - TriggerCondition map[string]uint `json:"triggerCondition"` + PlannedRecoverTime uint64 `json:"plannedRecoverTime"` + TriggerCondition map[string]uint64 `json:"triggerCondition"` Indicators map[string]TradingStatusIndicatorItem `json:"indicators"` UpdateTime time.Time `json:"updateTime"` } @@ -340,7 +340,7 @@ type AssetHistory struct { // including for staking, referrals and airdrops etc. type AssetDistributionHistories struct { Rows []AssetHistory `json:"rows"` - Total uint `json:"total"` + Total uint64 `json:"total"` } // SubAccount holds a single sub account instance in a Binance US account. @@ -359,7 +359,7 @@ type TransferHistory struct { From string `json:"from"` To string `json:"to"` Asset string `json:"asset"` - Qty uint `json:"qty,string"` + Qty uint64 `json:"qty,string"` TimeStamp time.Time `json:"time"` } @@ -398,9 +398,9 @@ type SubAccountAssets struct { type OrderRateLimit struct { RateLimitType string `json:"rateLimitType"` Interval string `json:"interval"` - IntervalNum uint `json:"intervalNum"` - Limit uint `json:"limit"` - Count uint `json:"count"` + IntervalNum uint64 `json:"intervalNum"` + Limit uint64 `json:"limit"` + Count uint64 `json:"count"` } // RequestParamsOrderType trade order type @@ -504,7 +504,7 @@ type OrderRequestParams struct { Symbol string `json:"symbol"` // REQUIRED OrderID uint64 `json:"orderId"` OrigClientOrderID string `json:"origClientOrderId"` - recvWindow uint + recvWindow uint64 } // CancelOrderRequestParams this struct will be used as a parameter for @@ -514,7 +514,7 @@ type CancelOrderRequestParams struct { OrderID string ClientSuppliedOrderID string NewClientOrderID string - RecvWindow uint + RecvWindow uint64 } // GetTradesParams request param to get the trade history @@ -1076,7 +1076,7 @@ type OCBSOrderRequestParams struct { OrderID string StartTime time.Time EndTime time.Time - Limit uint + Limit uint64 } // OCBSTradeOrdersResponse holds the quantity and list of OCBS Orders. From 175c58416738cfea2e9b0c61c7bbfa1ca6369582 Mon Sep 17 00:00:00 2001 From: Adrian Gallagher Date: Mon, 12 Feb 2024 10:20:51 +1100 Subject: [PATCH 4/4] Throw blank identifiers into the trash --- engine/apiserver.go | 2 +- exchanges/exchange_test.go | 4 ++-- exchanges/request/request_test.go | 6 +++--- exchanges/stream/buffer/buffer_test.go | 4 ++-- exchanges/stream/websocket_test.go | 6 +++--- 5 files changed, 11 insertions(+), 11 deletions(-) diff --git a/engine/apiserver.go b/engine/apiserver.go index 40f4efaec40..e43253236d6 100644 --- a/engine/apiserver.go +++ b/engine/apiserver.go @@ -656,7 +656,7 @@ func (m *apiServerManager) WebsocketClientHandler(w http.ResponseWriter, r *http // Allow insecure origin if the Origin request header is present and not // equal to the Host request header. Default to false if m.remoteConfig.WebsocketRPC.AllowInsecureOrigin { - upgrader.CheckOrigin = func(_ *http.Request) bool { return true } + upgrader.CheckOrigin = func(*http.Request) bool { return true } } conn, err := upgrader.Upgrade(w, r, nil) diff --git a/exchanges/exchange_test.go b/exchanges/exchange_test.go index e4b6805116d..d41f499d48d 100644 --- a/exchanges/exchange_test.go +++ b/exchanges/exchange_test.go @@ -1264,7 +1264,7 @@ func TestSetupDefaults(t *testing.T) { RunningURL: "ws://something.com", Connector: func() error { return nil }, GenerateSubscriptions: func() ([]subscription.Subscription, error) { return []subscription.Subscription{}, nil }, - Subscriber: func(_ []subscription.Subscription) error { return nil }, + Subscriber: func([]subscription.Subscription) error { return nil }, }) if err != nil { t.Fatal(err) @@ -1613,7 +1613,7 @@ func TestIsWebsocketEnabled(t *testing.T) { RunningURL: "ws://something.com", Connector: func() error { return nil }, GenerateSubscriptions: func() ([]subscription.Subscription, error) { return nil, nil }, - Subscriber: func(_ []subscription.Subscription) error { return nil }, + Subscriber: func([]subscription.Subscription) error { return nil }, }) if err != nil { t.Error(err) diff --git a/exchanges/request/request_test.go b/exchanges/request/request_test.go index bbb86fb3af7..5796ae2a016 100644 --- a/exchanges/request/request_test.go +++ b/exchanges/request/request_test.go @@ -406,7 +406,7 @@ func TestDoRequest(t *testing.T) { func TestDoRequest_Retries(t *testing.T) { t.Parallel() - backoff := func(_ int) time.Duration { + backoff := func(int) time.Duration { return 0 } r, err := New("test", new(http.Client), WithBackoff(backoff)) @@ -449,7 +449,7 @@ func TestDoRequest_Retries(t *testing.T) { func TestDoRequest_RetryNonRecoverable(t *testing.T) { t.Parallel() - backoff := func(_ int) time.Duration { + backoff := func(int) time.Duration { return 0 } r, err := New("test", new(http.Client), WithBackoff(backoff)) @@ -471,7 +471,7 @@ func TestDoRequest_NotRetryable(t *testing.T) { t.Parallel() notRetryErr := errors.New("not retryable") - retry := func(_ *http.Response, _ error) (bool, error) { + retry := func(*http.Response, error) (bool, error) { return false, notRetryErr } backoff := func(n int) time.Duration { diff --git a/exchanges/stream/buffer/buffer_test.go b/exchanges/stream/buffer/buffer_test.go index d61248b41f0..2eb71e85ddb 100644 --- a/exchanges/stream/buffer/buffer_test.go +++ b/exchanges/stream/buffer/buffer_test.go @@ -460,7 +460,7 @@ func TestOrderbookLastUpdateID(t *testing.T) { exp, itemArray[1][0].Price) } - holder.checksum = func(_ *orderbook.Base, _ uint32) error { return errors.New("testerino") } + holder.checksum = func(*orderbook.Base, uint32) error { return errors.New("testerino") } // this update invalidates the book err = holder.Update(&orderbook.Update{ @@ -479,7 +479,7 @@ func TestOrderbookLastUpdateID(t *testing.T) { t.Fatal(err) } - holder.checksum = func(_ *orderbook.Base, _ uint32) error { return nil } + holder.checksum = func(*orderbook.Base, uint32) error { return nil } holder.updateIDProgression = true for i := range itemArray { diff --git a/exchanges/stream/websocket_test.go b/exchanges/stream/websocket_test.go index 7883457d878..3ab49e0df10 100644 --- a/exchanges/stream/websocket_test.go +++ b/exchanges/stream/websocket_test.go @@ -73,8 +73,8 @@ var defaultSetup = &WebsocketSetup{ DefaultURL: "testDefaultURL", RunningURL: "wss://testRunningURL", Connector: func() error { return nil }, - Subscriber: func(_ []subscription.Subscription) error { return nil }, - Unsubscriber: func(_ []subscription.Subscription) error { return nil }, + Subscriber: func([]subscription.Subscription) error { return nil }, + Unsubscriber: func([]subscription.Subscription) error { return nil }, GenerateSubscriptions: func() ([]subscription.Subscription, error) { return []subscription.Subscription{ {Channel: "TestSub"}, @@ -1283,7 +1283,7 @@ func TestEnable(t *testing.T) { GenerateSubs: func() ([]subscription.Subscription, error) { return []subscription.Subscription{{Channel: "test"}}, nil }, - Subscriber: func(_ []subscription.Subscription) error { return nil }, + Subscriber: func([]subscription.Subscription) error { return nil }, } err := web.Enable()