Fix test suites!

This commit is contained in:
Edvard 2018-12-10 15:40:45 +01:00
parent e1ba7ac5b4
commit 637623b752
5 changed files with 17 additions and 8 deletions

View File

@ -2,6 +2,7 @@ package shared
import (
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/log"
"github.com/vulcanize/vulcanizedb/pkg/core"
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
"github.com/vulcanize/vulcanizedb/pkg/transformers"
@ -18,7 +19,7 @@ type Watcher struct {
Topics []common.Hash
}
func NewWatcher(db postgres.DB, bc core.BlockChain) Watcher {
func NewWatcher(db postgres.DB, bc core.BlockChain, fetcher shared.LogFetcher) Watcher {
transformerConfigs := transformers.TransformerConfigs()
var contractAddresses []common.Address
var topic0s []common.Hash
@ -31,7 +32,6 @@ func NewWatcher(db postgres.DB, bc core.BlockChain) Watcher {
}
chunker := shared.NewLogChunker(transformerConfigs)
fetcher := shared.NewFetcher(bc)
return Watcher{
DB: db,
@ -73,6 +73,10 @@ func (watcher *Watcher) Execute() error {
for _, transformer := range watcher.Transformers {
logChunk := chunkedLogs[transformer.Name()]
err = transformer.Execute(logChunk, header)
if err != nil {
log.Error("%v transformer failed to execute: %v", transformer.Name(), err)
return err
}
}
}
return err

View File

@ -11,6 +11,7 @@ import (
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres/repositories"
"github.com/vulcanize/vulcanizedb/pkg/fakes"
shared2 "github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/mocks"
"github.com/vulcanize/vulcanizedb/test_config"
)
@ -45,7 +46,7 @@ var _ = Describe("Watcher", func() {
// TODO Add tests for aggregate fetching
// TODO Add tests for MissingHeaders
It("Adds transformers", func() {
It("adds transformers", func() {
watcher := shared.Watcher{}
watcher.AddTransformers([]shared2.TransformerInitializer{fakeTransformerInitializer})
@ -54,7 +55,7 @@ var _ = Describe("Watcher", func() {
Expect(watcher.Transformers).To(ConsistOf(&MockTransformer{}))
})
It("Adds transformers from multiple sources", func() {
It("adds transformers from multiple sources", func() {
watcher := shared.Watcher{}
watcher.AddTransformers([]shared2.TransformerInitializer{fakeTransformerInitializer})
@ -69,12 +70,14 @@ var _ = Describe("Watcher", func() {
watcher shared.Watcher
fakeTransformer *MockTransformer
headerRepository repositories.HeaderRepository
mockFetcher shared2.LogFetcher
)
BeforeEach(func() {
db = test_config.NewTestDB(test_config.NewTestNode())
test_config.CleanTestDB(db)
watcher = shared.NewWatcher(*db, nil)
mockFetcher = &mocks.MockLogFetcher{}
watcher = shared.NewWatcher(*db, nil, mockFetcher)
headerRepository = repositories.NewHeaderRepository(db)
_, err := headerRepository.CreateOrUpdateHeader(fakes.FakeHeader)
Expect(err).NotTo(HaveOccurred())

View File

@ -44,6 +44,7 @@ func (transformer LogNoteTransformer) Execute(logs []types.Log, header core.Head
log.Printf("Error marking header as checked in %v: %v", transformerName, err)
return err
}
return nil
}
models, err := transformer.Converter.ToModels(logs)

View File

@ -44,6 +44,7 @@ func (transformer Transformer) Execute(logs []types.Log, header core.Header) err
log.Printf("Error marking header as checked in %v: %v", transformerName, err)
return err
}
return nil
}
entities, err := transformer.Converter.ToEntities(config.ContractAbi, logs)

View File

@ -21,7 +21,7 @@ import (
)
type MockLogFetcher struct {
FetchedContractAddresses [][]string
FetchedContractAddresses [][]common.Address
FetchedTopics [][]common.Hash
FetchedBlocks []int64
fetcherError error
@ -29,9 +29,9 @@ type MockLogFetcher struct {
SetBcCalled bool
}
func (mlf *MockLogFetcher) FetchLogs(contractAddresses []string, topics [][]common.Hash, header core.Header) ([]types.Log, error) {
func (mlf *MockLogFetcher) FetchLogs(contractAddresses []common.Address, topics []common.Hash, header core.Header) ([]types.Log, error) {
mlf.FetchedContractAddresses = append(mlf.FetchedContractAddresses, contractAddresses)
mlf.FetchedTopics = topics
mlf.FetchedTopics = [][]common.Hash{topics}
mlf.FetchedBlocks = append(mlf.FetchedBlocks, header.BlockNumber)
return mlf.FetchedLogs, mlf.fetcherError