mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-13 23:16:45 +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
184 lines
4.8 KiB
Go
184 lines
4.8 KiB
Go
package collateral
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
func TestValidCollateralType(t *testing.T) {
|
|
t.Parallel()
|
|
if !SingleMode.Valid() {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if !MultiMode.Valid() {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if !PortfolioMode.Valid() {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if !SpotFuturesMode.Valid() {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if UnsetMode.Valid() {
|
|
t.Fatal("expected 'false', received 'true'")
|
|
}
|
|
if UnknownMode.Valid() {
|
|
t.Fatal("expected 'false', received 'true'")
|
|
}
|
|
if Mode(137).Valid() {
|
|
t.Fatal("expected 'false', received 'true'")
|
|
}
|
|
}
|
|
|
|
func TestUnmarshalJSONCollateralType(t *testing.T) {
|
|
t.Parallel()
|
|
type martian struct {
|
|
M Mode `json:"collateral"`
|
|
}
|
|
|
|
var alien martian
|
|
jason := []byte(`{"collateral":"single"}`)
|
|
err := json.Unmarshal(jason, &alien)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if alien.M != SingleMode {
|
|
t.Errorf("received '%v' expected 'single'", alien.M)
|
|
}
|
|
|
|
jason = []byte(`{"collateral":"multi"}`)
|
|
err = json.Unmarshal(jason, &alien)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if alien.M != MultiMode {
|
|
t.Errorf("received '%v' expected 'Multi'", alien.M)
|
|
}
|
|
|
|
jason = []byte(`{"collateral":"portfolio"}`)
|
|
err = json.Unmarshal(jason, &alien)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if alien.M != PortfolioMode {
|
|
t.Errorf("received '%v' expected 'Portfolio'", alien.M)
|
|
}
|
|
|
|
jason = []byte(`{"collateral":"hello moto"}`)
|
|
err = json.Unmarshal(jason, &alien)
|
|
if !errors.Is(err, ErrInvalidCollateralMode) {
|
|
t.Error(err)
|
|
}
|
|
if alien.M != UnknownMode {
|
|
t.Errorf("received '%v' expected 'UnknownMode'", alien.M)
|
|
}
|
|
}
|
|
|
|
func TestStringCollateralType(t *testing.T) {
|
|
t.Parallel()
|
|
if UnknownMode.String() != unknownCollateralStr {
|
|
t.Errorf("received '%v' expected '%v'", UnknownMode.String(), unknownCollateralStr)
|
|
}
|
|
if SingleMode.String() != singleCollateralStr {
|
|
t.Errorf("received '%v' expected '%v'", SingleMode.String(), singleCollateralStr)
|
|
}
|
|
if MultiMode.String() != multiCollateralStr {
|
|
t.Errorf("received '%v' expected '%v'", MultiMode.String(), multiCollateralStr)
|
|
}
|
|
if PortfolioMode.String() != portfolioCollateralStr {
|
|
t.Errorf("received '%v' expected '%v'", PortfolioMode.String(), portfolioCollateralStr)
|
|
}
|
|
if UnsetMode.String() != unsetCollateralStr {
|
|
t.Errorf("received '%v' expected '%v'", UnsetMode.String(), unsetCollateralStr)
|
|
}
|
|
}
|
|
|
|
func TestUpperCollateralType(t *testing.T) {
|
|
t.Parallel()
|
|
if UnknownMode.Upper() != strings.ToUpper(unknownCollateralStr) {
|
|
t.Errorf("received '%v' expected '%v'", UnknownMode.Upper(), strings.ToUpper(unknownCollateralStr))
|
|
}
|
|
if SingleMode.Upper() != strings.ToUpper(singleCollateralStr) {
|
|
t.Errorf("received '%v' expected '%v'", SingleMode.Upper(), strings.ToUpper(singleCollateralStr))
|
|
}
|
|
if MultiMode.Upper() != strings.ToUpper(multiCollateralStr) {
|
|
t.Errorf("received '%v' expected '%v'", MultiMode.Upper(), strings.ToUpper(multiCollateralStr))
|
|
}
|
|
if PortfolioMode.Upper() != strings.ToUpper(portfolioCollateralStr) {
|
|
t.Errorf("received '%v' expected '%v'", PortfolioMode.Upper(), strings.ToUpper(portfolioCollateralStr))
|
|
}
|
|
if UnsetMode.Upper() != strings.ToUpper(unsetCollateralStr) {
|
|
t.Errorf("received '%v' expected '%v'", UnsetMode.Upper(), strings.ToUpper(unsetCollateralStr))
|
|
}
|
|
}
|
|
|
|
func TestIsValidCollateralTypeString(t *testing.T) {
|
|
t.Parallel()
|
|
if IsValidCollateralModeString("lol") {
|
|
t.Fatal("expected 'false', received 'true'")
|
|
}
|
|
if !IsValidCollateralModeString("single") {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if !IsValidCollateralModeString("multi") {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if !IsValidCollateralModeString("portfolio") {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if !IsValidCollateralModeString("unset") {
|
|
t.Fatal("expected 'true', received 'false'")
|
|
}
|
|
if IsValidCollateralModeString("") {
|
|
t.Fatal("expected 'false', received 'true'")
|
|
}
|
|
if IsValidCollateralModeString("unknown") {
|
|
t.Fatal("expected 'false', received 'true'")
|
|
}
|
|
}
|
|
|
|
func TestStringToCollateralType(t *testing.T) {
|
|
t.Parallel()
|
|
resp, err := StringToMode("lol")
|
|
if !errors.Is(err, ErrInvalidCollateralMode) {
|
|
t.Error(err)
|
|
}
|
|
if resp != UnknownMode {
|
|
t.Errorf("received '%v' expected '%v'", resp, UnknownMode)
|
|
}
|
|
|
|
resp, err = StringToMode("")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if resp != UnsetMode {
|
|
t.Errorf("received '%v' expected '%v'", resp, UnsetMode)
|
|
}
|
|
|
|
resp, err = StringToMode("single")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if resp != SingleMode {
|
|
t.Errorf("received '%v' expected '%v'", resp, SingleMode)
|
|
}
|
|
|
|
resp, err = StringToMode("multi")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if resp != MultiMode {
|
|
t.Errorf("received '%v' expected '%v'", resp, MultiMode)
|
|
}
|
|
|
|
resp, err = StringToMode("portfolio")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if resp != PortfolioMode {
|
|
t.Errorf("received '%v' expected '%v'", resp, PortfolioMode)
|
|
}
|
|
}
|