mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-23 23:16:49 +00:00
* Bump CI versions * Specifically set go version as 1.17.x bumps it to 1.18 * Another * Adjust AppVeyor * Part 1 of linter issues * Part 2 * Fix various linters and improvements * Part 3 * Finishing touches * Tests and EqualFold * Fix nitterinos plus bonus requester jobs bump for exchanges with large number of tests * Fix nitterinos and bump golangci-lint timeout for AppVeyor * Address nits, ensure all books are returned on err due to syncer regression * Fix the wiggins * Fix duplication * Fix nitterinos
288 lines
5.8 KiB
Go
288 lines
5.8 KiB
Go
package kline
|
|
|
|
import (
|
|
"errors"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/shopspring/decimal"
|
|
"github.com/thrasher-corp/gocryptotrader/backtester/common"
|
|
"github.com/thrasher-corp/gocryptotrader/backtester/eventtypes/event"
|
|
"github.com/thrasher-corp/gocryptotrader/backtester/eventtypes/kline"
|
|
"github.com/thrasher-corp/gocryptotrader/currency"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/asset"
|
|
gctkline "github.com/thrasher-corp/gocryptotrader/exchanges/kline"
|
|
)
|
|
|
|
const testExchange = "binance"
|
|
|
|
var elite = decimal.NewFromInt(1337)
|
|
|
|
func TestLoad(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
tt := time.Now()
|
|
d := DataFromKline{}
|
|
err := d.Load()
|
|
if !errors.Is(err, errNoCandleData) {
|
|
t.Errorf("received: %v, expected: %v", err, errNoCandleData)
|
|
}
|
|
d.Item = gctkline.Item{
|
|
Exchange: exch,
|
|
Pair: p,
|
|
Asset: a,
|
|
Interval: gctkline.FifteenMin,
|
|
Candles: []gctkline.Candle{
|
|
{
|
|
Time: tt,
|
|
Open: 1337,
|
|
High: 1337,
|
|
Low: 1337,
|
|
Close: 1337,
|
|
Volume: 1337,
|
|
},
|
|
},
|
|
}
|
|
err = d.Load()
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
}
|
|
|
|
func TestHasDataAtTime(t *testing.T) {
|
|
t.Parallel()
|
|
dStart := time.Date(2020, 1, 0, 0, 0, 0, 0, time.UTC)
|
|
dInsert := time.Date(2020, 1, 1, 0, 0, 0, 0, time.UTC)
|
|
dEnd := time.Date(2020, 1, 2, 0, 0, 0, 0, time.UTC)
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{}
|
|
has := d.HasDataAtTime(time.Now())
|
|
if has {
|
|
t.Error("expected false")
|
|
}
|
|
|
|
d.Item = gctkline.Item{
|
|
Exchange: exch,
|
|
Pair: p,
|
|
Asset: a,
|
|
Interval: gctkline.OneDay,
|
|
Candles: []gctkline.Candle{
|
|
{
|
|
Time: dInsert,
|
|
Open: 1337,
|
|
High: 1337,
|
|
Low: 1337,
|
|
Close: 1337,
|
|
Volume: 1337,
|
|
},
|
|
},
|
|
}
|
|
if err := d.Load(); err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
has = d.HasDataAtTime(dInsert)
|
|
if has {
|
|
t.Error("expected false")
|
|
}
|
|
|
|
ranger, err := gctkline.CalculateCandleDateRanges(dStart, dEnd, gctkline.OneDay, 100000)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
d.RangeHolder = ranger
|
|
d.RangeHolder.SetHasDataFromCandles(d.Item.Candles)
|
|
has = d.HasDataAtTime(dInsert)
|
|
if !has {
|
|
t.Error("expected true")
|
|
}
|
|
}
|
|
|
|
func TestAppend(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{
|
|
RangeHolder: &gctkline.IntervalRangeHolder{},
|
|
}
|
|
item := gctkline.Item{
|
|
Exchange: exch,
|
|
Pair: p,
|
|
Asset: a,
|
|
Interval: gctkline.OneDay,
|
|
Candles: []gctkline.Candle{
|
|
{
|
|
Time: time.Now(),
|
|
Open: 1337,
|
|
High: 1337,
|
|
Low: 1337,
|
|
Close: 1337,
|
|
Volume: 1337,
|
|
},
|
|
},
|
|
}
|
|
d.AppendResults(&item)
|
|
}
|
|
|
|
func TestStreamOpen(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{}
|
|
if bad := d.StreamOpen(); len(bad) > 0 {
|
|
t.Error("expected no stream")
|
|
}
|
|
d.SetStream([]common.DataEventHandler{
|
|
&kline.Kline{
|
|
Base: event.Base{
|
|
Exchange: exch,
|
|
Time: time.Now(),
|
|
Interval: gctkline.OneDay,
|
|
CurrencyPair: p,
|
|
AssetType: a,
|
|
},
|
|
Open: elite,
|
|
High: elite,
|
|
Low: elite,
|
|
Close: elite,
|
|
Volume: elite,
|
|
},
|
|
})
|
|
d.Next()
|
|
if open := d.StreamOpen(); len(open) == 0 {
|
|
t.Error("expected open")
|
|
}
|
|
}
|
|
|
|
func TestStreamVolume(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{}
|
|
if bad := d.StreamVol(); len(bad) > 0 {
|
|
t.Error("expected no stream")
|
|
}
|
|
d.SetStream([]common.DataEventHandler{
|
|
&kline.Kline{
|
|
Base: event.Base{
|
|
Exchange: exch,
|
|
Time: time.Now(),
|
|
Interval: gctkline.OneDay,
|
|
CurrencyPair: p,
|
|
AssetType: a,
|
|
},
|
|
Open: elite,
|
|
High: elite,
|
|
Low: elite,
|
|
Close: elite,
|
|
Volume: elite,
|
|
},
|
|
})
|
|
d.Next()
|
|
if open := d.StreamVol(); len(open) == 0 {
|
|
t.Error("expected volume")
|
|
}
|
|
}
|
|
|
|
func TestStreamClose(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{}
|
|
if bad := d.StreamClose(); len(bad) > 0 {
|
|
t.Error("expected no stream")
|
|
}
|
|
d.SetStream([]common.DataEventHandler{
|
|
&kline.Kline{
|
|
Base: event.Base{
|
|
Exchange: exch,
|
|
Time: time.Now(),
|
|
Interval: gctkline.OneDay,
|
|
CurrencyPair: p,
|
|
AssetType: a,
|
|
},
|
|
Open: elite,
|
|
High: elite,
|
|
Low: elite,
|
|
Close: elite,
|
|
Volume: elite,
|
|
},
|
|
})
|
|
d.Next()
|
|
if open := d.StreamClose(); len(open) == 0 {
|
|
t.Error("expected close")
|
|
}
|
|
}
|
|
|
|
func TestStreamHigh(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{}
|
|
if bad := d.StreamHigh(); len(bad) > 0 {
|
|
t.Error("expected no stream")
|
|
}
|
|
d.SetStream([]common.DataEventHandler{
|
|
&kline.Kline{
|
|
Base: event.Base{
|
|
Exchange: exch,
|
|
Time: time.Now(),
|
|
Interval: gctkline.OneDay,
|
|
CurrencyPair: p,
|
|
AssetType: a,
|
|
},
|
|
Open: elite,
|
|
High: elite,
|
|
Low: elite,
|
|
Close: elite,
|
|
Volume: elite,
|
|
},
|
|
})
|
|
d.Next()
|
|
if open := d.StreamHigh(); len(open) == 0 {
|
|
t.Error("expected high")
|
|
}
|
|
}
|
|
|
|
func TestStreamLow(t *testing.T) {
|
|
t.Parallel()
|
|
exch := testExchange
|
|
a := asset.Spot
|
|
p := currency.NewPair(currency.BTC, currency.USDT)
|
|
d := DataFromKline{
|
|
RangeHolder: &gctkline.IntervalRangeHolder{},
|
|
}
|
|
if bad := d.StreamLow(); len(bad) > 0 {
|
|
t.Error("expected no stream")
|
|
}
|
|
d.SetStream([]common.DataEventHandler{
|
|
&kline.Kline{
|
|
Base: event.Base{
|
|
Exchange: exch,
|
|
Time: time.Now(),
|
|
Interval: gctkline.OneDay,
|
|
CurrencyPair: p,
|
|
AssetType: a,
|
|
},
|
|
Open: elite,
|
|
High: elite,
|
|
Low: elite,
|
|
Close: elite,
|
|
Volume: elite,
|
|
},
|
|
})
|
|
d.Next()
|
|
if open := d.StreamLow(); len(open) == 0 {
|
|
t.Error("expected low")
|
|
}
|
|
}
|