d5c2ab33fc
= Add eth_node_fingerprint to block that can be imitated by both hot and cold imports - Only sync missing blocks (blocks that are missing or don't share a fingerprint) on cold import - Set block is_final status after import
98 lines
3.3 KiB
Go
98 lines
3.3 KiB
Go
package cold_import_test
|
|
|
|
import (
|
|
"errors"
|
|
"github.com/ethereum/go-ethereum/common"
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
|
"github.com/vulcanize/vulcanizedb/pkg/geth/cold_import"
|
|
)
|
|
|
|
var _ = Describe("Cold importer node builder", func() {
|
|
Describe("when level path is not valid", func() {
|
|
It("returns error if no chaindata extension", func() {
|
|
gethPath := "path/to/geth"
|
|
mockReader := fakes.NewMockFsReader()
|
|
mockParser := fakes.NewMockCryptoParser()
|
|
nodeBuilder := cold_import.NewColdImportNodeBuilder(mockReader, mockParser)
|
|
|
|
_, err := nodeBuilder.GetNode([]byte{1, 2, 3, 4, 5}, gethPath)
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
Expect(err).To(MatchError(cold_import.NoChainDataErr))
|
|
})
|
|
|
|
It("returns error if no root geth path", func() {
|
|
chaindataPath := "chaindata"
|
|
mockReader := fakes.NewMockFsReader()
|
|
mockParser := fakes.NewMockCryptoParser()
|
|
nodeBuilder := cold_import.NewColdImportNodeBuilder(mockReader, mockParser)
|
|
|
|
_, err := nodeBuilder.GetNode([]byte{1, 2, 3, 4, 5}, chaindataPath)
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
Expect(err).To(MatchError(cold_import.NoGethRootErr))
|
|
})
|
|
})
|
|
|
|
Describe("when reader fails", func() {
|
|
It("returns err", func() {
|
|
mockReader := fakes.NewMockFsReader()
|
|
fakeError := errors.New("Failed")
|
|
mockReader.SetReturnErr(fakeError)
|
|
mockParser := fakes.NewMockCryptoParser()
|
|
nodeBuilder := cold_import.NewColdImportNodeBuilder(mockReader, mockParser)
|
|
|
|
_, err := nodeBuilder.GetNode([]byte{1, 2, 3, 4, 5}, "path/to/geth/chaindata")
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
Expect(err).To(MatchError(fakeError))
|
|
})
|
|
})
|
|
|
|
Describe("when parser fails", func() {
|
|
It("returns err", func() {
|
|
mockReader := fakes.NewMockFsReader()
|
|
mockParser := fakes.NewMockCryptoParser()
|
|
fakeErr := errors.New("Failed")
|
|
mockParser.SetReturnErr(fakeErr)
|
|
nodeBuilder := cold_import.NewColdImportNodeBuilder(mockReader, mockParser)
|
|
|
|
_, err := nodeBuilder.GetNode([]byte{1, 2, 3, 4, 5}, "path/to/geth/chaindata")
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
Expect(err).To(MatchError(fakeErr))
|
|
})
|
|
})
|
|
|
|
Describe("when path is valid and reader and parser succeed", func() {
|
|
It("builds a node", func() {
|
|
fakeGenesisBlock := []byte{1, 2, 3, 4, 5}
|
|
fakeRootGethPath := "root/path/to/geth/"
|
|
fakeLevelPath := fakeRootGethPath + "chaindata"
|
|
fakeNodeKeyPath := fakeRootGethPath + "nodekey"
|
|
fakePublicKeyBytes := []byte{5, 4, 3, 2, 1}
|
|
fakePublicKeyString := "public_key"
|
|
mockReader := fakes.NewMockFsReader()
|
|
mockReader.SetReturnBytes(fakePublicKeyBytes)
|
|
mockParser := fakes.NewMockCryptoParser()
|
|
mockParser.SetReturnVal(fakePublicKeyString)
|
|
nodeBuilder := cold_import.NewColdImportNodeBuilder(mockReader, mockParser)
|
|
|
|
result, err := nodeBuilder.GetNode(fakeGenesisBlock, fakeLevelPath)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
mockReader.AssertReadCalledWith(fakeNodeKeyPath)
|
|
mockParser.AssertParsePublicKeyCalledWith(string(fakePublicKeyBytes))
|
|
Expect(result).NotTo(BeNil())
|
|
Expect(result.ClientName).To(Equal(cold_import.ColdImportClientName))
|
|
expectedGenesisBlock := common.BytesToHash(fakeGenesisBlock).String()
|
|
Expect(result.GenesisBlock).To(Equal(expectedGenesisBlock))
|
|
Expect(result.ID).To(Equal(fakePublicKeyString))
|
|
Expect(result.NetworkID).To(Equal(cold_import.ColdImportNetworkId))
|
|
})
|
|
})
|
|
|
|
})
|