2019-03-27 04:05:30 +00:00
|
|
|
package transactions_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ethereum/go-ethereum/core/types"
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
"github.com/vulcanize/vulcanizedb/libraries/shared/transactions"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
|
|
|
"github.com/vulcanize/vulcanizedb/test_config"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ = Describe("Transaction syncer", func() {
|
2019-03-27 17:26:04 +00:00
|
|
|
var (
|
|
|
|
blockChain *fakes.MockBlockChain
|
|
|
|
syncer transactions.TransactionsSyncer
|
|
|
|
)
|
|
|
|
|
|
|
|
BeforeEach(func() {
|
2019-03-27 04:05:30 +00:00
|
|
|
db := test_config.NewTestDB(test_config.NewTestNode())
|
2019-03-27 17:26:04 +00:00
|
|
|
test_config.CleanTestDB(db)
|
|
|
|
blockChain = fakes.NewMockBlockChain()
|
|
|
|
syncer = transactions.NewTransactionsSyncer(db, blockChain)
|
|
|
|
})
|
2019-03-27 04:05:30 +00:00
|
|
|
|
2019-03-27 17:26:04 +00:00
|
|
|
It("fetches transactions for logs", func() {
|
2019-03-27 04:05:30 +00:00
|
|
|
err := syncer.SyncTransactions(0, []types.Log{})
|
|
|
|
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
Expect(blockChain.GetTransactionsCalled).To(BeTrue())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("only fetches transactions with unique hashes", func() {
|
|
|
|
err := syncer.SyncTransactions(0, []types.Log{{
|
|
|
|
TxHash: fakes.FakeHash,
|
|
|
|
}, {
|
|
|
|
TxHash: fakes.FakeHash,
|
|
|
|
}})
|
|
|
|
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
Expect(len(blockChain.GetTransactionsPassedHashes)).To(Equal(1))
|
|
|
|
})
|
|
|
|
|
|
|
|
It("returns error if fetching transactions fails", func() {
|
|
|
|
blockChain.GetTransactionsError = fakes.FakeError
|
|
|
|
|
|
|
|
err := syncer.SyncTransactions(0, []types.Log{})
|
|
|
|
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
Expect(err).To(MatchError(fakes.FakeError))
|
|
|
|
})
|
|
|
|
|
|
|
|
It("passes transactions to repository for persistence", func() {
|
|
|
|
blockChain.Transactions = []core.TransactionModel{{}}
|
|
|
|
mockHeaderRepository := fakes.NewMockHeaderRepository()
|
|
|
|
syncer.Repository = mockHeaderRepository
|
|
|
|
|
|
|
|
err := syncer.SyncTransactions(0, []types.Log{})
|
|
|
|
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
2019-03-27 17:26:04 +00:00
|
|
|
Expect(mockHeaderRepository.CreateTransactionsCalled).To(BeTrue())
|
2019-03-27 04:05:30 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
It("returns error if persisting transactions fails", func() {
|
|
|
|
blockChain.Transactions = []core.TransactionModel{{}}
|
|
|
|
mockHeaderRepository := fakes.NewMockHeaderRepository()
|
2019-03-27 17:26:04 +00:00
|
|
|
mockHeaderRepository.CreateTransactionsError = fakes.FakeError
|
2019-03-27 04:05:30 +00:00
|
|
|
syncer.Repository = mockHeaderRepository
|
|
|
|
|
|
|
|
err := syncer.SyncTransactions(0, []types.Log{})
|
|
|
|
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
Expect(err).To(MatchError(fakes.FakeError))
|
|
|
|
})
|
|
|
|
})
|