forked from thrasher-corp/gocryptotrader
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
6 changed files
with
247 additions
and
40 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
package subscription | ||
|
||
import ( | ||
"testing" | ||
|
||
"github.com/stretchr/testify/assert" | ||
"github.com/thrasher-corp/gocryptotrader/currency" | ||
"github.com/thrasher-corp/gocryptotrader/exchanges/asset" | ||
) | ||
|
||
func TestListStrings(t *testing.T) { | ||
l := List{ | ||
&Subscription{ | ||
Channel: TickerChannel, | ||
Asset: asset.Spot, | ||
Pairs: currency.Pairs{ethusdcPair, btcusdtPair}, | ||
}, | ||
&Subscription{ | ||
Channel: OrderbookChannel, | ||
Pairs: currency.Pairs{ethusdcPair}, | ||
}, | ||
} | ||
exp := []string{"orderbook ETH/USDC", "ticker spot ETH/USDC,BTC/USDT"} | ||
assert.ElementsMatch(t, exp, l.Strings(), "String must return correct sorted list") | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
package subscription | ||
|
||
import ( | ||
"testing" | ||
|
||
"github.com/stretchr/testify/assert" | ||
"github.com/stretchr/testify/require" | ||
"github.com/thrasher-corp/gocryptotrader/common" | ||
"github.com/thrasher-corp/gocryptotrader/exchanges/asset" | ||
) | ||
|
||
// TestNewStore exercises NewStore | ||
func TestNewStore(t *testing.T) { | ||
s := NewStore() | ||
require.IsType(t, &Store{}, s, "Must return a store ref") | ||
require.NotNil(t, s.m, "storage map must be initialised") | ||
} | ||
|
||
// TestNewStoreFromList exercises NewStoreFromList | ||
func TestNewStoreFromList(t *testing.T) { | ||
s, err := NewStoreFromList(List{}) | ||
assert.NoError(t, err, "Should not error on empty list") | ||
require.IsType(t, &Store{}, s, "Must return a store ref") | ||
l := List{ | ||
{Channel: OrderbookChannel}, | ||
{Channel: TickerChannel}, | ||
} | ||
s, err = NewStoreFromList(l) | ||
assert.NoError(t, err, "Should not error on empty list") | ||
assert.Len(t, s.m, 2, "Map should have 2 values") | ||
assert.NotNil(t, s.get(l[0]), "Should be able to get a list element") | ||
|
||
l = append(l, &Subscription{Channel: OrderbookChannel}) | ||
s, err = NewStoreFromList(l) | ||
assert.ErrorIs(t, err, ErrDuplicate, "Should error correctly on duplicates") | ||
} | ||
|
||
// TestAdd exercises Add and add methods | ||
func TestAdd(t *testing.T) { | ||
assert.ErrorIs(t, (*Store)(nil).Add(&Subscription{}), common.ErrNilPointer, "Should error nil pointer correctly") | ||
assert.ErrorIs(t, (&Store{}).Add(nil), common.ErrNilPointer, "Should error nil pointer correctly") | ||
assert.NoError(t, (&Store{}).Add(&Subscription{}), "Should with no map should not error or panic") | ||
s := NewStore() | ||
sub := &Subscription{Channel: TickerChannel} | ||
require.NoError(t, s.Add(sub), "Should not error on a standard add") | ||
assert.NotNil(t, s.get(sub), "Should have stored the sub") | ||
assert.ErrorIs(t, s.Add(sub), ErrDuplicate, "Should error on duplicates") | ||
assert.Same(t, sub.Key, sub, "Add should call EnsureKeyed") | ||
} | ||
|
||
// HobbitKey is just a fixture for testing MatchableKey | ||
type HobbitKey int | ||
|
||
// Match implements MatchableKey | ||
// Returns true if the key provided is twice as big as the actual sub key | ||
func (f HobbitKey) Match(key any) bool { | ||
i, ok := key.(HobbitKey) | ||
return ok && int(i)*2 == int(f) | ||
} | ||
|
||
// TestGet exercises Get and get methods | ||
func TestGet(t *testing.T) { | ||
assert.Nil(t, (*Store)(nil).Get(&Subscription{}), "Should return nil when called on nil") | ||
assert.Nil(t, (&Store{}).Get(&Subscription{}), "Should return nil when called with no subscription map") | ||
s := NewStore() | ||
exp := []*Subscription{ | ||
{Channel: OrderbookChannel}, | ||
{Channel: TickerChannel}, | ||
{Key: 42, Channel: CandlesChannel}, | ||
{Key: HobbitKey(24), Channel: CandlesChannel}, | ||
} | ||
for _, sub := range exp { | ||
require.NoError(t, s.Add(sub), "Adding subscription must not error)") | ||
} | ||
|
||
assert.Nil(t, s.Get(Subscription{Channel: OrderbookChannel, Asset: asset.Spot}), "Should return nil for an unknown sub") | ||
assert.Same(t, exp[0], s.Get(exp[0]), "Should return same pointer for known sub") | ||
assert.Same(t, exp[1], s.Get(Subscription{Channel: TickerChannel}), "Should return pointer for known sub passed-by-value") | ||
assert.Same(t, exp[2], s.Get(42), "Should return pointer for simple key lookup") | ||
assert.Same(t, exp[3], s.Get(HobbitKey(48)), "Should use MatchableKey interface to find subs") | ||
assert.Nil(t, s.Get(HobbitKey(24)), "Should use MatchableKey interface to find subs, therefore not find a HobbitKey 24") | ||
} | ||
|
||
// TestRemove exercises the Remove method | ||
func TestRemove(t *testing.T) { | ||
assert.ErrorIs(t, (*Store)(nil).Remove(&Subscription{}), common.ErrNilPointer, "Should error correctly when called on nil") | ||
assert.ErrorIs(t, (&Store{}).Remove(nil), common.ErrNilPointer, "Should error correctly when called passing nil") | ||
assert.ErrorIs(t, (&Store{}).Remove(&Subscription{}), ErrNotFound, "Should error correctly when called with no subscription map") | ||
s := NewStore() | ||
require.NoError(t, s.Add(&Subscription{Key: HobbitKey(24), Channel: CandlesChannel}), "Adding subscription must not error") | ||
assert.ErrorIs(t, s.Remove(HobbitKey(24)), ErrNotFound, "Should error correctly when called with a non-matching hobbitkey") | ||
assert.NoError(t, s.Remove(HobbitKey(48)), ErrNotFound, "Should Remove correctly when called matching hobbitkey") | ||
assert.ErrorIs(t, s.Remove(HobbitKey(48)), ErrNotFound, "Should error correctly when called twice on same key") | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters