erigon-pulse/erigon-lib/downloader/downloader_test.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, "")
require.NoError(err)
d, err := New(context.Background(), cfg, log.New())
require.NoError(err)
defer d.Close()
err = d.AddInfoHashAsMagnetLink(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.AddInfoHashAsMagnetLink(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.AddInfoHashAsMagnetLink(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)
}