GHA: Add additional checks for common issues (#1922)

* GHA, tests: Add additional checks for common issues

These checks include:
- Ensuring that all testify funcs use their formatted variants (e.g., `assert.Equalf(t, expected, actual)` instead of `assert.Equal(t, expected, actual)`).
- Replacing `%s` with %q
- Enforcing consistent usage of should/must wording for testify assert/require messages

* Add support for checking backticked string format specifiers and fix issues

* tests: Fix error comparisons

* tests: Replace errors.Is(err, nil) usage with testify and automate check

* refactor: Rename ExtractPort to ExtractPortOrDefault

* tests: Replace assert with require for error handling in multiple test files

* tests: Replace assert with require for error handling and improve assertions in data tests

* tests: Fix typo in assertion message for StreamVol test

* OKX: Fix GetOpenInterestAndVolumeStrike test with instrument selection and improved assertions

* OKX: Revert intentional error check

* Improve error message for expiry time check in GetOpenInterestAndVolumeStrike test
This commit is contained in:
Adrian Gallagher
2025-05-28 12:26:51 +10:00
committed by GitHub
parent 1e5739dffa
commit a5b638bfb7
165 changed files with 2565 additions and 4626 deletions

View File

@@ -7,6 +7,8 @@ import (
"time"
"github.com/shopspring/decimal"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/thrasher-corp/gocryptotrader/backtester/common"
"github.com/thrasher-corp/gocryptotrader/backtester/eventtypes/event"
gctcommon "github.com/thrasher-corp/gocryptotrader/common"
@@ -34,9 +36,8 @@ func TestSetDataForCurrency(t *testing.T) {
t.Parallel()
d := HandlerHolder{}
err := d.SetDataForCurrency(exch, a, p, nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
if d.data == nil {
t.Error("expected not nil")
}
@@ -54,34 +55,25 @@ func TestGetAllData(t *testing.T) {
t.Parallel()
d := HandlerHolder{}
err := d.SetDataForCurrency(exch, a, p, nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
err = d.SetDataForCurrency(exch, a, currency.NewPair(currency.BTC, currency.DOGE), nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
result, err := d.GetAllData()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(result) != 2 {
t.Error("expected 2")
}
require.NoError(t, err)
assert.Len(t, result, 2, "GetAllData should return 2 items")
}
func TestGetDataForCurrency(t *testing.T) {
t.Parallel()
d := HandlerHolder{}
err := d.SetDataForCurrency(exch, a, p, &fakeHandler{})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
err = d.SetDataForCurrency(exch, a, currency.NewPair(currency.BTC, currency.DOGE), nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
_, err = d.GetDataForCurrency(nil)
if !errors.Is(err, common.ErrNilEvent) {
t.Errorf("received '%v' expected '%v'", err, common.ErrNilEvent)
@@ -101,63 +93,44 @@ func TestGetDataForCurrency(t *testing.T) {
AssetType: a,
CurrencyPair: p,
}})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
}
func TestReset(t *testing.T) {
t.Parallel()
d := &HandlerHolder{}
err := d.SetDataForCurrency(exch, a, p, nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
err = d.SetDataForCurrency(exch, a, currency.NewPair(currency.BTC, currency.DOGE), nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
err = d.Reset()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if d.data == nil {
t.Error("expected a map")
}
require.NoError(t, err)
assert.NotNil(t, d.data, "Reset should initialise the data map")
d = nil
err = d.Reset()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestBaseReset(t *testing.T) {
t.Parallel()
b := &Base{offset: 1}
err := b.Reset()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if b.offset != 0 {
t.Errorf("received '%v' expected '%v'", b.offset, 0)
}
require.NoError(t, err)
assert.Zero(t, b.offset, "offset should be reset")
b = nil
err = b.Reset()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestGetStream(t *testing.T) {
t.Parallel()
b := &Base{}
resp, err := b.GetStream()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(resp) != 0 {
t.Errorf("received '%v' expected '%v'", len(resp), 0)
}
require.NoError(t, err)
assert.Empty(t, resp, "GetStream should return an empty slice")
b.stream = []Event{
&fakeEvent{
Base: &event.Base{
@@ -173,56 +146,39 @@ func TestGetStream(t *testing.T) {
},
}
resp, err = b.GetStream()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(resp) != 2 {
t.Errorf("received '%v' expected '%v'", len(resp), 2)
}
require.NoError(t, err)
assert.Len(t, resp, 2, "GetStream should return 2 items")
b = nil
_, err = b.GetStream()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestOffset(t *testing.T) {
t.Parallel()
b := &Base{}
o, err := b.Offset()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if o != 0 {
t.Errorf("received '%v' expected '%v'", o, 0)
}
require.NoError(t, err)
assert.Zero(t, o, "offset should be zero when not set")
b.offset = 1337
o, err = b.Offset()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if o != 1337 {
t.Errorf("received '%v' expected '%v'", o, 1337)
}
require.NoError(t, err)
assert.Equal(t, int64(1337), o, "offset value should be correct")
b = nil
_, err = b.Offset()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestSetStream(t *testing.T) {
t.Parallel()
b := &Base{}
err := b.SetStream(nil)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(b.stream) != 0 {
t.Errorf("received '%v' expected '%v'", len(b.stream), 0)
}
require.NoError(t, err)
assert.Empty(t, b.stream, "SetStream should not error with nil slice and stream should be empty")
cp := currency.NewBTCUSD()
err = b.SetStream([]Event{
&fakeEvent{
@@ -244,17 +200,9 @@ func TestSetStream(t *testing.T) {
},
},
})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(b.stream) != 2 {
t.Fatalf("received '%v' expected '%v'", len(b.stream), 2)
}
if b.stream[0].GetOffset() != 1 {
t.Errorf("received '%v' expected '%v'", b.stream[0].GetOffset(), 1)
}
require.NoError(t, err)
assert.Len(t, b.stream, 2, "stream elements should be set correctly")
assert.Equal(t, int64(1), b.stream[0].GetOffset(), "GetOffset should return the correct value")
misMatchEvent := &fakeEvent{
Base: &event.Base{
Exchange: "mismatch",
@@ -309,36 +257,23 @@ func TestNext(t *testing.T) {
},
},
})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
resp, err := b.Next()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if resp != b.stream[0] {
t.Errorf("received '%v' expected '%v'", resp, b.stream[0])
}
if b.offset != 1 {
t.Errorf("received '%v' expected '%v'", b.offset, 1)
}
require.NoError(t, err)
assert.Equal(t, b.stream[0], resp, "Next should return the first event in the stream")
assert.Equal(t, int64(1), b.offset, "offset should be correct")
_, err = b.Next()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
resp, err = b.Next()
if !errors.Is(err, ErrEndOfData) {
t.Errorf("received '%v' expected '%v'", err, ErrEndOfData)
}
if resp != nil {
t.Errorf("received '%v' expected '%v'", resp, nil)
}
require.ErrorIs(t, err, ErrEndOfData)
assert.Nil(t, resp, "Expected nil response after end of data")
b = nil
_, err = b.Next()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestHistory(t *testing.T) {
@@ -365,34 +300,22 @@ func TestHistory(t *testing.T) {
},
},
})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
resp, err := b.History()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(resp) != 0 {
t.Errorf("received '%v' expected '%v'", len(resp), 0)
}
require.NoError(t, err)
assert.Empty(t, resp, "History should return an empty slice when no events have been processed")
_, err = b.Next()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
resp, err = b.History()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(resp) != 1 {
t.Errorf("received '%v' expected '%v'", len(resp), 1)
}
require.NoError(t, err)
assert.Len(t, resp, 1, "History should return the first event after one Next call")
b = nil
_, err = b.History()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestLatest(t *testing.T) {
@@ -419,45 +342,30 @@ func TestLatest(t *testing.T) {
},
},
})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
resp, err := b.Latest()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if resp != b.stream[0] {
t.Errorf("received '%v' expected '%v'", resp, b.stream[0])
}
_, err = b.Next()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
resp, err = b.Latest()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if resp != b.stream[0] {
t.Errorf("received '%v' expected '%v'", resp, b.stream[0])
}
require.NoError(t, err)
assert.Equal(t, b.stream[0], resp, "Latest should return the first event in the stream")
_, err = b.Next()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
resp, err = b.Latest()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if resp != b.stream[1] {
t.Errorf("received '%v' expected '%v'", resp, b.stream[1])
}
require.NoError(t, err)
assert.Equal(t, b.stream[0], resp, "Latest should return the first event after one Next call")
_, err = b.Next()
require.NoError(t, err)
resp, err = b.Latest()
require.NoError(t, err)
assert.Equal(t, b.stream[1], resp, "Latest should return the second event after two Next calls")
b = nil
_, err = b.Latest()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestList(t *testing.T) {
@@ -484,22 +392,15 @@ func TestList(t *testing.T) {
},
},
})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
list, err := b.List()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if len(list) != 2 {
t.Errorf("received '%v' expected '%v'", len(list), 2)
}
require.NoError(t, err)
assert.Len(t, list, 2, "List should return all events in the stream")
b = nil
_, err = b.List()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestIsLastEvent(t *testing.T) {
@@ -526,50 +427,37 @@ func TestIsLastEvent(t *testing.T) {
},
},
})
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
b.latest = b.stream[0]
b.offset = b.stream[0].GetOffset()
isLastEvent, err := b.IsLastEvent()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if isLastEvent {
t.Errorf("received '%v' expected '%v'", false, true)
}
require.NoError(t, err)
assert.False(t, isLastEvent, "isLastEvent should return false when not at the last event")
b.isLiveData = true
isLastEvent, err = b.IsLastEvent()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if isLastEvent {
t.Errorf("received '%v' expected '%v'", false, true)
}
require.NoError(t, err)
assert.False(t, isLastEvent, "isLastEvent should return false when live data is set")
b = nil
_, err = b.IsLastEvent()
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received '%v' expected '%v'", err, gctcommon.ErrNilPointer)
}
assert.ErrorIs(t, err, gctcommon.ErrNilPointer)
}
func TestIsLive(t *testing.T) {
t.Parallel()
b := &Base{}
isLive, err := b.IsLive()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
if isLive {
t.Error("expected false")
}
b.isLiveData = true
isLive, err = b.IsLive()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
if !isLive {
t.Error("expected true")
}
@@ -585,17 +473,15 @@ func TestSetLive(t *testing.T) {
t.Parallel()
b := &Base{}
err := b.SetLive(true)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
if !b.isLiveData {
t.Error("expected true")
}
err = b.SetLive(false)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
assert.NoError(t, err)
if b.isLiveData {
t.Error("expected false")
}
@@ -632,17 +518,15 @@ func TestAppendStream(t *testing.T) {
e.Time = tt
err = b.AppendStream(e, e)
if !errors.Is(err, nil) {
t.Fatalf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
if len(b.stream) != 1 {
t.Errorf("received '%v' expected '%v'", len(b.stream), 1)
}
err = b.AppendStream(e)
if !errors.Is(err, nil) {
t.Fatalf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
if len(b.stream) != 1 {
t.Errorf("received '%v' expected '%v'", len(b.stream), 1)
}
@@ -655,9 +539,8 @@ func TestAppendStream(t *testing.T) {
Time: time.Now(),
},
})
if !errors.Is(err, nil) {
t.Fatalf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
if len(b.stream) != 2 {
t.Errorf("received '%v' expected '%v'", len(b.stream), 2)
}
@@ -713,12 +596,8 @@ func TestFirst(t *testing.T) {
}
first, err := e.First()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if first.GetOffset() != id1 {
t.Errorf("received '%v' expected '%v'", first.GetOffset(), id1)
}
require.NoError(t, err)
assert.Equal(t, id1, first.GetOffset())
}
func TestLast(t *testing.T) {
@@ -733,12 +612,8 @@ func TestLast(t *testing.T) {
}
last, err := e.Last()
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
if last.GetOffset() != id3 {
t.Errorf("received '%v' expected '%v'", last.GetOffset(), id1)
}
require.NoError(t, err)
assert.Equal(t, id3, last.GetOffset())
}
// methods that satisfy the common.Event interface

View File

@@ -5,6 +5,7 @@ import (
"path/filepath"
"testing"
"github.com/stretchr/testify/assert"
"github.com/thrasher-corp/gocryptotrader/backtester/common"
"github.com/thrasher-corp/gocryptotrader/currency"
"github.com/thrasher-corp/gocryptotrader/exchanges/asset"
@@ -25,9 +26,7 @@ func TestLoadDataCandles(t *testing.T) {
p,
a,
false)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
}
func TestLoadDataTrades(t *testing.T) {
@@ -42,9 +41,7 @@ func TestLoadDataTrades(t *testing.T) {
p,
a,
false)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
}
func TestLoadDataInvalid(t *testing.T) {

View File

@@ -8,6 +8,8 @@ import (
"testing"
"time"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/thrasher-corp/gocryptotrader/backtester/common"
"github.com/thrasher-corp/gocryptotrader/config"
"github.com/thrasher-corp/gocryptotrader/currency"
@@ -85,14 +87,10 @@ func TestLoadDataCandles(t *testing.T) {
database.MigrationDir = filepath.Join("..", "..", "..", "..", "database", "migrations")
testhelpers.MigrationDir = filepath.Join("..", "..", "..", "..", "database", "migrations")
conn, err := testhelpers.ConnectToDatabase(&dbConfg)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
err = exchangeDB.InsertMany([]exchangeDB.Details{{Name: testExchange}})
if err != nil {
t.Fatal(err)
}
require.NoError(t, err)
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)
@@ -115,14 +113,10 @@ func TestLoadDataCandles(t *testing.T) {
},
}
_, err = gctkline.StoreInDatabase(data, true)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
_, err = LoadData(dStart, dEnd, gctkline.FifteenMin.Duration(), exch, common.DataCandle, p, a, false)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if err = conn.SQL.Close(); err != nil {
t.Error(err)
@@ -160,9 +154,7 @@ func TestLoadDataTrades(t *testing.T) {
database.MigrationDir = filepath.Join("..", "..", "..", "..", "database", "migrations")
testhelpers.MigrationDir = filepath.Join("..", "..", "..", "..", "database", "migrations")
conn, err := testhelpers.ConnectToDatabase(&dbConfg)
if !errors.Is(err, nil) {
t.Errorf("received '%v' expected '%v'", err, nil)
}
require.NoError(t, err)
err = exchangeDB.InsertMany([]exchangeDB.Details{{Name: testExchange}})
if err != nil {
@@ -183,14 +175,10 @@ func TestLoadDataTrades(t *testing.T) {
Side: gctorder.Buy.String(),
Timestamp: dInsert,
})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
require.NoError(t, err)
_, err = LoadData(dStart, dEnd, gctkline.FifteenMin.Duration(), exch, common.DataTrade, p, a, false)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if err = conn.SQL.Close(); err != nil {
t.Error(err)

View File

@@ -6,6 +6,8 @@ import (
"time"
"github.com/shopspring/decimal"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/thrasher-corp/gocryptotrader/backtester/data"
"github.com/thrasher-corp/gocryptotrader/backtester/eventtypes/event"
"github.com/thrasher-corp/gocryptotrader/backtester/eventtypes/kline"
@@ -49,9 +51,7 @@ func TestLoad(t *testing.T) {
},
}
err = d.Load()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
}
func TestHasDataAtTime(t *testing.T) {
@@ -65,21 +65,13 @@ func TestHasDataAtTime(t *testing.T) {
Base: &data.Base{},
}
has, err := d.HasDataAtTime(time.Now())
if !errors.Is(err, gctcommon.ErrNilPointer) {
t.Errorf("received: %v, expected: %v", err, gctcommon.ErrNilPointer)
}
if has {
t.Error("expected false")
}
require.ErrorIs(t, err, gctcommon.ErrNilPointer)
assert.False(t, has)
d.RangeHolder = &gctkline.IntervalRangeHolder{}
has, err = d.HasDataAtTime(time.Now())
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if has {
t.Error("expected false")
}
require.NoError(t, err)
assert.False(t, has)
d.Item = &gctkline.Item{
Exchange: exch,
@@ -97,52 +89,32 @@ func TestHasDataAtTime(t *testing.T) {
},
},
}
if err = d.Load(); err != nil {
t.Error(err)
}
require.NoError(t, d.Load(), "Load must not error")
has, err = d.HasDataAtTime(dStart)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if has {
t.Error("expected false")
}
require.NoError(t, err)
assert.False(t, has)
ranger, err := gctkline.CalculateCandleDateRanges(dStart, dEnd, gctkline.OneDay, 100000)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
require.NoError(t, err)
d.RangeHolder = ranger
err = d.RangeHolder.SetHasDataFromCandles(d.Item.Candles)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
require.NoError(t, err)
has, err = d.HasDataAtTime(dStart)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if !has {
t.Error("expected true")
}
require.NoError(t, err)
assert.True(t, has)
err = d.SetLive(true)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
require.NoError(t, err)
has, err = d.HasDataAtTime(time.Time{})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if has {
t.Error("expected false")
}
require.NoError(t, err)
assert.False(t, has)
has, err = d.HasDataAtTime(dStart)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if !has {
t.Error("expected true")
}
require.NoError(t, err)
assert.True(t, has)
}
func TestAppend(t *testing.T) {
@@ -192,14 +164,10 @@ func TestAppend(t *testing.T) {
item.Asset = a
err = d.AppendResults(&item)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
err = d.AppendResults(&item)
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
err = d.AppendResults(nil)
if !errors.Is(err, gctcommon.ErrNilPointer) {
@@ -216,12 +184,9 @@ func TestStreamOpen(t *testing.T) {
Base: &data.Base{},
}
bad, err := d.StreamOpen()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if len(bad) > 0 {
t.Error("expected no stream")
}
require.NoError(t, err)
assert.Empty(t, bad, "StreamOpen should return an empty slice when no data is set")
err = d.SetStream([]data.Event{
&kline.Kline{
Base: &event.Base{
@@ -238,20 +203,14 @@ func TestStreamOpen(t *testing.T) {
Volume: elite,
},
})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
require.NoError(t, err)
_, err = d.Next()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
require.NoError(t, err)
open, err := d.StreamOpen()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if len(open) == 0 {
t.Error("expected open")
}
require.NoError(t, err)
assert.NotEmpty(t, open, "open should not be empty")
}
func TestStreamVolume(t *testing.T) {
@@ -263,9 +222,8 @@ func TestStreamVolume(t *testing.T) {
Base: &data.Base{},
}
bad, err := d.StreamVol()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if len(bad) > 0 {
t.Error("expected no stream")
}
@@ -285,20 +243,14 @@ func TestStreamVolume(t *testing.T) {
Volume: elite,
},
})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
_, err = d.Next()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
vol, err := d.StreamVol()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if len(vol) == 0 {
t.Error("expected volume")
}
require.NoError(t, err)
assert.NotEmpty(t, vol, "StreamVol should return a non-empty slice")
}
func TestStreamClose(t *testing.T) {
@@ -310,9 +262,8 @@ func TestStreamClose(t *testing.T) {
Base: &data.Base{},
}
bad, err := d.StreamClose()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if len(bad) > 0 {
t.Error("expected no stream")
}
@@ -333,20 +284,14 @@ func TestStreamClose(t *testing.T) {
Volume: elite,
},
})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
_, err = d.Next()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
cl, err := d.StreamClose()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
if len(cl) == 0 {
t.Error("expected close")
}
require.NoError(t, err)
assert.NotEmpty(t, cl, "StreamClose should return a non-empty slice")
}
func TestStreamHigh(t *testing.T) {
@@ -358,9 +303,8 @@ func TestStreamHigh(t *testing.T) {
Base: &data.Base{},
}
bad, err := d.StreamHigh()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if len(bad) > 0 {
t.Error("expected no stream")
}
@@ -381,17 +325,14 @@ func TestStreamHigh(t *testing.T) {
Volume: elite,
},
})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
_, err = d.Next()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
high, err := d.StreamHigh()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if len(high) == 0 {
t.Error("expected high")
}
@@ -407,9 +348,8 @@ func TestStreamLow(t *testing.T) {
RangeHolder: &gctkline.IntervalRangeHolder{},
}
bad, err := d.StreamLow()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if len(bad) > 0 {
t.Error("expected no stream")
}
@@ -430,18 +370,14 @@ func TestStreamLow(t *testing.T) {
Volume: elite,
},
})
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
_, err = d.Next()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
low, err := d.StreamLow()
if !errors.Is(err, nil) {
t.Errorf("received: %v, expected: %v", err, nil)
}
assert.NoError(t, err)
if len(low) == 0 {
t.Error("expected low")
}