mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-07 11:32:20 +00:00
116 lines
2.4 KiB
Go
116 lines
2.4 KiB
Go
|
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
|
||
|
}
|