mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-20 23:16:49 +00:00
* few fixes and add ratelimiter * adds test * revert configtest.json changes * configtest updated * WIP: adds public endpoint support * WIP: adds public endpoint support * adds public endpoint support * WIP: adds auth. endpoint support * adds test for auth. endpoint * fixes * adds auth. endpoint support * WIP: ws support * WIP * WIP * WIP * WIP * WIP * WIP * WIP * Testing * Complete WS spot testing * adds support for ws events * minor change * WIP: adds REST support for CoinMarginedFutures * Fixes * WIP: adds REST support for CoinMarginedFutures * Fixes * improvement in SPOT REST * Typo fix * WIP: add REST support for CMF Account API * minor fixes * WIP: add support for CMF conditional orders and few minor fixes * complete support for CMF conditional orders * adds support for public CMF endpoint * adds support for CMF position API * Complete REST CMF support * WIP * Testing REST CMF support * Testing REST CMF support * Testing REST CMF support completed * WIP: add support for UMF * completed non-auth UMF * WIP: add support for REST Auth. UMF * WIP: add support for REST Auth. UMF and some improvements * WIP * WIP * WIP * completed REST UMF * renaming * adds REST support for futures * add testcases for UMF and some optimizations * add testcases for futures * Testing UMF, futures and its changes * Fixes * Fixes after testing * WIP * WIP * WIP * completed ws USDT futures support * WIP: ws support for futures * fixes in WS futures * fixes in WS support * roll back changes made for WS CMF, USDT and Futures * fixes * WIP * WIP * fixes * Steps for new PR * WIP * WIP * WIP * WIP * complete PR setup * fixes for successfully running tests * update in symbol for futures pair in test file * WIP * Fixes in test file and other minor fix * fix testdata/configtest.json * reset CONTRIBUTORS file * review changes * remove unwanted file * remove redundant code * improvisation * adds comment for exported functions * remove unwanted TODO and commented code * fix * improvisation * fix * defined errors * improvisation * improvisation * improvisation * updates test * adds comment for exported types * review changes * review changes * fix * fixes * Changes for making BYBIT compatible with existing code base * Test file changes * Changes for making BYBIT compatible with existing code base * Changes for making BYBIT compatible with existing code base * fix lint issues * fix * review changes * review changes * review changes * review changes * review changes * review changes * review changes * review changes * review changes * review changes * WIP * add test cases for new API's * minor improvements * add missing API and their tests * minor fixes * add bybitTime * add bybitTimeSec, bybitTimeMilliSec, bybitTimeNanoSec and necessary support * fix GetTradeHistory function * error handling * test fixes * add GetServerTime API * adds GetHistoricCandlesExtended and review changes * test fixes * minor fix * integrating CMF Bybit recent change log * minor fixes * adds extractCurrencyPair * minor fixes * minor fix * review changes * adds variable declaration of error * review commit * adds embeddable type in API response for all API and integrate it * fixes * adds authentication WS connection * review changes * review changes * compatible changes * adds asset to GetWithdrawalsHistory * adds asset_type in rpc.proto * adds asset argument in gctcli withdrawal request command * improve error handling in exchange API error * web socket fix * review changes * improvements * improvements * minor fix * review changes * fixing wrapper issues * fixes * fixes * review changes * add test cases * fix for GetActiveOrders * lint fixes * fixes in websocket * adds wrapper testcases * adds wrapper testcases * adds wrapper testcases * fixes * fix issue with GetHistoricCandlesExtended * fix merge issues * improving error reporting * adds wrapper testcases and a minor fix * gctrpc changes * adds test cases fixes in websocket * review changes for ws * review changes in WS * fix gctrpc * merge fixes * review changes * WIP * updates pair in configs * adds new asset USDCMarginedFutures * adds URL const for USDCMarginedFutures * adds API support * minor fixes * adds kline API * minor fix * adds API * adds API * adds API * WIP * WIP * WIP * adds support for USDC auth requests to SendAuthHTTPRequest * adds SendUSDCAuthHTTPRequest * run test and fix them * rollback support added for Auth. USDC request inside SendAuthHTTPRequest * adds API and test cases * adds API and test cases * adds APIs and test cases * adds APIs * adds rate limit for USDC * adds USDCMarginedFutures to wrapper * adds USDC testcases in wrapper and fix few issues * minor test fixes * minor test fixes * fix lint issues * WIP * Merge changes * minor fixes * remove "else" and optimize * review changes * review changes * review changes * fix lint issue * merge fix * fix test * fix templates and run them * changes after merge * review changes and improvements * code improvement * fixes with respect to changes in API response in documentation * fixed review change in test * adds check in CancelExistingOrder * update exchange template * review changes * adds GetDepositAddress API * WIP: adds GetOrderHistory * complete GetOrderHistory * fixes * adds test case * fixes and add WithdrawFund API * WIP * WIP * updating all SendAuthHTTPRequest call * adds WithdrawCryptocurrencyFunds * update test cases * fix lint issues * fixes after merge * adds GetAvailableTransferChains and few fixes * minor fix in GetDepositAddress * minor fix with WS ping/pong handling * add ping handler for WS Auth. * fix typo mistake * update doc
250 lines
5.3 KiB
Go
250 lines
5.3 KiB
Go
package asset
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"testing"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/common"
|
|
)
|
|
|
|
func TestString(t *testing.T) {
|
|
t.Parallel()
|
|
a := Spot
|
|
if a.String() != "spot" {
|
|
t.Fatal("TestString returned an unexpected result")
|
|
}
|
|
|
|
a = 0
|
|
if a.String() != "" {
|
|
t.Fatal("TestString returned an unexpected result")
|
|
}
|
|
}
|
|
|
|
func TestToStringArray(t *testing.T) {
|
|
t.Parallel()
|
|
a := Items{Spot, Futures}
|
|
result := a.Strings()
|
|
for x := range a {
|
|
if !common.StringDataCompare(result, a[x].String()) {
|
|
t.Fatal("TestToStringArray returned an unexpected result")
|
|
}
|
|
}
|
|
}
|
|
|
|
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()
|
|
if Item(0).IsValid() {
|
|
t.Fatal("TestIsValid returned an unexpected result")
|
|
}
|
|
|
|
if !Spot.IsValid() {
|
|
t.Fatal("TestIsValid returned an unexpected result")
|
|
}
|
|
}
|
|
|
|
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},
|
|
}
|
|
|
|
for x := range cases {
|
|
tt := cases[x]
|
|
t.Run("", func(t *testing.T) {
|
|
t.Parallel()
|
|
returned, err := New(tt.Input)
|
|
if !errors.Is(err, tt.Error) {
|
|
t.Fatalf("receieved: '%v' but expected: '%v'", err, tt.Error)
|
|
}
|
|
if returned != tt.Expected {
|
|
t.Fatalf("receieved: '%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 := 0; i < len(supportedList); i++ {
|
|
if s[i] != supportedList[i] {
|
|
t.Fatal("TestSupported returned an unexpected result")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestIsFutures(t *testing.T) {
|
|
t.Parallel()
|
|
type scenario struct {
|
|
item Item
|
|
isFutures bool
|
|
}
|
|
scenarios := []scenario{
|
|
{
|
|
item: Spot,
|
|
isFutures: false,
|
|
},
|
|
{
|
|
item: Margin,
|
|
isFutures: false,
|
|
},
|
|
{
|
|
item: MarginFunding,
|
|
isFutures: false,
|
|
},
|
|
{
|
|
item: Index,
|
|
isFutures: false,
|
|
},
|
|
{
|
|
item: Binary,
|
|
isFutures: false,
|
|
},
|
|
{
|
|
item: PerpetualContract,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: PerpetualSwap,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: Futures,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: UpsideProfitContract,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: DownsideProfitContract,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: CoinMarginedFutures,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: USDTMarginedFutures,
|
|
isFutures: true,
|
|
},
|
|
{
|
|
item: USDCMarginedFutures,
|
|
isFutures: true,
|
|
},
|
|
}
|
|
for _, s := range scenarios {
|
|
testScenario := s
|
|
t.Run(testScenario.item.String(), func(t *testing.T) {
|
|
t.Parallel()
|
|
if testScenario.item.IsFutures() != testScenario.isFutures {
|
|
t.Errorf("expected %v isFutures to be %v", testScenario.item, testScenario.isFutures)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestUnmarshalMarshal(t *testing.T) {
|
|
t.Parallel()
|
|
data, err := json.Marshal(Item(0))
|
|
if !errors.Is(err, nil) {
|
|
t.Fatalf("receieved: '%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("receieved: '%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("receieved: '%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("receieved: '%v' but expected: '%v'", err, ErrNotSupported)
|
|
}
|
|
|
|
err = json.Unmarshal([]byte(`""`), &spot)
|
|
if !errors.Is(err, nil) {
|
|
t.Fatalf("receieved: '%v' but expected: '%v'", err, nil)
|
|
}
|
|
|
|
err = json.Unmarshal([]byte(`123`), &spot)
|
|
if errors.Is(err, nil) {
|
|
t.Fatalf("receieved: '%v' but expected: '%v'", nil, "an error")
|
|
}
|
|
}
|
|
|
|
func TestUseDefault(t *testing.T) {
|
|
t.Parallel()
|
|
if UseDefault() != Spot {
|
|
t.Fatalf("receieved: '%v' but expected: '%v'", UseDefault(), Spot)
|
|
}
|
|
}
|