mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2024-12-25 04:57:17 +00:00
63 lines
1.2 KiB
Go
63 lines
1.2 KiB
Go
|
package downloader
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/ethereum/go-ethereum/common"
|
||
|
"github.com/ethereum/go-ethereum/core/types"
|
||
|
"gopkg.in/fatih/set.v0"
|
||
|
)
|
||
|
|
||
|
func createHashSet(hashes []common.Hash) *set.Set {
|
||
|
hset := set.New()
|
||
|
|
||
|
for _, hash := range hashes {
|
||
|
hset.Add(hash)
|
||
|
}
|
||
|
|
||
|
return hset
|
||
|
}
|
||
|
|
||
|
func createBlocksFromHashSet(hashes *set.Set) []*types.Block {
|
||
|
blocks := make([]*types.Block, hashes.Size())
|
||
|
|
||
|
var i int
|
||
|
hashes.Each(func(v interface{}) bool {
|
||
|
blocks[i] = createBlock(i, common.Hash{}, v.(common.Hash))
|
||
|
i++
|
||
|
return true
|
||
|
})
|
||
|
|
||
|
return blocks
|
||
|
}
|
||
|
|
||
|
func TestChunking(t *testing.T) {
|
||
|
queue := newqueue()
|
||
|
peer1 := newPeer("peer1", common.Hash{}, nil, nil)
|
||
|
peer2 := newPeer("peer2", common.Hash{}, nil, nil)
|
||
|
|
||
|
// 99 + 1 (1 == known genesis hash)
|
||
|
hashes := createHashes(0, 99)
|
||
|
hashSet := createHashSet(hashes)
|
||
|
queue.put(hashSet)
|
||
|
|
||
|
chunk1 := queue.get(peer1, 99)
|
||
|
if chunk1 == nil {
|
||
|
t.Errorf("chunk1 is nil")
|
||
|
t.FailNow()
|
||
|
}
|
||
|
chunk2 := queue.get(peer2, 99)
|
||
|
if chunk2 == nil {
|
||
|
t.Errorf("chunk2 is nil")
|
||
|
t.FailNow()
|
||
|
}
|
||
|
|
||
|
if chunk1.hashes.Size() != 99 {
|
||
|
t.Error("expected chunk1 hashes to be 99, got", chunk1.hashes.Size())
|
||
|
}
|
||
|
|
||
|
if chunk2.hashes.Size() != 1 {
|
||
|
t.Error("expected chunk1 hashes to be 1, got", chunk2.hashes.Size())
|
||
|
}
|
||
|
}
|