mirror of
https://github.com/status-im/status-go.git
synced 2025-01-18 18:55:47 +00:00
bd816f1e29
chore(wallet)_: split getWalletTokenBalances into multiple functions Removed some unused balances methods from wallet API chore(wallet)_: refactored FetchOrGetWalletTokenBalances - getWalletTokenBalances only returns cached ones - update of balances is done in a separate method chore(wallet)_: fix isVisible in getWalletTokenBalances is overwritten It is overwritten and in some cases its value is desrespected chore(wallet)_: simplify getWalletTokenBalance even further chore(wallet)_: remove accountsDB from wallet.Reader Call GetTestNetworkEnabled from NetworkManager instead chore(wallet)_: remove rpc.Client from wallet.Reader. Added GetActiveNetworks() method for NetworkManager Removed adding native tokens from networks, as this is done already in NetworkManager chore(wallet)_: moved Persistence to token package As it works with token_balances table, moved Persistence to token package. Fixed TokenManager's Mark/Get previously owned tokens to use persistence storage instead of direct SQL calls. Introduced StorageToken that aggregates Token type, because when Persistence moved to token package, names clash test(wallet)_: tests for wallet.Reader.FetchorGetCachedBalances
123 lines
2.7 KiB
Go
123 lines
2.7 KiB
Go
package testutils
|
|
|
|
import (
|
|
"reflect"
|
|
"sort"
|
|
|
|
"github.com/golang/mock/gomock"
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
)
|
|
|
|
const EthSymbol = "ETH"
|
|
const SntSymbol = "SNT"
|
|
const DaiSymbol = "DAI"
|
|
|
|
func SliceContains[T comparable](slice []T, value T) bool {
|
|
for _, v := range slice {
|
|
if v == value {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
func StructExistsInSlice[T any](target T, slice []T) bool {
|
|
for _, item := range slice {
|
|
if reflect.DeepEqual(target, item) {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func Filter[T any](ss []T, test func(T) bool) (ret []T) {
|
|
for _, s := range ss {
|
|
if test(s) {
|
|
ret = append(ret, s)
|
|
}
|
|
}
|
|
return
|
|
}
|
|
|
|
// AddressSliceMatcher is a custom matcher for comparing common.Address slices regardless of order.
|
|
type AddressSliceMatcher struct {
|
|
expected []common.Address
|
|
}
|
|
|
|
func NewAddressSliceMatcher(expected []common.Address) gomock.Matcher {
|
|
return &AddressSliceMatcher{expected: expected}
|
|
}
|
|
|
|
func (m *AddressSliceMatcher) Matches(x interface{}) bool {
|
|
actual, ok := x.([]common.Address)
|
|
if !ok {
|
|
return false
|
|
}
|
|
|
|
if len(m.expected) != len(actual) {
|
|
return false
|
|
}
|
|
|
|
// Create copies of the slices to sort them
|
|
expectedCopy := make([]common.Address, len(m.expected))
|
|
actualCopy := make([]common.Address, len(actual))
|
|
copy(expectedCopy, m.expected)
|
|
copy(actualCopy, actual)
|
|
|
|
sort.Slice(expectedCopy, func(i, j int) bool { return expectedCopy[i].Hex() < expectedCopy[j].Hex() })
|
|
sort.Slice(actualCopy, func(i, j int) bool { return actualCopy[i].Hex() < actualCopy[j].Hex() })
|
|
|
|
for i := range expectedCopy {
|
|
if expectedCopy[i] != actualCopy[i] {
|
|
return false
|
|
}
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
func (m *AddressSliceMatcher) String() string {
|
|
return "matches Address slice regardless of order"
|
|
}
|
|
|
|
// Uint64SliceMatcher is a custom matcher for comparing uint64 slices regardless of order.
|
|
type Uint64SliceMatcher struct {
|
|
expected []uint64
|
|
}
|
|
|
|
func NewUint64SliceMatcher(expected []uint64) gomock.Matcher {
|
|
return &Uint64SliceMatcher{expected: expected}
|
|
}
|
|
|
|
func (m *Uint64SliceMatcher) Matches(x interface{}) bool {
|
|
actual, ok := x.([]uint64)
|
|
if !ok {
|
|
return false
|
|
}
|
|
|
|
if len(m.expected) != len(actual) {
|
|
return false
|
|
}
|
|
|
|
// Create copies of the slices to sort them
|
|
expectedCopy := make([]uint64, len(m.expected))
|
|
actualCopy := make([]uint64, len(actual))
|
|
copy(expectedCopy, m.expected)
|
|
copy(actualCopy, actual)
|
|
|
|
sort.Slice(expectedCopy, func(i, j int) bool { return expectedCopy[i] < expectedCopy[j] })
|
|
sort.Slice(actualCopy, func(i, j int) bool { return actualCopy[i] < actualCopy[j] })
|
|
|
|
for i := range expectedCopy {
|
|
if expectedCopy[i] != actualCopy[i] {
|
|
return false
|
|
}
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
func (m *Uint64SliceMatcher) String() string {
|
|
return "matches uint64 slice regardless of order"
|
|
}
|