erigon-pulse/turbo/snapshotsync/block_snapshots_test.go

187 lines
5.4 KiB
Go
Raw Normal View History

2021-11-16 08:33:41 +00:00
package snapshotsync
import (
"context"
"path/filepath"
2021-11-16 08:33:41 +00:00
"testing"
"github.com/ledgerwatch/erigon-lib/compress"
"github.com/ledgerwatch/erigon-lib/recsplit"
2021-12-21 14:12:32 +00:00
"github.com/ledgerwatch/erigon/common/math"
"github.com/ledgerwatch/erigon/eth/ethconfig"
"github.com/ledgerwatch/erigon/params/networkname"
"github.com/ledgerwatch/erigon/turbo/snapshotsync/snapshothashes"
2021-11-16 08:33:41 +00:00
"github.com/stretchr/testify/require"
)
2022-02-22 01:55:24 +00:00
func createTestSegmentFile(t *testing.T, from, to uint64, name SnapshotType, dir string) {
c, err := compress.NewCompressor(context.Background(), "test", filepath.Join(dir, SegmentFileName(from, to, name)), dir, 100, 1)
require.NoError(t, err)
defer c.Close()
err = c.AddWord([]byte{1})
require.NoError(t, err)
err = c.Compress()
require.NoError(t, err)
idx, err := recsplit.NewRecSplit(recsplit.RecSplitArgs{
KeyCount: 1,
BucketSize: 10,
TmpDir: dir,
IndexFile: filepath.Join(dir, IdxFileName(from, to, name)),
LeafSize: 8,
})
require.NoError(t, err)
err = idx.AddKey([]byte{1}, 0)
require.NoError(t, err)
err = idx.Build()
require.NoError(t, err)
if name == Transactions {
2021-11-16 08:33:41 +00:00
idx, err := recsplit.NewRecSplit(recsplit.RecSplitArgs{
KeyCount: 1,
BucketSize: 10,
TmpDir: dir,
2022-02-22 01:55:24 +00:00
IndexFile: filepath.Join(dir, IdxFileName(from, to, Transactions2Block)),
2021-11-16 08:33:41 +00:00
LeafSize: 8,
})
2022-02-22 01:55:24 +00:00
require.NoError(t, err)
2021-11-16 08:33:41 +00:00
err = idx.AddKey([]byte{1}, 0)
2022-02-22 01:55:24 +00:00
require.NoError(t, err)
2021-11-16 08:33:41 +00:00
err = idx.Build()
2022-02-22 01:55:24 +00:00
require.NoError(t, err)
}
}
func TestMerge(t *testing.T) {
dir, require := t.TempDir(), require.New(t)
createFile := func(from, to uint64) {
for _, snT := range AllSnapshotTypes {
createTestSegmentFile(t, from, to, snT, dir)
}
}
N := uint64(15)
createFile(0, 500_000)
for i := uint64(500_000); i < 500_000+N*50_000; i += 50_000 {
createFile(i, i+50_000)
2021-11-16 08:33:41 +00:00
}
2022-02-22 01:55:24 +00:00
cfg := ethconfig.Snapshot{Enabled: true}
s := NewRoSnapshots(cfg, dir)
defer s.Close()
require.NoError(s.ReopenSegments())
err := findAndMergeBlockSegments(context.Background(), s, dir)
require.NoError(err)
require.NoError(s.ReopenSegments())
expectedFileName := SegmentFileName(500_000, 1_000_000, Transactions)
d, err := compress.NewDecompressor(filepath.Join(dir, expectedFileName))
require.NoError(err)
defer d.Close()
a := d.Count()
require.Equal(10, a)
err = findAndMergeBlockSegments(context.Background(), s, dir)
require.NoError(err)
require.NoError(s.ReopenSegments())
expectedFileName = SegmentFileName(1_000_000, 1_250_000, Transactions)
d, err = compress.NewDecompressor(filepath.Join(dir, expectedFileName))
require.NoError(err)
defer d.Close()
a = d.Count()
require.Equal(5, a)
}
func TestOpenAllSnapshot(t *testing.T) {
dir, require := t.TempDir(), require.New(t)
chainSnapshotCfg := snapshothashes.KnownConfig(networkname.MainnetChainName)
chainSnapshotCfg.ExpectBlocks = math.MaxUint64
cfg := ethconfig.Snapshot{Enabled: true}
createFile := func(from, to uint64, name SnapshotType) { createTestSegmentFile(t, from, to, name, dir) }
s := NewRoSnapshots(cfg, dir)
2021-12-21 14:12:32 +00:00
defer s.Close()
err := s.ReopenSegments()
2021-11-16 08:33:41 +00:00
require.NoError(err)
require.Equal(0, len(s.blocks))
s.Close()
createFile(500_000, 1_000_000, Bodies)
s = NewRoSnapshots(cfg, dir)
2021-12-21 14:12:32 +00:00
defer s.Close()
2021-11-16 08:33:41 +00:00
require.Equal(0, len(s.blocks)) //because, no headers and transactions snapshot files are created
s.Close()
createFile(500_000, 1_000_000, Headers)
createFile(500_000, 1_000_000, Transactions)
s = NewRoSnapshots(cfg, dir)
err = s.ReopenSegments()
2021-12-21 14:12:32 +00:00
require.Error(err)
2021-11-16 08:33:41 +00:00
require.Equal(0, len(s.blocks)) //because, no gaps are allowed (expect snapshots from block 0)
s.Close()
createFile(0, 500_000, Bodies)
createFile(0, 500_000, Headers)
createFile(0, 500_000, Transactions)
s = NewRoSnapshots(cfg, dir)
defer s.Close()
err = s.ReopenSegments()
require.NoError(err)
s.indicesReady.Store(true)
2021-11-16 08:33:41 +00:00
require.Equal(2, len(s.blocks))
sn, ok := s.Blocks(10)
require.True(ok)
require.Equal(int(sn.To), 500_000)
sn, ok = s.Blocks(500_000)
require.True(ok)
require.Equal(int(sn.To), 1_000_000) // [from:to)
_, ok = s.Blocks(1_000_000)
require.False(ok)
2021-12-21 14:12:32 +00:00
// Erigon may create new snapshots by itself - with high bigger than hardcoded ExpectedBlocks
// ExpectedBlocks - says only how much block must come from Torrent
chainSnapshotCfg.ExpectBlocks = 500_000 - 1
s = NewRoSnapshots(cfg, dir)
2021-12-21 14:12:32 +00:00
err = s.ReopenSegments()
require.NoError(err)
defer s.Close()
require.Equal(2, len(s.blocks))
2021-12-21 14:12:32 +00:00
createFile(500_000, 900_000, Headers)
createFile(500_000, 900_000, Bodies)
createFile(500_000, 900_000, Transactions)
chainSnapshotCfg.ExpectBlocks = math.MaxUint64
s = NewRoSnapshots(cfg, dir)
2021-12-21 14:12:32 +00:00
defer s.Close()
err = s.ReopenSegments()
2022-02-22 01:55:24 +00:00
require.NoError(err)
2021-11-16 08:33:41 +00:00
}
func TestParseCompressedFileName(t *testing.T) {
require := require.New(t)
_, _, _, err := ParseFileName("a", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("1-a", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("1-2-a", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("1-2-bodies.info", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("1-2-bodies.idx", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("1-2-bodies.seg", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("v2-1-2-bodies.seg", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
_, _, _, err = ParseFileName("v0-1-2-bodies.seg", ".seg")
2021-11-16 08:33:41 +00:00
require.Error(err)
from, to, tt, err := ParseFileName("v1-1-2-bodies.seg", ".seg")
2021-11-16 08:33:41 +00:00
require.NoError(err)
require.Equal(tt, Bodies)
require.Equal(1_000, int(from))
require.Equal(2_000, int(to))
}