Some checks are pending
docker-build-cometbft / vars (push) Waiting to run
docker-build-cometbft / build-images (amd64, ubuntu-24.04) (push) Blocked by required conditions
docker-build-cometbft / build-images (arm64, ubuntu-24.04-arm) (push) Blocked by required conditions
docker-build-cometbft / merge-images (push) Blocked by required conditions
docker-build-e2e-node / vars (push) Waiting to run
docker-build-e2e-node / build-images (amd64, ubuntu-24.04) (push) Blocked by required conditions
docker-build-e2e-node / build-images (arm64, ubuntu-24.04-arm) (push) Blocked by required conditions
docker-build-e2e-node / merge-images (push) Blocked by required conditions
149 lines
3.2 KiB
Go
149 lines
3.2 KiB
Go
package mempool
|
|
|
|
import (
|
|
"sync/atomic"
|
|
"testing"
|
|
|
|
"github.com/cometbft/cometbft/abci/example/kvstore"
|
|
"github.com/cometbft/cometbft/proxy"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func BenchmarkReap(b *testing.B) {
|
|
app := kvstore.NewInMemoryApplication()
|
|
cc := proxy.NewLocalClientCreator(app)
|
|
mp, cleanup := newMempoolWithApp(cc)
|
|
defer cleanup()
|
|
|
|
mp.config.Size = 100_000_000 // so that the mempool never saturates
|
|
addTxs(b, mp, 0, 10000)
|
|
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
mp.ReapMaxBytesMaxGas(100_000_000, -1)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCheckTx(b *testing.B) {
|
|
app := kvstore.NewInMemoryApplication()
|
|
cc := proxy.NewLocalClientCreator(app)
|
|
mp, cleanup := newMempoolWithApp(cc)
|
|
defer cleanup()
|
|
|
|
mp.config.Size = 100_000_000
|
|
b.ResetTimer()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
b.StopTimer()
|
|
tx := kvstore.NewTxFromID(i)
|
|
b.StartTimer()
|
|
|
|
err := mp.CheckTx(tx, nil, TxInfo{})
|
|
require.NoError(b, err, i)
|
|
}
|
|
}
|
|
|
|
func BenchmarkParallelCheckTx(b *testing.B) {
|
|
app := kvstore.NewInMemoryApplication()
|
|
cc := proxy.NewLocalClientCreator(app)
|
|
mp, cleanup := newMempoolWithApp(cc)
|
|
defer cleanup()
|
|
|
|
mp.config.Size = 100_000_000
|
|
var txcnt uint64
|
|
next := func() uint64 {
|
|
return atomic.AddUint64(&txcnt, 1)
|
|
}
|
|
|
|
b.ResetTimer()
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
for pb.Next() {
|
|
tx := kvstore.NewTxFromID(int(next()))
|
|
err := mp.CheckTx(tx, nil, TxInfo{})
|
|
require.NoError(b, err, tx)
|
|
}
|
|
})
|
|
}
|
|
|
|
func BenchmarkCheckDuplicateTx(b *testing.B) {
|
|
app := kvstore.NewInMemoryApplication()
|
|
cc := proxy.NewLocalClientCreator(app)
|
|
mp, cleanup := newMempoolWithApp(cc)
|
|
defer cleanup()
|
|
|
|
mp.config.Size = 2
|
|
|
|
tx := kvstore.NewTxFromID(1)
|
|
if err := mp.CheckTx(tx, nil, TxInfo{}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
err := mp.FlushAppConn()
|
|
require.NoError(b, err)
|
|
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
err := mp.CheckTx(tx, nil, TxInfo{})
|
|
require.ErrorAs(b, err, &ErrTxInCache, "tx should be duplicate")
|
|
}
|
|
}
|
|
|
|
func BenchmarkUpdate(b *testing.B) {
|
|
app := kvstore.NewInMemoryApplication()
|
|
cc := proxy.NewLocalClientCreator(app)
|
|
mp, cleanup := newMempoolWithApp(cc)
|
|
defer cleanup()
|
|
|
|
numTxs := 1000
|
|
b.ResetTimer()
|
|
for i := 1; i <= b.N; i++ {
|
|
b.StopTimer()
|
|
txs := addTxs(b, mp, i*numTxs, numTxs)
|
|
require.Equal(b, len(txs), mp.Size(), len(txs))
|
|
b.StartTimer()
|
|
|
|
doUpdate(b, mp, int64(i), txs)
|
|
require.Zero(b, mp.Size())
|
|
}
|
|
}
|
|
|
|
func BenchmarkUpdateAndRecheck(b *testing.B) {
|
|
app := kvstore.NewInMemoryApplication()
|
|
cc := proxy.NewLocalClientCreator(app)
|
|
mp, cleanup := newMempoolWithApp(cc)
|
|
defer cleanup()
|
|
|
|
numTxs := 1000
|
|
b.ResetTimer()
|
|
for i := 1; i <= b.N; i++ {
|
|
b.StopTimer()
|
|
mp.Flush()
|
|
txs := addTxs(b, mp, i*numTxs, numTxs)
|
|
require.Equal(b, len(txs), mp.Size(), len(txs))
|
|
b.StartTimer()
|
|
|
|
// Update a part of txs and recheck the rest.
|
|
doUpdate(b, mp, int64(i), txs[:numTxs/2])
|
|
}
|
|
|
|
}
|
|
|
|
func BenchmarkUpdateRemoteClient(b *testing.B) {
|
|
mp, cleanup := newMempoolWithAsyncConnection(b)
|
|
defer cleanup()
|
|
|
|
b.ResetTimer()
|
|
for i := 1; i <= b.N; i++ {
|
|
b.StopTimer()
|
|
tx := kvstore.NewTxFromID(i)
|
|
err := mp.CheckTx(tx, nil, TxInfo{})
|
|
require.NoError(b, err)
|
|
err = mp.FlushAppConn()
|
|
require.NoError(b, err)
|
|
require.Equal(b, 1, mp.Size())
|
|
b.StartTimer()
|
|
|
|
txs := mp.ReapMaxTxs(mp.Size())
|
|
doUpdate(b, mp, int64(i), txs)
|
|
}
|
|
|
|
}
|