mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-17 15:09:59 +00:00
* added mfi and example * renamed to moving average * converted to array return type and added obv and mfi * started work on test coverage * test coverage added for rsi & mfi * test coverage added for all indicators removed go mod replace moved to append helper method * moved all indicators to new appendTo and increased test coverage * added additional test and bumped go-talib to latest commi * go.mod update * linter fixes * go mod clean up * small fixes * reverted changes from previous attempt to rework as data is still incorrect now passing full OHLCV data back to script binding * testing new structure of passing full ohlcv data * started linking ohlcv to gctscript * OHCLV link up completed reworking passing back to indicators started * OHCLV link up completed reworking passing back to indicators started * added test coverage for tofloat * linter fixes (gofmt) * removed unused value * improved test coverage * added correct detection for 1w added ParseInterval test coverage moved OHCLV string to const * removed unused value * first round of changes addressed * all indicators have been split with packages named after each indicator and a new calculate() method added * linters * fixed tests * added check to check ta is running in validator for uploading * Added test data for OHLCV testing new indicator interface for wrapper * typed const to float64 * reworked validator data to generate previous timestamps * rewored macd to return slice of array * adding bbands linking and example * why didn't this pick it up before :D * bumped up total number of modules for test * moved parseIndicator to exchange added comments * test coverage added for ParseMAType & ParseIndicatorSelector * gofmt * WIP changes * updated tests for bbands & obv bumped to latest go-talib * move multiple use strong to const * reverted rpc.pb.go to master * added 4w option * removed selector from obv as unneeded * improved test coverage and reworked all indicator methods on how they pass errors back * order incoming OHCLV data * revert go.mod * removed verbose toggles * added spot asset type * removed 4w as its unused/uncommon * renamed * reworked further tests * converted all examples to use coinbasepro for consistency * updated all date ranges to 2019 + 6 months * backported binance OHLCV wrapper from #479 * removed o * rounded numbers * chnage requests addressed and attempt to fix MACD... today has been really unproctive code wise :D * Migrated to gct-ta library * Corrected test import * wording changes on test * removed TA lib from go.mod * PR changes addressed Removed parallel running from tests due to slight possibility in very extreme cases TestExecution might not be set to the expected value and will cause lower test coverage * removed pkg folder * bumped gct-ta version * gct-ta version bump
313 lines
6.5 KiB
Go
313 lines
6.5 KiB
Go
package gct
|
|
|
|
import (
|
|
"errors"
|
|
"os"
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
objects "github.com/d5/tengo/v2"
|
|
"github.com/thrasher-corp/gocryptotrader/gctscript/modules"
|
|
"github.com/thrasher-corp/gocryptotrader/gctscript/wrappers/validator"
|
|
)
|
|
|
|
var (
|
|
exch = &objects.String{
|
|
Value: "BTC Markets",
|
|
}
|
|
exchError = &objects.String{
|
|
Value: "error",
|
|
}
|
|
currencyPair = &objects.String{
|
|
Value: "BTC-AUD",
|
|
}
|
|
delimiter = &objects.String{
|
|
Value: "-",
|
|
}
|
|
assetType = &objects.String{
|
|
Value: "SPOT",
|
|
}
|
|
orderID = &objects.String{
|
|
Value: "1235",
|
|
}
|
|
|
|
tv = objects.TrueValue
|
|
fv = objects.FalseValue
|
|
errTestFailed = errors.New("test failed")
|
|
)
|
|
|
|
func TestMain(m *testing.M) {
|
|
modules.SetModuleWrapper(validator.Wrapper{})
|
|
os.Exit(m.Run())
|
|
}
|
|
|
|
func TestExchangeOrderbook(t *testing.T) {
|
|
t.Parallel()
|
|
_, err := ExchangeOrderbook(exch, currencyPair, delimiter, assetType)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderbook(exchError, currencyPair, delimiter, assetType)
|
|
if err != nil && errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderbook()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeTicker(t *testing.T) {
|
|
t.Parallel()
|
|
_, err := ExchangeTicker(exch, currencyPair, delimiter, assetType)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeTicker(exchError, currencyPair, delimiter, assetType)
|
|
if err != nil && errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeTicker()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeExchanges(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
_, err := ExchangeExchanges(tv)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeExchanges(exch)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeExchanges(fv)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeExchanges()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangePairs(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
_, err := ExchangePairs(exch, tv, assetType)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangePairs(exchError, tv, assetType)
|
|
if err != nil && errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangePairs()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestAccountInfo(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
_, err := ExchangeAccountInfo()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeAccountInfo(exch)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeAccountInfo(exchError)
|
|
if err != nil && !errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeOrderQuery(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
_, err := ExchangeOrderQuery()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderQuery(exch, orderID)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderQuery(exchError, orderID)
|
|
if err != nil && !errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeOrderCancel(t *testing.T) {
|
|
_, err := ExchangeOrderCancel()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderCancel(exch, orderID)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderCancel(exch, objects.FalseValue)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderCancel(exchError, orderID)
|
|
if err != nil && !errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeOrderSubmit(t *testing.T) {
|
|
_, err := ExchangeOrderSubmit()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
orderSide := &objects.String{Value: "ASK"}
|
|
orderType := &objects.String{Value: "LIMIT"}
|
|
orderPrice := &objects.Float{Value: 1}
|
|
orderAmount := &objects.Float{Value: 1}
|
|
|
|
_, err = ExchangeOrderSubmit(exch, currencyPair, delimiter,
|
|
orderType, orderSide, orderPrice, orderAmount, orderID)
|
|
if err != nil && !errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderSubmit(exch, currencyPair, delimiter,
|
|
orderType, orderSide, orderPrice, orderAmount, orderID)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeOrderSubmit(objects.TrueValue, currencyPair, delimiter,
|
|
orderType, orderSide, orderPrice, orderAmount, orderID)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestAllModuleNames(t *testing.T) {
|
|
x := AllModuleNames()
|
|
xType := reflect.TypeOf(x).Kind()
|
|
if xType != reflect.Slice {
|
|
t.Fatalf("AllModuleNames() should return slice instead received: %v", x)
|
|
}
|
|
}
|
|
|
|
func TestExchangeDepositAddress(t *testing.T) {
|
|
_, err := ExchangeDepositAddress()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
currCode := &objects.String{Value: "BTC"}
|
|
_, err = ExchangeDepositAddress(exch, currCode)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
_, err = ExchangeDepositAddress(exchError, currCode)
|
|
if err != nil && !errors.Is(err, errTestFailed) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeWithdrawCrypto(t *testing.T) {
|
|
_, err := ExchangeWithdrawCrypto()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
currCode := &objects.String{Value: "BTC"}
|
|
desc := &objects.String{Value: "HELLO"}
|
|
address := &objects.String{Value: "0xTHISISALEGITBTCADDRESSS"}
|
|
amount := &objects.Float{Value: 1.0}
|
|
|
|
_, err = ExchangeWithdrawCrypto(exch, currCode, address, address, amount, amount, desc)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestExchangeWithdrawFiat(t *testing.T) {
|
|
_, err := ExchangeWithdrawFiat()
|
|
if !errors.Is(err, objects.ErrWrongNumArguments) {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
currCode := &objects.String{Value: "AUD"}
|
|
desc := &objects.String{Value: "Hello"}
|
|
amount := &objects.Float{Value: 1.0}
|
|
bankID := &objects.String{Value: "test-bank-01"}
|
|
_, err = ExchangeWithdrawFiat(exch, currCode, desc, amount, bankID)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestParseInterval(t *testing.T) {
|
|
v, err := parseInterval("1h")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if v != time.Hour {
|
|
t.Fatalf("unexpected value return expected %v received %v", time.Hour, v)
|
|
}
|
|
|
|
v, err = parseInterval("1d")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if v != time.Hour*24 {
|
|
t.Fatalf("unexpected value return expected %v received %v", time.Hour*24, v)
|
|
}
|
|
|
|
v, err = parseInterval("3d")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if v != time.Hour*72 {
|
|
t.Fatalf("unexpected value return expected %v received %v", time.Hour*72, v)
|
|
}
|
|
|
|
v, err = parseInterval("1w")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if v != time.Hour*168 {
|
|
t.Fatalf("unexpected value return expected %v received %v", time.Hour*168, v)
|
|
}
|
|
|
|
_, err = parseInterval("6m")
|
|
if err != nil {
|
|
if !errors.Is(err, errInvalidInterval) {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
}
|