erigon-pulse/ethdb/prune/storage_mode_test.go

76 lines
1.7 KiB
Go

package prune
import (
"math/rand"
"strconv"
"testing"
"github.com/ledgerwatch/erigon-lib/kv/memdb"
"github.com/ledgerwatch/erigon/common/math"
"github.com/stretchr/testify/assert"
)
func TestSetStorageModeIfNotExist(t *testing.T) {
_, tx := memdb.NewTestTx(t)
prune, err := Get(tx)
assert.NoError(t, err)
assert.Equal(t, Mode{true, Distance(math.MaxUint64), Distance(math.MaxUint64),
Distance(math.MaxUint64), Distance(math.MaxUint64), Experiments{TEVM: false}}, prune)
err = SetIfNotExist(tx, Mode{true, Distance(1), Distance(2),
Before(3), Before(4), Experiments{TEVM: false}})
assert.NoError(t, err)
prune, err = Get(tx)
assert.NoError(t, err)
assert.Equal(t, Mode{true, Distance(1), Distance(2),
Before(3), Before(4), Experiments{TEVM: false}}, prune)
}
var distanceTests = []struct {
stageHead uint64
pruneTo uint64
expected uint64
}{
{3_000_000, 1, 2_999_999},
{3_000_000, 4_000_000, 0},
{3_000_000, math.MaxUint64, 0},
{3_000_000, 1_000_000, 2_000_000},
}
func TestDistancePruneTo(t *testing.T) {
for _, tt := range distanceTests {
t.Run(strconv.FormatUint(tt.pruneTo, 10), func(t *testing.T) {
stageHead := tt.stageHead
d := Distance(tt.pruneTo)
pruneTo := d.PruneTo(stageHead)
if pruneTo != tt.expected {
t.Errorf("got %d, want %d", pruneTo, tt.expected)
}
})
}
}
var beforeTests = []struct {
pruneTo uint64
expected uint64
}{
{0, 0},
{1_000_000, 999_999},
}
func TestBeforePruneTo(t *testing.T) {
for _, tt := range beforeTests {
t.Run(strconv.FormatUint(tt.pruneTo, 10), func(t *testing.T) {
stageHead := uint64(rand.Int63n(10_000_000))
b := Before(tt.pruneTo)
pruneTo := b.PruneTo(stageHead)
if pruneTo != tt.expected {
t.Errorf("got %d, want %d", pruneTo, tt.expected)
}
})
}
}