mirror of
https://github.com/status-im/status-go.git
synced 2025-01-22 20:54:23 +00:00
9d6577049f
* feat(wallet): implement balance history based on fetched transfers * Added vendor 'ttlcache'
289 lines
5.2 KiB
Go
289 lines
5.2 KiB
Go
package history
|
|
|
|
import (
|
|
"math/big"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
|
)
|
|
|
|
func Test_entriesToDataPoints(t *testing.T) {
|
|
type args struct {
|
|
chainIDs []uint64
|
|
data []*entry
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want []*DataPoint
|
|
wantErr bool
|
|
}{
|
|
{
|
|
name: "zeroAllChainsSameTimestamp",
|
|
args: args{
|
|
chainIDs: []uint64{1, 2},
|
|
data: []*entry{
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(0),
|
|
timestamp: 1,
|
|
block: big.NewInt(1),
|
|
},
|
|
{
|
|
chainID: 2,
|
|
balance: big.NewInt(0),
|
|
timestamp: 1,
|
|
block: big.NewInt(5),
|
|
},
|
|
},
|
|
},
|
|
want: []*DataPoint{
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(0)),
|
|
Timestamp: 1,
|
|
},
|
|
},
|
|
wantErr: false,
|
|
},
|
|
{
|
|
name: "oneZeroAllChainsDifferentTimestamp",
|
|
args: args{
|
|
chainIDs: []uint64{1, 2},
|
|
data: []*entry{
|
|
{
|
|
chainID: 2,
|
|
balance: big.NewInt(0),
|
|
timestamp: 1,
|
|
block: big.NewInt(1),
|
|
},
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(2),
|
|
timestamp: 2,
|
|
block: big.NewInt(2),
|
|
},
|
|
},
|
|
},
|
|
want: []*DataPoint{
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(0)),
|
|
Timestamp: 1,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(2)),
|
|
Timestamp: 2,
|
|
},
|
|
},
|
|
wantErr: false,
|
|
},
|
|
{
|
|
name: "nonZeroAllChainsDifferentTimestamp",
|
|
args: args{
|
|
chainIDs: []uint64{1, 2},
|
|
data: []*entry{
|
|
{
|
|
chainID: 2,
|
|
balance: big.NewInt(1),
|
|
timestamp: 1,
|
|
},
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(2),
|
|
timestamp: 2,
|
|
},
|
|
},
|
|
},
|
|
want: []*DataPoint{
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(1)),
|
|
Timestamp: 1,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(2)),
|
|
Timestamp: 2,
|
|
},
|
|
},
|
|
wantErr: false,
|
|
},
|
|
{
|
|
name: "sameChainDifferentTimestamp",
|
|
args: args{
|
|
chainIDs: []uint64{1, 2},
|
|
data: []*entry{
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(1),
|
|
timestamp: 1,
|
|
block: big.NewInt(1),
|
|
},
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(2),
|
|
timestamp: 2,
|
|
block: big.NewInt(2),
|
|
},
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(0),
|
|
timestamp: 3,
|
|
},
|
|
},
|
|
},
|
|
want: []*DataPoint{
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(1)),
|
|
Timestamp: 1,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(2)),
|
|
Timestamp: 2,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(0)),
|
|
Timestamp: 3,
|
|
},
|
|
},
|
|
wantErr: false,
|
|
},
|
|
{
|
|
name: "sameChainDifferentTimestampOtherChainsEmpty",
|
|
args: args{
|
|
chainIDs: []uint64{1, 2},
|
|
data: []*entry{
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(1),
|
|
timestamp: 1,
|
|
block: big.NewInt(1),
|
|
},
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(2),
|
|
timestamp: 2,
|
|
block: big.NewInt(2),
|
|
},
|
|
{
|
|
chainID: 2,
|
|
balance: big.NewInt(0),
|
|
timestamp: 2,
|
|
block: big.NewInt(2),
|
|
},
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(2),
|
|
timestamp: 3,
|
|
},
|
|
},
|
|
},
|
|
want: []*DataPoint{
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(1)),
|
|
Timestamp: 1,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(2)),
|
|
Timestamp: 2,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(2)),
|
|
Timestamp: 3,
|
|
},
|
|
},
|
|
wantErr: false,
|
|
},
|
|
{
|
|
name: "onlyEdgePointsOnManyChainsWithPadding",
|
|
args: args{
|
|
chainIDs: []uint64{1, 2, 3},
|
|
data: []*entry{
|
|
// Left edge - same timestamp
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(1),
|
|
timestamp: 1,
|
|
},
|
|
{
|
|
chainID: 2,
|
|
balance: big.NewInt(2),
|
|
timestamp: 1,
|
|
},
|
|
{
|
|
chainID: 3,
|
|
balance: big.NewInt(3),
|
|
timestamp: 1,
|
|
},
|
|
// Padding
|
|
{
|
|
chainID: 0,
|
|
balance: big.NewInt(6),
|
|
timestamp: 2,
|
|
},
|
|
{
|
|
chainID: 0,
|
|
balance: big.NewInt(6),
|
|
timestamp: 3,
|
|
},
|
|
{
|
|
chainID: 0,
|
|
balance: big.NewInt(6),
|
|
timestamp: 4,
|
|
},
|
|
// Right edge - same timestamp
|
|
{
|
|
chainID: 1,
|
|
balance: big.NewInt(1),
|
|
timestamp: 5,
|
|
},
|
|
{
|
|
chainID: 2,
|
|
balance: big.NewInt(2),
|
|
timestamp: 5,
|
|
},
|
|
{
|
|
chainID: 3,
|
|
balance: big.NewInt(3),
|
|
timestamp: 5,
|
|
},
|
|
},
|
|
},
|
|
want: []*DataPoint{
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(6)),
|
|
Timestamp: 1,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(6)),
|
|
Timestamp: 2,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(6)),
|
|
Timestamp: 3,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(6)),
|
|
Timestamp: 4,
|
|
},
|
|
{
|
|
Balance: (*hexutil.Big)(big.NewInt(6)),
|
|
Timestamp: 5,
|
|
},
|
|
},
|
|
wantErr: false,
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
got, err := entriesToDataPoints(tt.args.chainIDs, tt.args.data)
|
|
if (err != nil) != tt.wantErr {
|
|
t.Errorf("entriesToDataPoints() error = %v, wantErr %v", err, tt.wantErr)
|
|
return
|
|
}
|
|
if !reflect.DeepEqual(got, tt.want) {
|
|
t.Errorf("entriesToDataPoints() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|