erigon-pulse/state/aggregator_bench_test.go

116 lines
2.4 KiB
Go
Raw Normal View History

package state
import (
"context"
"math/rand"
"os"
"testing"
"github.com/ledgerwatch/log/v3"
"github.com/stretchr/testify/require"
"github.com/ledgerwatch/erigon-lib/common/length"
"github.com/ledgerwatch/erigon-lib/kv"
"github.com/ledgerwatch/erigon-lib/kv/mdbx"
)
func testDbAndAggregatorBench(b *testing.B, prefixLen int, aggStep uint64) (string, kv.RwDB, *Aggregator) {
b.Helper()
path := b.TempDir()
b.Cleanup(func() { os.RemoveAll(path) })
logger := log.New()
db := mdbx.NewMDBX(logger).Path(path).WithTableCfg(func(defaultBuckets kv.TableCfg) kv.TableCfg {
return kv.ChaindataTablesCfg
}).MustOpen()
b.Cleanup(db.Close)
agg, err := NewAggregator(path, path, aggStep)
require.NoError(b, err)
b.Cleanup(agg.Close)
return path, db, agg
}
func BenchmarkAggregator_Processing(b *testing.B) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
//keys := queueKeys(ctx, 42, length.Addr)
longKeys := queueKeys(ctx, 64, length.Addr+length.Hash)
vals := queueKeys(ctx, 53, length.Hash)
aggStep := uint64(100_000)
_, db, agg := testDbAndAggregatorBench(b, length.Addr, aggStep)
tx, err := db.BeginRw(ctx)
require.NoError(b, err)
defer func() {
if tx != nil {
tx.Rollback()
}
if agg != nil {
agg.Close()
}
}()
commit := func(txN uint64) (err error) {
err = tx.Commit()
require.NoError(b, err)
if err != nil {
return err
}
tx = nil
tx, err = db.BeginRw(ctx)
require.NoError(b, err)
if err != nil {
return err
}
agg.SetTx(tx)
return nil
}
agg.SetCommitFn(commit)
agg.SetTx(tx)
defer agg.StartWrites().FinishWrites()
require.NoError(b, err)
agg.StartWrites()
defer agg.FinishWrites()
b.ReportAllocs()
b.ResetTimer()
//keyList := make([][]byte, 20000)
for i := 0; i < b.N; i++ {
//var key []byte
//if i >= len(keyList) {
// pi := i % (len(keyList))
// key = keyList[pi]
//} else {
// key = <-longKeys
// keyList[i] = key
//}
key := <-longKeys
val := <-vals
agg.SetTxNum(uint64(i))
err := agg.WriteAccountStorage(key[:length.Addr], key[length.Addr:], val)
require.NoError(b, err)
err = agg.FinishTx()
require.NoError(b, err)
}
}
func queueKeys(ctx context.Context, seed, ofSize uint64) <-chan []byte {
rnd := rand.New(rand.NewSource(int64(seed)))
keys := make(chan []byte, 1)
go func() {
for {
if ctx.Err() != nil {
break
}
bb := make([]byte, ofSize)
rnd.Read(bb)
keys <- bb
}
close(keys)
}()
return keys
}