Merge PR #2653: Add benchmark for get and set account
This commit is contained in:
parent
8e328c8706
commit
b6443e9496
|
@ -45,7 +45,7 @@ IMPROVEMENTS
|
||||||
- \#1924 [x/mock/simulation] Use a transition matrix for block size
|
- \#1924 [x/mock/simulation] Use a transition matrix for block size
|
||||||
- \#2660 [x/mock/simulation] Staking transactions get tested far more frequently
|
- \#2660 [x/mock/simulation] Staking transactions get tested far more frequently
|
||||||
- #2610 [x/stake] Block redelegation to and from the same validator
|
- #2610 [x/stake] Block redelegation to and from the same validator
|
||||||
|
- #2652 [x/auth] Add benchmark for get and set account
|
||||||
|
|
||||||
* Tendermint
|
* Tendermint
|
||||||
|
|
||||||
|
|
|
@ -3,15 +3,13 @@ package auth
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
|
||||||
|
|
||||||
abci "github.com/tendermint/tendermint/abci/types"
|
|
||||||
dbm "github.com/tendermint/tendermint/libs/db"
|
|
||||||
"github.com/tendermint/tendermint/libs/log"
|
|
||||||
|
|
||||||
codec "github.com/cosmos/cosmos-sdk/codec"
|
codec "github.com/cosmos/cosmos-sdk/codec"
|
||||||
"github.com/cosmos/cosmos-sdk/store"
|
"github.com/cosmos/cosmos-sdk/store"
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
abci "github.com/tendermint/tendermint/abci/types"
|
||||||
|
dbm "github.com/tendermint/tendermint/libs/db"
|
||||||
|
"github.com/tendermint/tendermint/libs/log"
|
||||||
)
|
)
|
||||||
|
|
||||||
func setupMultiStore() (sdk.MultiStore, *sdk.KVStoreKey, *sdk.KVStoreKey) {
|
func setupMultiStore() (sdk.MultiStore, *sdk.KVStoreKey, *sdk.KVStoreKey) {
|
||||||
|
@ -115,9 +113,92 @@ func BenchmarkAccountMapperGetAccountFound(b *testing.B) {
|
||||||
acc := mapper.NewAccountWithAddress(ctx, addr)
|
acc := mapper.NewAccountWithAddress(ctx, addr)
|
||||||
mapper.SetAccount(ctx, acc)
|
mapper.SetAccount(ctx, acc)
|
||||||
}
|
}
|
||||||
|
|
||||||
b.ResetTimer()
|
b.ResetTimer()
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
arr := []byte{byte((i & 0xFF0000) >> 16), byte((i & 0xFF00) >> 8), byte(i & 0xFF)}
|
arr := []byte{byte((i & 0xFF0000) >> 16), byte((i & 0xFF00) >> 8), byte(i & 0xFF)}
|
||||||
mapper.GetAccount(ctx, sdk.AccAddress(arr))
|
mapper.GetAccount(ctx, sdk.AccAddress(arr))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func BenchmarkAccountMapperGetAccountFoundWithCoins(b *testing.B) {
|
||||||
|
ms, capKey, _ := setupMultiStore()
|
||||||
|
cdc := codec.New()
|
||||||
|
RegisterBaseAccount(cdc)
|
||||||
|
|
||||||
|
// make context and mapper
|
||||||
|
ctx := sdk.NewContext(ms, abci.Header{}, false, log.NewNopLogger())
|
||||||
|
mapper := NewAccountKeeper(cdc, capKey, ProtoBaseAccount)
|
||||||
|
|
||||||
|
coins := sdk.Coins{
|
||||||
|
sdk.NewCoin("LTC", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("BTC", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("ETH", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("XRP", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("BCH", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("EOS", sdk.NewInt(1000)),
|
||||||
|
}
|
||||||
|
|
||||||
|
// assumes b.N < 2**24
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
arr := []byte{byte((i & 0xFF0000) >> 16), byte((i & 0xFF00) >> 8), byte(i & 0xFF)}
|
||||||
|
addr := sdk.AccAddress(arr)
|
||||||
|
acc := mapper.NewAccountWithAddress(ctx, addr)
|
||||||
|
acc.SetCoins(coins)
|
||||||
|
mapper.SetAccount(ctx, acc)
|
||||||
|
}
|
||||||
|
|
||||||
|
b.ResetTimer()
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
arr := []byte{byte((i & 0xFF0000) >> 16), byte((i & 0xFF00) >> 8), byte(i & 0xFF)}
|
||||||
|
mapper.GetAccount(ctx, sdk.AccAddress(arr))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func BenchmarkAccountMapperSetAccount(b *testing.B) {
|
||||||
|
ms, capKey, _ := setupMultiStore()
|
||||||
|
cdc := codec.New()
|
||||||
|
RegisterBaseAccount(cdc)
|
||||||
|
|
||||||
|
// make context and mapper
|
||||||
|
ctx := sdk.NewContext(ms, abci.Header{}, false, log.NewNopLogger())
|
||||||
|
mapper := NewAccountKeeper(cdc, capKey, ProtoBaseAccount)
|
||||||
|
|
||||||
|
b.ResetTimer()
|
||||||
|
// assumes b.N < 2**24
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
arr := []byte{byte((i & 0xFF0000) >> 16), byte((i & 0xFF00) >> 8), byte(i & 0xFF)}
|
||||||
|
addr := sdk.AccAddress(arr)
|
||||||
|
acc := mapper.NewAccountWithAddress(ctx, addr)
|
||||||
|
mapper.SetAccount(ctx, acc)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func BenchmarkAccountMapperSetAccountWithCoins(b *testing.B) {
|
||||||
|
ms, capKey, _ := setupMultiStore()
|
||||||
|
cdc := codec.New()
|
||||||
|
RegisterBaseAccount(cdc)
|
||||||
|
|
||||||
|
// make context and mapper
|
||||||
|
ctx := sdk.NewContext(ms, abci.Header{}, false, log.NewNopLogger())
|
||||||
|
mapper := NewAccountKeeper(cdc, capKey, ProtoBaseAccount)
|
||||||
|
|
||||||
|
coins := sdk.Coins{
|
||||||
|
sdk.NewCoin("LTC", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("BTC", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("ETH", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("XRP", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("BCH", sdk.NewInt(1000)),
|
||||||
|
sdk.NewCoin("EOS", sdk.NewInt(1000)),
|
||||||
|
}
|
||||||
|
|
||||||
|
b.ResetTimer()
|
||||||
|
// assumes b.N < 2**24
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
arr := []byte{byte((i & 0xFF0000) >> 16), byte((i & 0xFF00) >> 8), byte(i & 0xFF)}
|
||||||
|
addr := sdk.AccAddress(arr)
|
||||||
|
acc := mapper.NewAccountWithAddress(ctx, addr)
|
||||||
|
acc.SetCoins(coins)
|
||||||
|
mapper.SetAccount(ctx, acc)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue