mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-14 07:26:47 +00:00
* requester: defer execution of request.Item generation in closure. * bithumb: fix issue * coinut/itbit: fix linter issues * binance: fix bug on recvWindow setting * requester: standardize sendpayload + add readme update * nonce: remove inc() function * request: defer unlockiflocked * binance: revert changes for open orders * btcmarkets: defer auth generation functionality, rm context deadline as this will be created just before sending HTTP request. * binance: move const to top * exmo: remove debug output as its generated in the requester function * ftx: defer auth functionality * requester: move error to top * bittrex: defer auth functionality * bitmex: defer auth functionality and remove deadline as generation occurs after rate limiting. * btse: defer auth functionality * coinbasepro: defer auth functionality and removed context deadline as this is generated after rate limiting * coinbene: defer auth functionality and remove context deadline as this is generated after rate limiting * huobi: defer auth functionality and remove context deadline as this is generated after rate limiting * huobi-futures: defer auth functionality and remove context deadline as this is generated after rate limiting * kraken: defer auth functionality and remove context deadline as this is generated after rate limiting * kraken: remove deadline protection for timestamp generation * okgroup: defer auth functionality and remove context deadline as this is generated after rate limiting * poloniex: defer auth functionality * zb: defer auth functionality and remove context deadline as this is generated after rate limiting * exchanges: clean up log output which are done and inspected in the requester package * binance: fix path bug on every retry, rm timeout context as this is not needed * coinbene: fix path bug on retry * binance: consolidate functionality * coinbene: fix linter issues * poloniex: linter fix * kraken: change add -> set * bitstamp: fix path bug for retry * BTSE: fix retry path bug * coinbene: fix path bug whoopsie by me * gateio: fix bug where on retry it does not reset reader * localbitcoins: fix path bug on retry * zb: change domain to land * exchanges: make sure io.Reader is generated every request * exchanges: move reader generation into function scope * wrapper_issues: setup exchange manager * engine: expand withdraw manager test * engine: dont look for environment * bitstamp: fix pathing bug (@thrasher-) * engine/withdraw_manager: purge tests as this is covered in repository withdraw
214 lines
5.5 KiB
Go
214 lines
5.5 KiB
Go
package engine
|
|
|
|
import (
|
|
"errors"
|
|
"sync"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/common"
|
|
"github.com/thrasher-corp/gocryptotrader/currency"
|
|
exchange "github.com/thrasher-corp/gocryptotrader/exchanges"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/binance"
|
|
"github.com/thrasher-corp/gocryptotrader/portfolio"
|
|
"github.com/thrasher-corp/gocryptotrader/portfolio/banking"
|
|
"github.com/thrasher-corp/gocryptotrader/portfolio/withdraw"
|
|
)
|
|
|
|
const (
|
|
exchangeName = "Binance"
|
|
)
|
|
|
|
func withdrawManagerTestHelper(t *testing.T) (*ExchangeManager, *portfolioManager) {
|
|
t.Helper()
|
|
em := SetupExchangeManager()
|
|
b := new(binance.Binance)
|
|
b.SetDefaults()
|
|
em.Add(b)
|
|
pm, err := setupPortfolioManager(em, 0, &portfolio.Base{Addresses: []portfolio.Address{}})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
return em, pm
|
|
}
|
|
|
|
func TestSubmitWithdrawal(t *testing.T) {
|
|
t.Parallel()
|
|
em, pm := withdrawManagerTestHelper(t)
|
|
m, err := SetupWithdrawManager(em, pm, false)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
bank := banking.Account{
|
|
Enabled: true,
|
|
ID: "test-bank-01",
|
|
BankName: "Test Bank",
|
|
BankAddress: "42 Bank Street",
|
|
BankPostalCode: "13337",
|
|
BankPostalCity: "Satoshiville",
|
|
BankCountry: "Japan",
|
|
AccountName: "Satoshi Nakamoto",
|
|
AccountNumber: "0234",
|
|
BSBNumber: "123456",
|
|
SWIFTCode: "91272837",
|
|
IBAN: "98218738671897",
|
|
SupportedCurrencies: "AUD,USD",
|
|
SupportedExchanges: "Binance",
|
|
}
|
|
|
|
banking.AppendAccounts(bank)
|
|
|
|
req := &withdraw.Request{
|
|
Exchange: exchangeName,
|
|
Currency: currency.AUD,
|
|
Description: exchangeName,
|
|
Amount: 1.0,
|
|
Type: withdraw.Fiat,
|
|
Fiat: withdraw.FiatRequest{
|
|
Bank: bank,
|
|
},
|
|
}
|
|
_, err = m.SubmitWithdrawal(req)
|
|
if !errors.Is(err, common.ErrFunctionNotSupported) {
|
|
t.Errorf("received %v, expected %v", err, common.ErrFunctionNotSupported)
|
|
}
|
|
|
|
req.Type = withdraw.Crypto
|
|
req.Currency = currency.BTC
|
|
req.Crypto.Address = "1337"
|
|
_, err = m.SubmitWithdrawal(req)
|
|
if !errors.Is(err, withdraw.ErrStrAddressNotWhiteListed) {
|
|
t.Errorf("received %v, expected %v", err, withdraw.ErrStrAddressNotWhiteListed)
|
|
}
|
|
var wg sync.WaitGroup
|
|
err = pm.Start(&wg)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
err = pm.AddAddress("1337", "", req.Currency, 1337)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
adds := pm.GetAddresses()
|
|
adds[0].WhiteListed = true
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("received %v, expected %v", err, nil)
|
|
}
|
|
_, err = m.SubmitWithdrawal(req)
|
|
if !errors.Is(err, withdraw.ErrStrExchangeNotSupportedByAddress) {
|
|
t.Errorf("received %v, expected %v", err, withdraw.ErrStrExchangeNotSupportedByAddress)
|
|
}
|
|
|
|
adds[0].SupportedExchanges = exchangeName
|
|
_, err = m.SubmitWithdrawal(req)
|
|
if !errors.Is(err, exchange.ErrAuthenticatedRequestWithoutCredentialsSet) {
|
|
t.Errorf("received %v, expected %v", err, exchange.ErrAuthenticatedRequestWithoutCredentialsSet)
|
|
}
|
|
|
|
_, err = m.SubmitWithdrawal(nil)
|
|
if !errors.Is(err, withdraw.ErrRequestCannotBeNil) {
|
|
t.Errorf("received %v, expected %v", err, withdraw.ErrRequestCannotBeNil)
|
|
}
|
|
|
|
m.isDryRun = true
|
|
_, err = m.SubmitWithdrawal(req)
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("received %v, expected %v", err, nil)
|
|
}
|
|
}
|
|
|
|
func TestWithdrawEventByID(t *testing.T) {
|
|
t.Parallel()
|
|
em, pm := withdrawManagerTestHelper(t)
|
|
m, err := SetupWithdrawManager(em, pm, false)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
tempResp := &withdraw.Response{
|
|
ID: withdraw.DryRunID,
|
|
}
|
|
_, err = m.WithdrawalEventByID(withdraw.DryRunID.String())
|
|
if !errors.Is(err, ErrWithdrawRequestNotFound) {
|
|
t.Errorf("received %v, expected %v", err, ErrWithdrawRequestNotFound)
|
|
}
|
|
|
|
withdraw.Cache.Add(withdraw.DryRunID.String(), tempResp)
|
|
v, err := m.WithdrawalEventByID(withdraw.DryRunID.String())
|
|
if !errors.Is(err, nil) {
|
|
t.Errorf("expected %v, received %v", nil, err)
|
|
}
|
|
if v == nil {
|
|
t.Error("expected WithdrawalEventByID() to return data from cache")
|
|
}
|
|
}
|
|
|
|
func TestWithdrawalEventByExchange(t *testing.T) {
|
|
t.Parallel()
|
|
em, pm := withdrawManagerTestHelper(t)
|
|
m, err := SetupWithdrawManager(em, pm, false)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = (*WithdrawManager)(nil).WithdrawalEventByExchange("xxx", 0)
|
|
if !errors.Is(err, ErrNilSubsystem) {
|
|
t.Errorf("received: %v but expected: %v",
|
|
err,
|
|
ErrNilSubsystem)
|
|
}
|
|
|
|
_, err = m.WithdrawalEventByExchange("xxx", 0)
|
|
if !errors.Is(err, ErrExchangeNotFound) {
|
|
t.Errorf("received: %v but expected: %v",
|
|
err,
|
|
ErrExchangeNotFound)
|
|
}
|
|
}
|
|
|
|
func TestWithdrawEventByDate(t *testing.T) {
|
|
t.Parallel()
|
|
em, pm := withdrawManagerTestHelper(t)
|
|
m, err := SetupWithdrawManager(em, pm, false)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = (*WithdrawManager)(nil).WithdrawEventByDate("xxx", time.Now(), time.Now(), 1)
|
|
if !errors.Is(err, ErrNilSubsystem) {
|
|
t.Errorf("received: %v but expected: %v",
|
|
err,
|
|
ErrNilSubsystem)
|
|
}
|
|
|
|
_, err = m.WithdrawEventByDate("xxx", time.Now(), time.Now(), 1)
|
|
if !errors.Is(err, ErrExchangeNotFound) {
|
|
t.Errorf("received: %v but expected: %v",
|
|
err,
|
|
ErrExchangeNotFound)
|
|
}
|
|
}
|
|
|
|
func TestWithdrawalEventByExchangeID(t *testing.T) {
|
|
t.Parallel()
|
|
em, _ := withdrawManagerTestHelper(t)
|
|
m, err := SetupWithdrawManager(em, nil, false)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = (*WithdrawManager)(nil).WithdrawalEventByExchangeID("xxx", "xxx")
|
|
if !errors.Is(err, ErrNilSubsystem) {
|
|
t.Errorf("received: %v but expected: %v",
|
|
err,
|
|
ErrNilSubsystem)
|
|
}
|
|
|
|
_, err = m.WithdrawalEventByExchangeID("xxx", "xxx")
|
|
if !errors.Is(err, ErrExchangeNotFound) {
|
|
t.Errorf("received: %v but expected: %v",
|
|
err,
|
|
ErrExchangeNotFound)
|
|
}
|
|
}
|