Files
gocryptotrader/exchanges/collateral/collateral_test.go
Samuael A. 5c892307c7 exchanges: Okx Update (#1420)
* 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
2025-02-10 10:44:48 +11:00

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