Finish watcher and watcher tests (+fmt)
This commit is contained in:
parent
d93817f346
commit
5d4239de05
@ -5,7 +5,6 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/log"
|
"github.com/ethereum/go-ethereum/log"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/core"
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -25,8 +24,8 @@ type Watcher struct {
|
|||||||
Repository WatcherRepository
|
Repository WatcherRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWatcher(db *postgres.DB, fetcher shared.LogFetcher, repository WatcherRepository) Watcher {
|
func NewWatcher(db *postgres.DB, fetcher shared.LogFetcher, repository WatcherRepository,
|
||||||
transformerConfigs := transformers.TransformerConfigs()
|
transformerConfigs []shared.TransformerConfig) Watcher {
|
||||||
var contractAddresses []common.Address
|
var contractAddresses []common.Address
|
||||||
var topic0s []common.Hash
|
var topic0s []common.Hash
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ package shared_test
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"github.com/ethereum/go-ethereum/common"
|
||||||
"github.com/ethereum/go-ethereum/core/types"
|
"github.com/ethereum/go-ethereum/core/types"
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
@ -10,6 +11,7 @@ import (
|
|||||||
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres/repositories"
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres/repositories"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/transformers"
|
||||||
shared2 "github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
shared2 "github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/mocks"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/mocks"
|
||||||
"github.com/vulcanize/vulcanizedb/test_config"
|
"github.com/vulcanize/vulcanizedb/test_config"
|
||||||
@ -42,7 +44,28 @@ func fakeTransformerInitializer(db *postgres.DB) shared2.Transformer {
|
|||||||
|
|
||||||
var _ = Describe("Watcher", func() {
|
var _ = Describe("Watcher", func() {
|
||||||
It("initialises correctly", func() {
|
It("initialises correctly", func() {
|
||||||
// TODO Test watcher initialisation
|
db := test_config.NewTestDB(core.Node{ID: "testNode"})
|
||||||
|
fetcher := mocks.MockLogFetcher{}
|
||||||
|
repository := &mocks.MockWatcherRepository{}
|
||||||
|
configA := shared2.TransformerConfig{
|
||||||
|
ContractAddresses: []string{"0xA"},
|
||||||
|
Topic: "0xA",
|
||||||
|
}
|
||||||
|
configB := shared2.TransformerConfig{
|
||||||
|
ContractAddresses: []string{"0xB"},
|
||||||
|
Topic: "0xB",
|
||||||
|
}
|
||||||
|
configs := []shared2.TransformerConfig{configA, configB}
|
||||||
|
watcher := shared.NewWatcher(db, &fetcher, repository, configs)
|
||||||
|
|
||||||
|
Expect(watcher.DB).To(Equal(db))
|
||||||
|
Expect(watcher.Fetcher).NotTo(BeNil())
|
||||||
|
Expect(watcher.Chunker).NotTo(BeNil())
|
||||||
|
Expect(watcher.Repository).To(Equal(repository))
|
||||||
|
Expect(watcher.Topics).To(And(
|
||||||
|
ContainElement(common.HexToHash("0xA")), ContainElement(common.HexToHash("0xB"))))
|
||||||
|
Expect(watcher.Addresses).To(And(
|
||||||
|
ContainElement(common.HexToAddress("0xA")), ContainElement(common.HexToAddress("0xB"))))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("adds transformers", func() {
|
It("adds transformers", func() {
|
||||||
@ -69,22 +92,26 @@ var _ = Describe("Watcher", func() {
|
|||||||
watcher shared.Watcher
|
watcher shared.Watcher
|
||||||
fakeTransformer *MockTransformer
|
fakeTransformer *MockTransformer
|
||||||
headerRepository repositories.HeaderRepository
|
headerRepository repositories.HeaderRepository
|
||||||
mockFetcher shared2.LogFetcher
|
mockFetcher mocks.MockLogFetcher
|
||||||
|
repository mocks.MockWatcherRepository
|
||||||
)
|
)
|
||||||
|
|
||||||
BeforeEach(func() {
|
BeforeEach(func() {
|
||||||
db = test_config.NewTestDB(test_config.NewTestNode())
|
db = test_config.NewTestDB(test_config.NewTestNode())
|
||||||
test_config.CleanTestDB(db)
|
test_config.CleanTestDB(db)
|
||||||
mockFetcher = &mocks.MockLogFetcher{}
|
mockFetcher = mocks.MockLogFetcher{}
|
||||||
watcher = shared.NewWatcher(db, mockFetcher)
|
|
||||||
headerRepository = repositories.NewHeaderRepository(db)
|
headerRepository = repositories.NewHeaderRepository(db)
|
||||||
_, err := headerRepository.CreateOrUpdateHeader(fakes.FakeHeader)
|
_, err := headerRepository.CreateOrUpdateHeader(fakes.FakeHeader)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
|
repository = mocks.MockWatcherRepository{}
|
||||||
|
watcher = shared.NewWatcher(db, &mockFetcher, &repository, transformers.TransformerConfigs())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("executes each transformer", func() {
|
It("executes each transformer", func() {
|
||||||
fakeTransformer = &MockTransformer{}
|
fakeTransformer = &MockTransformer{}
|
||||||
watcher.Transformers = []shared2.Transformer{fakeTransformer}
|
watcher.Transformers = []shared2.Transformer{fakeTransformer}
|
||||||
|
repository.SetMissingHeaders([]core.Header{fakes.FakeHeader})
|
||||||
|
|
||||||
err := watcher.Execute()
|
err := watcher.Execute()
|
||||||
|
|
||||||
@ -95,6 +122,7 @@ var _ = Describe("Watcher", func() {
|
|||||||
It("returns an error if transformer returns an error", func() {
|
It("returns an error if transformer returns an error", func() {
|
||||||
fakeTransformer = &MockTransformer{executeError: errors.New("Something bad happened")}
|
fakeTransformer = &MockTransformer{executeError: errors.New("Something bad happened")}
|
||||||
watcher.Transformers = []shared2.Transformer{fakeTransformer}
|
watcher.Transformers = []shared2.Transformer{fakeTransformer}
|
||||||
|
repository.SetMissingHeaders([]core.Header{fakes.FakeHeader})
|
||||||
|
|
||||||
err := watcher.Execute()
|
err := watcher.Execute()
|
||||||
|
|
||||||
@ -102,24 +130,65 @@ var _ = Describe("Watcher", func() {
|
|||||||
Expect(fakeTransformer.executeWasCalled).To(BeFalse())
|
Expect(fakeTransformer.executeWasCalled).To(BeFalse())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("calls MissingHeaders", func() {
|
|
||||||
// TODO Tests for calling MissingHeaders
|
|
||||||
})
|
|
||||||
|
|
||||||
It("returns an error if missingHeaders returns an error", func() {
|
|
||||||
// TODO Test for propagating missingHeaders error
|
|
||||||
})
|
|
||||||
|
|
||||||
It("calls the log fetcher", func() {
|
|
||||||
// TODO Test for calling FetchLogs
|
|
||||||
})
|
|
||||||
|
|
||||||
It("returns an error if the log fetcher returns an error", func() {
|
|
||||||
// TODO Test for propagating log fetcher error
|
|
||||||
})
|
|
||||||
|
|
||||||
It("passes only relevant logs to each transformer", func() {
|
It("passes only relevant logs to each transformer", func() {
|
||||||
// TODO Test log delegation
|
// TODO Test log delegation
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Describe("uses the repository correctly:", func() {
|
||||||
|
|
||||||
|
It("calls MissingHeaders", func() {
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).To(Not(HaveOccurred()))
|
||||||
|
Expect(repository.MissingHeadersCalled).To(BeTrue())
|
||||||
|
})
|
||||||
|
|
||||||
|
It("propagates MissingHeaders errors", func() {
|
||||||
|
missingHeadersError := errors.New("MissingHeadersError")
|
||||||
|
repository.MissingHeadersError = missingHeadersError
|
||||||
|
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).To(MatchError(missingHeadersError))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("calls CreateNotCheckedSQL", func() {
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
Expect(repository.CreateNotCheckedSQLCalled).To(BeTrue())
|
||||||
|
})
|
||||||
|
|
||||||
|
It("calls GetCheckedColumnNames", func() {
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
Expect(repository.GetCheckedColumnNamesCalled).To(BeTrue())
|
||||||
|
})
|
||||||
|
|
||||||
|
It("propagates GetCheckedColumnNames errors", func() {
|
||||||
|
getCheckedColumnNamesError := errors.New("GetCheckedColumnNamesError")
|
||||||
|
repository.GetCheckedColumnNamesError = getCheckedColumnNamesError
|
||||||
|
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).To(MatchError(getCheckedColumnNamesError))
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
Describe("uses the LogFetcher correctly:", func() {
|
||||||
|
BeforeEach(func() {
|
||||||
|
repository.SetMissingHeaders([]core.Header{fakes.FakeHeader})
|
||||||
|
})
|
||||||
|
|
||||||
|
It("fetches logs", func() {
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
Expect(mockFetcher.FetchLogsCalled).To(BeTrue())
|
||||||
|
})
|
||||||
|
|
||||||
|
It("propagates log fetcher errors", func() {
|
||||||
|
fetcherError := errors.New("FetcherError")
|
||||||
|
mockFetcher.SetFetcherError(fetcherError)
|
||||||
|
|
||||||
|
err := watcher.Execute()
|
||||||
|
Expect(err).To(MatchError(fetcherError))
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -19,8 +19,6 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/core/types"
|
"github.com/ethereum/go-ethereum/core/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TODO Add unit tests for LogChunker
|
|
||||||
|
|
||||||
type LogChunker struct {
|
type LogChunker struct {
|
||||||
AddressToNames map[string][]string
|
AddressToNames map[string][]string
|
||||||
NameToTopic0 map[string]common.Hash
|
NameToTopic0 map[string]common.Hash
|
||||||
|
@ -71,7 +71,7 @@ var _ = Describe("Log chunker", func() {
|
|||||||
logs := []types.Log{log1, log2, log3, log4, log5}
|
logs := []types.Log{log1, log2, log3, log4, log5}
|
||||||
chunks := chunker.ChunkLogs(logs)
|
chunks := chunker.ChunkLogs(logs)
|
||||||
|
|
||||||
Expect(chunks["TransformerA"]).To(And(ContainElement(log1),ContainElement(log4)))
|
Expect(chunks["TransformerA"]).To(And(ContainElement(log1), ContainElement(log4)))
|
||||||
Expect(chunks["TransformerB"]).To(BeEmpty())
|
Expect(chunks["TransformerB"]).To(BeEmpty())
|
||||||
Expect(chunks["TransformerC"]).To(ContainElement(log5))
|
Expect(chunks["TransformerC"]).To(ContainElement(log5))
|
||||||
})
|
})
|
||||||
|
@ -26,14 +26,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var _ = Describe("Fetcher", func() {
|
var _ = Describe("Fetcher", func() {
|
||||||
Describe("Iinitialisation", func() {
|
|
||||||
It("creates correct lookup maps", func() {
|
|
||||||
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
Describe("FetchLogs", func() {
|
Describe("FetchLogs", func() {
|
||||||
// TODO Add tests for aggregate fetching
|
|
||||||
It("fetches logs based on the given query", func() {
|
It("fetches logs based on the given query", func() {
|
||||||
blockChain := fakes.NewMockBlockChain()
|
blockChain := fakes.NewMockBlockChain()
|
||||||
fetcher := shared.NewFetcher(blockChain)
|
fetcher := shared.NewFetcher(blockChain)
|
||||||
|
@ -27,12 +27,14 @@ type MockLogFetcher struct {
|
|||||||
fetcherError error
|
fetcherError error
|
||||||
FetchedLogs []types.Log
|
FetchedLogs []types.Log
|
||||||
SetBcCalled bool
|
SetBcCalled bool
|
||||||
|
FetchLogsCalled bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (mlf *MockLogFetcher) FetchLogs(contractAddresses []common.Address, 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.FetchedContractAddresses = append(mlf.FetchedContractAddresses, contractAddresses)
|
||||||
mlf.FetchedTopics = [][]common.Hash{topics}
|
mlf.FetchedTopics = [][]common.Hash{topics}
|
||||||
mlf.FetchedBlocks = append(mlf.FetchedBlocks, header.BlockNumber)
|
mlf.FetchedBlocks = append(mlf.FetchedBlocks, header.BlockNumber)
|
||||||
|
mlf.FetchLogsCalled = true
|
||||||
|
|
||||||
return mlf.FetchedLogs, mlf.fetcherError
|
return mlf.FetchedLogs, mlf.fetcherError
|
||||||
}
|
}
|
||||||
|
53
pkg/transformers/test_data/mocks/mock_watcher_repository.go
Normal file
53
pkg/transformers/test_data/mocks/mock_watcher_repository.go
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
package mocks
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
||||||
|
)
|
||||||
|
|
||||||
|
type MockWatcherRepository struct {
|
||||||
|
ReturnCheckedColumnNames []string
|
||||||
|
GetCheckedColumnNamesError error
|
||||||
|
GetCheckedColumnNamesCalled bool
|
||||||
|
|
||||||
|
ReturnNotCheckedSQL string
|
||||||
|
CreateNotCheckedSQLCalled bool
|
||||||
|
|
||||||
|
ReturnMissingHeaders []core.Header
|
||||||
|
MissingHeadersError error
|
||||||
|
MissingHeadersCalled bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (repository *MockWatcherRepository) GetCheckedColumnNames(db *postgres.DB) ([]string, error) {
|
||||||
|
repository.GetCheckedColumnNamesCalled = true
|
||||||
|
if repository.GetCheckedColumnNamesError != nil {
|
||||||
|
return []string{}, repository.GetCheckedColumnNamesError
|
||||||
|
}
|
||||||
|
|
||||||
|
return repository.ReturnCheckedColumnNames, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (repository *MockWatcherRepository) SetCheckedColumnNames(checkedColumnNames []string) {
|
||||||
|
repository.ReturnCheckedColumnNames = checkedColumnNames
|
||||||
|
}
|
||||||
|
|
||||||
|
func (repository *MockWatcherRepository) CreateNotCheckedSQL(boolColumns []string) string {
|
||||||
|
repository.CreateNotCheckedSQLCalled = true
|
||||||
|
return repository.ReturnNotCheckedSQL
|
||||||
|
}
|
||||||
|
|
||||||
|
func (repository *MockWatcherRepository) SetNotCheckedSQL(notCheckedSql string) {
|
||||||
|
repository.ReturnNotCheckedSQL = notCheckedSql
|
||||||
|
}
|
||||||
|
|
||||||
|
func (repository *MockWatcherRepository) MissingHeaders(startingBlockNumber int64, endingBlockNumber int64, db *postgres.DB, notCheckedSQL string) ([]core.Header, error) {
|
||||||
|
if repository.MissingHeadersError != nil {
|
||||||
|
return []core.Header{}, repository.MissingHeadersError
|
||||||
|
}
|
||||||
|
repository.MissingHeadersCalled = true
|
||||||
|
return repository.ReturnMissingHeaders, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (repository *MockWatcherRepository) SetMissingHeaders(headers []core.Header) {
|
||||||
|
repository.ReturnMissingHeaders = headers
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user