mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-06-01 15:10:44 +00:00
* update acccount ratelimits and added missing endpoints * completed mapping missing trade accoung REST endpoints and Rate Limit * added orderbook trading missing REST endpoints * Added few missing endpoints and unit tests * Completed grid trading and signal bot trading with unit tests * Added Recurring Buy endpoints and corresponding unit tests * Added copy trading endpoints and unit tests * added newly added block trading and spread endpoints * completed mapping spread endpoints * Added new endpoints and unit tests * Added round 1: Okx types and converts update. * Update endpoints handling and types update * Removed constants, updated unit tests, and updated endpoint methods * Slight endpoint and unit test update * Added spread and other websocket endpoints and update * completed Spread WS Orderbook handler * Added missing spread channels and handlers * Adding Bussinss websocket and missing subscriptions, update unit tests, and endpoints * Added spread endpoints to wrapper and unit tests update * Added missing websocket subscriptions and copy trading endpoints * Added missing endpoints and re-organize business websocket handlers * Docs update * Endpoints code updates * types, unit test and endpoints update * Minor unit tests update * spelling fix * fix unit test issues * Updating unit tests error handling * Updating unit tests error handling * Unit tests assertion handling update * Unit tests update * Resolve linter issues * linter issues fix * Orderbook unit test error fix * Minor fixes * Change on test handling and types * Updating unit tests and cleanups * Fix unit test issues * Add ratelimit test and update unit tests and methods * Update method parameters and error declarations * Added lending endpoints, unit tests, and update endpoint methods and error declarations * Update ratelimiters, add missing lending and trading endpoints and unit tests * Update websocket authentication and subscription handling * Minor update to unit test and types * Types, error handling, and other minor updates * Update unit tests and endpoint functions * error declarations update and unit tests * Overall update on unit endpoint, unit tests, and types * Adding review fixes * Update on endpoints, order types, and unit tests * Update unit tests and endpoint functions * Update on endpoint and update missing parameters * Implemented and tested newly added trading endpoints * endpoints update and unit tests * Update missing endpoints and update overall code * added and testing funding and fiat related endpoints * Update on convert and fiat related endpoints * linter fix, types, endpoints, and unit tests update * linter issues fix * revert changes on tempos * Fix Panic and update websocket auth calls handling * config linter issue fix * Fix panic issues and update unit tests * Fix race condition, TestAllExchangeWrappers unit test issues * Fix withdrawal manager test issue * Rename ClosePositionForContractrID --> ClosePositionForContractID * Rename ClosePositionForContractrID --> ClosePositionForContractID * Fix error * endpoints update and fix unit test issues * added unit tests, updated comments, and code sections * revert change in defaultSubscriptions * few types comments update * Minor changes * remove lending endpoints * rm mistakenly added code * fix unit test * minor unit test fix * Adding offline error tests, update endpoints function, config update * Update unit test coverage for offline error handliing * Updating wrapper algo order coverage, endpoint calls, and unit tests * Updating wrapper trade functions to accomodate algo orders * update wrapper unit tests * Fix wrapper order functions offline errors handling * Tested and updated wrapper order functions * Address review comments * update order unit tests, and okx endpoint functions * finalize affected order, endpoint, and margin endpoints * Slight change on margin unit test * fix margin unit test issues * Minor change on unit test * updates on contract settlement and future contract wrapper function * add test coverage for contract functions and minor fix on wrapper * Overall update and unit testing * codespell, unit tests, type declaration and naming, and code-structure updates * margin types value and validation function fix * Update tests and helper funcs * Improve test coverage * helper functions and unit tests update * Fix margin unit test * Minor review updates * minor fix on if statement * Update helper functions * error handling and functions naming update * update comment * minor error return fixes * minor unit test fix * Minor fix on spread websocket orders handling * codespell fix * skip orderbook depth with incomplete price * skip orderbook depth with incomplete price
204 lines
5.3 KiB
Go
204 lines
5.3 KiB
Go
package asset
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"slices"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestString(t *testing.T) {
|
|
t.Parallel()
|
|
for a := range All {
|
|
if a == 0 {
|
|
assert.Empty(t, a.String(), "Empty.String should return empty")
|
|
} else {
|
|
assert.NotEmptyf(t, a.String(), "%s.String should return empty", a)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestStrings(t *testing.T) {
|
|
t.Parallel()
|
|
assert.ElementsMatch(t, Items{Spot, Futures}.Strings(), []string{"spot", "futures"})
|
|
}
|
|
|
|
func TestContains(t *testing.T) {
|
|
t.Parallel()
|
|
a := Items{Spot, Futures}
|
|
if a.Contains(666) {
|
|
t.Fatal("TestContains returned an unexpected result")
|
|
}
|
|
|
|
if !a.Contains(Spot) {
|
|
t.Fatal("TestContains returned an unexpected result")
|
|
}
|
|
|
|
if a.Contains(Binary) {
|
|
t.Fatal("TestContains returned an unexpected result")
|
|
}
|
|
|
|
// Every asset should be created and matched with func New so this should
|
|
// not be matched against list
|
|
if a.Contains(0) {
|
|
t.Error("TestContains returned an unexpected result")
|
|
}
|
|
}
|
|
|
|
func TestJoinToString(t *testing.T) {
|
|
t.Parallel()
|
|
a := Items{Spot, Futures}
|
|
if a.JoinToString(",") != "spot,futures" {
|
|
t.Fatal("TestJoinToString returned an unexpected result")
|
|
}
|
|
}
|
|
|
|
func TestIsValid(t *testing.T) {
|
|
t.Parallel()
|
|
for a := range All {
|
|
if a.String() == "" {
|
|
require.Falsef(t, a.IsValid(), "IsValid must return false with non-asset value %d", a)
|
|
} else {
|
|
require.Truef(t, a.IsValid(), "IsValid must return true for %s", a)
|
|
}
|
|
}
|
|
require.False(t, All.IsValid(), "IsValid must return false for All")
|
|
}
|
|
|
|
func TestIsFutures(t *testing.T) {
|
|
t.Parallel()
|
|
valid := []Item{PerpetualContract, PerpetualSwap, Futures, DeliveryFutures, UpsideProfitContract, DownsideProfitContract, CoinMarginedFutures, USDTMarginedFutures, USDCMarginedFutures, FutureCombo, LinearContract, Spread}
|
|
for a := range All {
|
|
if slices.Contains(valid, a) {
|
|
require.Truef(t, a.IsFutures(), "IsFutures must return true for %s", a)
|
|
} else {
|
|
require.Falsef(t, a.IsFutures(), "IsFutures must return false for non-asset value %d (%s)", a, a)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestIsOptions(t *testing.T) {
|
|
t.Parallel()
|
|
valid := []Item{Options, OptionCombo}
|
|
for a := range All {
|
|
if slices.Contains(valid, a) {
|
|
require.Truef(t, a.IsOptions(), "IsOptions must return true for %s", a)
|
|
} else {
|
|
require.Falsef(t, a.IsOptions(), "IsOptions must return false for non-asset value %d (%s)", a, a)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestNew(t *testing.T) {
|
|
t.Parallel()
|
|
cases := []struct {
|
|
Input string
|
|
Expected Item
|
|
Error error
|
|
}{
|
|
{Input: "Spota", Error: ErrNotSupported},
|
|
{Input: "MARGIN", Expected: Margin},
|
|
{Input: "MARGINFUNDING", Expected: MarginFunding},
|
|
{Input: "INDEX", Expected: Index},
|
|
{Input: "BINARY", Expected: Binary},
|
|
{Input: "PERPETUALCONTRACT", Expected: PerpetualContract},
|
|
{Input: "PERPETUALSWAP", Expected: PerpetualSwap},
|
|
{Input: "FUTURES", Expected: Futures},
|
|
{Input: "UpsideProfitContract", Expected: UpsideProfitContract},
|
|
{Input: "DownsideProfitContract", Expected: DownsideProfitContract},
|
|
{Input: "CoinMarginedFutures", Expected: CoinMarginedFutures},
|
|
{Input: "USDTMarginedFutures", Expected: USDTMarginedFutures},
|
|
{Input: "USDCMarginedFutures", Expected: USDCMarginedFutures},
|
|
{Input: "Options", Expected: Options},
|
|
{Input: "Option", Expected: Options},
|
|
{Input: "Future", Error: ErrNotSupported},
|
|
{Input: "option_combo", Expected: OptionCombo},
|
|
{Input: "future_combo", Expected: FutureCombo},
|
|
{Input: "spread", Expected: Spread},
|
|
{Input: "linearContract", Expected: LinearContract},
|
|
}
|
|
|
|
for _, tt := range cases {
|
|
t.Run("", func(t *testing.T) {
|
|
t.Parallel()
|
|
returned, err := New(tt.Input)
|
|
if !errors.Is(err, tt.Error) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", err, tt.Error)
|
|
}
|
|
if returned != tt.Expected {
|
|
t.Fatalf("received: '%v' but expected: '%v'", returned, tt.Expected)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSupported(t *testing.T) {
|
|
t.Parallel()
|
|
s := Supported()
|
|
if len(supportedList) != len(s) {
|
|
t.Fatal("TestSupported mismatched lengths")
|
|
}
|
|
for i := range supportedList {
|
|
if s[i] != supportedList[i] {
|
|
t.Fatal("TestSupported returned an unexpected result")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestUnmarshalMarshal(t *testing.T) {
|
|
t.Parallel()
|
|
data, err := json.Marshal(Item(0))
|
|
if !errors.Is(err, nil) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", err, nil)
|
|
}
|
|
|
|
if string(data) != `""` {
|
|
t.Fatal("unexpected value")
|
|
}
|
|
|
|
data, err = json.Marshal(Spot)
|
|
if !errors.Is(err, nil) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", err, nil)
|
|
}
|
|
|
|
if string(data) != `"spot"` {
|
|
t.Fatal("unexpected value")
|
|
}
|
|
|
|
var spot Item
|
|
|
|
err = json.Unmarshal(data, &spot)
|
|
if !errors.Is(err, nil) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", err, nil)
|
|
}
|
|
|
|
if spot != Spot {
|
|
t.Fatal("unexpected value")
|
|
}
|
|
|
|
err = json.Unmarshal([]byte(`"confused"`), &spot)
|
|
if !errors.Is(err, ErrNotSupported) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", err, ErrNotSupported)
|
|
}
|
|
|
|
err = json.Unmarshal([]byte(`""`), &spot)
|
|
if !errors.Is(err, nil) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", err, nil)
|
|
}
|
|
|
|
err = json.Unmarshal([]byte(`123`), &spot)
|
|
if errors.Is(err, nil) {
|
|
t.Fatalf("received: '%v' but expected: '%v'", nil, "an error")
|
|
}
|
|
}
|
|
|
|
func TestUseDefault(t *testing.T) {
|
|
t.Parallel()
|
|
if UseDefault() != Spot {
|
|
t.Fatalf("received: '%v' but expected: '%v'", UseDefault(), Spot)
|
|
}
|
|
}
|