mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-03 09:37:38 +00:00
d41d523050
"whitelisting" mechanism (list of files - stored in DB) - which protecting us from downloading new files after upgrade/downgrade was broken. And seems it became over-complicated with time. I replacing it by 1 persistent flag inside downloader: "prohibit_new_downloads.lock" Erigon will turn downloader into this mode after downloading/verification of first snapshots. ``` //Corner cases: // - Erigon generated file X with hash H1. User upgraded Erigon. New version has preverified file X with hash H2. Must ignore H2 (don't send to Downloader) // - Erigon "download once": means restart/upgrade/downgrade must not download files (and will be fast) // - After "download once" - Erigon will produce and seed new files ``` ------ `downloader --seedbox` is never "prohibit new downloads"
67 lines
2.3 KiB
Go
67 lines
2.3 KiB
Go
package downloader
|
|
|
|
import (
|
|
"context"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
lg "github.com/anacrolix/log"
|
|
"github.com/ledgerwatch/erigon-lib/common/datadir"
|
|
downloadercfg2 "github.com/ledgerwatch/erigon-lib/downloader/downloadercfg"
|
|
"github.com/ledgerwatch/erigon-lib/downloader/snaptype"
|
|
"github.com/ledgerwatch/log/v3"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestChangeInfoHashOfSameFile(t *testing.T) {
|
|
require := require.New(t)
|
|
dirs := datadir.New(t.TempDir())
|
|
cfg, err := downloadercfg2.New(dirs, "", lg.Info, 0, 0, 0, 0, 0, nil, nil, "testnet")
|
|
require.NoError(err)
|
|
d, err := New(context.Background(), cfg, dirs, log.New(), log.LvlInfo, true)
|
|
require.NoError(err)
|
|
defer d.Close()
|
|
err = d.AddMagnetLink(d.ctx, snaptype.Hex2InfoHash("aa"), "a.seg")
|
|
require.NoError(err)
|
|
tt, ok := d.torrentClient.Torrent(snaptype.Hex2InfoHash("aa"))
|
|
require.True(ok)
|
|
require.Equal("a.seg", tt.Name())
|
|
|
|
// adding same file twice is ok
|
|
err = d.AddMagnetLink(d.ctx, snaptype.Hex2InfoHash("aa"), "a.seg")
|
|
require.NoError(err)
|
|
|
|
// adding same file with another infoHash - is ok, must be skipped
|
|
// use-cases:
|
|
// - release of re-compressed version of same file,
|
|
// - ErigonV1.24 produced file X, then ErigonV1.25 released with new compression algorithm and produced X with anouther infoHash.
|
|
// ErigonV1.24 node must keep using existing file instead of downloading new one.
|
|
err = d.AddMagnetLink(d.ctx, snaptype.Hex2InfoHash("bb"), "a.seg")
|
|
require.NoError(err)
|
|
tt, ok = d.torrentClient.Torrent(snaptype.Hex2InfoHash("aa"))
|
|
require.True(ok)
|
|
require.Equal("a.seg", tt.Name())
|
|
}
|
|
|
|
func TestNoEscape(t *testing.T) {
|
|
require := require.New(t)
|
|
dirs := datadir.New(t.TempDir())
|
|
ctx := context.Background()
|
|
|
|
// allow adding files only if they are inside snapshots dir
|
|
_, err := BuildTorrentIfNeed(ctx, "a.seg", dirs.Snap)
|
|
require.NoError(err)
|
|
_, err = BuildTorrentIfNeed(ctx, "b/a.seg", dirs.Snap)
|
|
require.NoError(err)
|
|
_, err = BuildTorrentIfNeed(ctx, filepath.Join(dirs.Snap, "a.seg"), dirs.Snap)
|
|
require.NoError(err)
|
|
_, err = BuildTorrentIfNeed(ctx, filepath.Join(dirs.Snap, "b", "a.seg"), dirs.Snap)
|
|
require.NoError(err)
|
|
|
|
// reject escaping snapshots dir
|
|
_, err = BuildTorrentIfNeed(ctx, filepath.Join(dirs.Chaindata, "b", "a.seg"), dirs.Snap)
|
|
require.Error(err)
|
|
_, err = BuildTorrentIfNeed(ctx, "./../a.seg", dirs.Snap)
|
|
require.Error(err)
|
|
}
|