mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-13 23:16:45 +00:00
* fix kraken, batch bittrex, fix lint * surprise gemini! * thought this happened automatically * fix before shazbert sees * fixes annoying atoi bug * rm futures from gemini * lint * bittrex UpdatedAt, gemini Limits, stats relook * STATS used HARDEN!(improve stats package) * Whoopsies in your Daisies * rm RWMutex, json stringeroo * fixes additional index issues 😆 😭
288 lines
5.8 KiB
Go
288 lines
5.8 KiB
Go
package stats
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/currency"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/asset"
|
|
)
|
|
|
|
const (
|
|
testExchange = "Okx"
|
|
)
|
|
|
|
func TestLenByPrice(t *testing.T) {
|
|
t.Parallel()
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
localItems := []Item{
|
|
{
|
|
Exchange: testExchange,
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1200,
|
|
Volume: 5,
|
|
},
|
|
}
|
|
|
|
if byPrice.Len(localItems) < 1 {
|
|
t.Error("stats LenByPrice() length not correct.")
|
|
}
|
|
}
|
|
|
|
func TestLessByPrice(t *testing.T) {
|
|
t.Parallel()
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
localItems := []Item{
|
|
{
|
|
Exchange: "alphapoint",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1200,
|
|
Volume: 5,
|
|
},
|
|
{
|
|
Exchange: "bitfinex",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1198,
|
|
Volume: 20,
|
|
},
|
|
}
|
|
|
|
if !byPrice.Less(localItems, 1, 0) {
|
|
t.Error("stats LessByPrice() incorrect return.")
|
|
}
|
|
if byPrice.Less(localItems, 0, 1) {
|
|
t.Error("stats LessByPrice() incorrect return.")
|
|
}
|
|
}
|
|
|
|
func TestSwapByPrice(t *testing.T) {
|
|
t.Parallel()
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
localItems := []Item{
|
|
{
|
|
Exchange: "bitstamp",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1324,
|
|
Volume: 5,
|
|
},
|
|
{
|
|
Exchange: "bitfinex",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 7863,
|
|
Volume: 20,
|
|
},
|
|
}
|
|
|
|
byPrice.Swap(localItems, 0, 1)
|
|
if localItems[0].Exchange != "bitfinex" || localItems[1].Exchange != "bitstamp" {
|
|
t.Error("stats SwapByPrice did not swap values.")
|
|
}
|
|
}
|
|
|
|
func TestLenByVolume(t *testing.T) {
|
|
t.Parallel()
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
localItems := []Item{
|
|
{
|
|
Exchange: "bitstamp",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1324,
|
|
Volume: 5,
|
|
},
|
|
{
|
|
Exchange: "bitfinex",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 7863,
|
|
Volume: 20,
|
|
},
|
|
}
|
|
|
|
if byVolume.Len(localItems) != 2 {
|
|
t.Error("stats lenByVolume did not swap values.")
|
|
}
|
|
}
|
|
|
|
func TestLessByVolume(t *testing.T) {
|
|
t.Parallel()
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
localItems := []Item{
|
|
{
|
|
Exchange: "bitstamp",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1324,
|
|
Volume: 5,
|
|
},
|
|
{
|
|
Exchange: "bitfinex",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 7863,
|
|
Volume: 20,
|
|
},
|
|
}
|
|
if !byVolume.Less(localItems, 0, 1) {
|
|
t.Error("localItems[0].Volume should be less than localItems[1].Volume")
|
|
}
|
|
}
|
|
|
|
func TestSwapByVolume(t *testing.T) {
|
|
t.Parallel()
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
localItems := []Item{
|
|
{
|
|
Exchange: "bitstamp",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 1324,
|
|
Volume: 5,
|
|
},
|
|
{
|
|
Exchange: "bitfinex",
|
|
Pair: p,
|
|
AssetType: asset.Spot,
|
|
Price: 7863,
|
|
Volume: 20,
|
|
},
|
|
}
|
|
byVolume.Swap(localItems, 0, 1)
|
|
if localItems[0].Exchange != "bitfinex" || localItems[1].Exchange != "bitstamp" {
|
|
t.Error("stats SwapByVolume did not swap values.")
|
|
}
|
|
}
|
|
|
|
func TestAdd(t *testing.T) {
|
|
items = items[:0]
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
err = Add(testExchange, p, asset.Spot, 1200, 42)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if len(items) < 1 {
|
|
t.Error("stats Add did not add exchange info.")
|
|
}
|
|
|
|
err = Add("", p, asset.Empty, 0, 0)
|
|
if err == nil {
|
|
t.Fatal("error cannot be nil")
|
|
}
|
|
|
|
if len(items) != 1 {
|
|
t.Error("stats Add did not add exchange info.")
|
|
}
|
|
|
|
p.Base = currency.XBT
|
|
err = Add(testExchange, p, asset.Spot, 1201, 43)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if items[1].Pair.String() != "XBTUSD" {
|
|
t.Fatal("stats Add did not add exchange info.")
|
|
}
|
|
|
|
p, err = currency.NewPairFromStrings("ETH", "USDT")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
err = Add(testExchange, p, asset.Spot, 300, 1000)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if items[2].Pair.String() != "ETHUSD" {
|
|
t.Fatal("stats Add did not add exchange info.")
|
|
}
|
|
}
|
|
|
|
func TestAppend(t *testing.T) {
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
Append("sillyexchange", p, asset.Spot, 1234, 45)
|
|
if len(items) < 2 {
|
|
t.Error("stats AppendResults did not add exchange values.")
|
|
}
|
|
|
|
Append("sillyexchange", p, asset.Spot, 1234, 45)
|
|
if len(items) == 3 {
|
|
t.Error("stats AppendResults added exchange values")
|
|
}
|
|
}
|
|
|
|
func TestAlreadyExists(t *testing.T) {
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !AlreadyExists(testExchange, p, asset.Spot, 1200, 42) {
|
|
t.Error("stats AlreadyExists exchange does not exist.")
|
|
}
|
|
p.Base = currency.NewCode("dii")
|
|
if AlreadyExists("bla", p, asset.Spot, 1234, 123) {
|
|
t.Error("stats AlreadyExists found incorrect exchange.")
|
|
}
|
|
}
|
|
|
|
func TestSortExchangesByVolume(t *testing.T) {
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
topVolume := SortExchangesByVolume(p, asset.Spot, true)
|
|
if topVolume[0].Exchange != "sillyexchange" {
|
|
t.Error("stats SortExchangesByVolume incorrectly sorted values.")
|
|
}
|
|
|
|
topVolume = SortExchangesByVolume(p, asset.Spot, false)
|
|
if topVolume[0].Exchange != testExchange {
|
|
t.Error("stats SortExchangesByVolume incorrectly sorted values.")
|
|
}
|
|
}
|
|
|
|
func TestSortExchangesByPrice(t *testing.T) {
|
|
p, err := currency.NewPairFromStrings("BTC", "USD")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
topPrice := SortExchangesByPrice(p, asset.Spot, true)
|
|
if topPrice[0].Exchange != "sillyexchange" {
|
|
t.Error("stats SortExchangesByPrice incorrectly sorted values.")
|
|
}
|
|
|
|
topPrice = SortExchangesByPrice(p, asset.Spot, false)
|
|
if topPrice[0].Exchange != testExchange {
|
|
t.Error("stats SortExchangesByPrice incorrectly sorted values.")
|
|
}
|
|
}
|