erigon-pulse/state/locality_index_test.go

85 lines
2.4 KiB
Go
Raw Normal View History

package state
import (
"context"
"encoding/binary"
"math"
"testing"
"github.com/ledgerwatch/erigon-lib/recsplit"
"github.com/stretchr/testify/require"
)
func TestLocality(t *testing.T) {
ctx, require := context.Background(), require.New(t)
const Module uint64 = 31
path, db, ii, txs := filledInvIndexOfSize(t, 300, 4, Module)
mergeInverted(t, db, ii, txs)
li, _ := NewLocalityIndex(path, path, 4, "inv")
defer li.Close()
err := li.BuildMissedIndices(ctx, ii)
require.NoError(err)
t.Run("locality iterator", func(t *testing.T) {
ic := ii.MakeContext()
defer ic.Close()
it := ic.iterateKeysLocality(math.MaxUint64)
require.True(it.HasNext())
key, bitmap := it.Next()
require.Equal(uint64(2), binary.BigEndian.Uint64(key))
require.Equal([]uint64{0, 1}, bitmap)
require.True(it.HasNext())
key, bitmap = it.Next()
require.Equal(uint64(3), binary.BigEndian.Uint64(key))
require.Equal([]uint64{0, 1}, bitmap)
var last []byte
for it.HasNext() {
key, _ = it.Next()
last = key
}
require.Equal(Module, binary.BigEndian.Uint64(last))
})
files, err := li.buildFiles(ctx, ii, ii.endTxNumMinimax()/ii.aggregationStep)
require.NoError(err)
defer files.Close()
t.Run("locality index: get full bitamp", func(t *testing.T) {
res, err := files.bm.At(0)
require.NoError(err)
require.Equal([]uint64{0, 1}, res)
res, err = files.bm.At(1)
require.NoError(err)
require.Equal([]uint64{0, 1}, res)
res, err = files.bm.At(32) //too big, must error
require.Error(err)
require.Empty(res)
})
t.Run("locality index: search from given position", func(t *testing.T) {
fst, snd, ok1, ok2, err := files.bm.First2At(0, 1)
require.NoError(err)
require.True(ok1)
require.False(ok2)
require.Equal(uint64(1), fst)
require.Zero(snd)
})
t.Run("locality index: search from given position in future", func(t *testing.T) {
fst, snd, ok1, ok2, err := files.bm.First2At(0, 2)
require.NoError(err)
require.False(ok1)
require.False(ok2)
require.Zero(fst)
require.Zero(snd)
})
t.Run("locality index: lookup", func(t *testing.T) {
var k [8]byte
binary.BigEndian.PutUint64(k[:], 1)
v1, v2, from, ok1, ok2 := li.lookupIdxFiles(recsplit.NewIndexReader(files.index), files.bm, li.file, k[:], 1*li.aggregationStep*StepsInBiggestFile)
require.True(ok1)
require.False(ok2)
require.Equal(uint64(1*StepsInBiggestFile), v1)
require.Equal(uint64(0*StepsInBiggestFile), v2)
require.Equal(2*li.aggregationStep*StepsInBiggestFile, from)
})
}