forked from cerc-io/ipld-eth-server
Use transformer factory for FlipKick (#96)
This commit is contained in:
parent
ab4e904713
commit
981393d0a7
@ -16,10 +16,11 @@ package flip_kick
|
|||||||
|
|
||||||
import "github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
import "github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
||||||
|
|
||||||
var FlipKickConfig = shared.TransformerConfig{
|
var FlipKickConfig = shared.SingleTransformerConfig{
|
||||||
|
TransformerName: shared.FlipKickLabel,
|
||||||
ContractAddresses: []string{shared.FlipperContractAddress},
|
ContractAddresses: []string{shared.FlipperContractAddress},
|
||||||
ContractAbi: shared.FlipperABI,
|
ContractAbi: shared.FlipperABI,
|
||||||
Topics: []string{shared.FlipKickSignature},
|
Topic: shared.FlipKickSignature,
|
||||||
StartingBlockNumber: 0,
|
StartingBlockNumber: 0,
|
||||||
EndingBlockNumber: 10000000,
|
EndingBlockNumber: 10000000,
|
||||||
}
|
}
|
||||||
|
@ -23,18 +23,15 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
"github.com/ethereum/go-ethereum/core/types"
|
"github.com/ethereum/go-ethereum/core/types"
|
||||||
|
|
||||||
|
"fmt"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/geth"
|
"github.com/vulcanize/vulcanizedb/pkg/geth"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Converter interface {
|
|
||||||
ToEntities(contractAbi string, ethLogs []types.Log) ([]FlipKickEntity, error)
|
|
||||||
ToModels(flipKicks []FlipKickEntity) ([]FlipKickModel, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
type FlipKickConverter struct{}
|
type FlipKickConverter struct{}
|
||||||
|
|
||||||
func (FlipKickConverter) ToEntities(contractAbi string, ethLogs []types.Log) (results []FlipKickEntity, err error) {
|
func (FlipKickConverter) ToEntities(contractAbi string, ethLogs []types.Log) ([]interface{}, error) {
|
||||||
|
var entities []interface{}
|
||||||
for _, ethLog := range ethLogs {
|
for _, ethLog := range ethLogs {
|
||||||
entity := &FlipKickEntity{}
|
entity := &FlipKickEntity{}
|
||||||
address := ethLog.Address
|
address := ethLog.Address
|
||||||
@ -52,27 +49,33 @@ func (FlipKickConverter) ToEntities(contractAbi string, ethLogs []types.Log) (re
|
|||||||
entity.Raw = ethLog
|
entity.Raw = ethLog
|
||||||
entity.TransactionIndex = ethLog.TxIndex
|
entity.TransactionIndex = ethLog.TxIndex
|
||||||
entity.LogIndex = ethLog.Index
|
entity.LogIndex = ethLog.Index
|
||||||
results = append(results, *entity)
|
entities = append(entities, *entity)
|
||||||
}
|
}
|
||||||
|
|
||||||
return results, nil
|
return entities, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (FlipKickConverter) ToModels(flipKicks []FlipKickEntity) (results []FlipKickModel, err error) {
|
func (FlipKickConverter) ToModels(entities []interface{}) ([]interface{}, error) {
|
||||||
for _, flipKick := range flipKicks {
|
var models []interface{}
|
||||||
if flipKick.Id == nil {
|
for _, entity := range entities {
|
||||||
|
flipKickEntity, ok := entity.(FlipKickEntity)
|
||||||
|
if !ok {
|
||||||
|
return nil, fmt.Errorf("entity of type %T, not %T", entity, FlipKickEntity{})
|
||||||
|
}
|
||||||
|
|
||||||
|
if flipKickEntity.Id == nil {
|
||||||
return nil, errors.New("FlipKick log ID cannot be nil.")
|
return nil, errors.New("FlipKick log ID cannot be nil.")
|
||||||
}
|
}
|
||||||
|
|
||||||
id := flipKick.Id.String()
|
id := flipKickEntity.Id.String()
|
||||||
lot := shared.BigIntToString(flipKick.Lot)
|
lot := shared.BigIntToString(flipKickEntity.Lot)
|
||||||
bid := shared.BigIntToString(flipKick.Bid)
|
bid := shared.BigIntToString(flipKickEntity.Bid)
|
||||||
gal := flipKick.Gal.String()
|
gal := flipKickEntity.Gal.String()
|
||||||
endValue := shared.BigIntToInt64(flipKick.End)
|
endValue := shared.BigIntToInt64(flipKickEntity.End)
|
||||||
end := time.Unix(endValue, 0)
|
end := time.Unix(endValue, 0)
|
||||||
urn := common.BytesToAddress(flipKick.Urn[:common.AddressLength]).String()
|
urn := common.BytesToAddress(flipKickEntity.Urn[:common.AddressLength]).String()
|
||||||
tab := shared.BigIntToString(flipKick.Tab)
|
tab := shared.BigIntToString(flipKickEntity.Tab)
|
||||||
rawLogJson, err := json.Marshal(flipKick.Raw)
|
rawLogJson, err := json.Marshal(flipKickEntity.Raw)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -86,11 +89,11 @@ func (FlipKickConverter) ToModels(flipKicks []FlipKickEntity) (results []FlipKic
|
|||||||
End: end,
|
End: end,
|
||||||
Urn: urn,
|
Urn: urn,
|
||||||
Tab: tab,
|
Tab: tab,
|
||||||
TransactionIndex: flipKick.TransactionIndex,
|
TransactionIndex: flipKickEntity.TransactionIndex,
|
||||||
LogIndex: flipKick.LogIndex,
|
LogIndex: flipKickEntity.LogIndex,
|
||||||
Raw: rawLogString,
|
Raw: rawLogString,
|
||||||
}
|
}
|
||||||
results = append(results, model)
|
models = append(models, model)
|
||||||
}
|
}
|
||||||
return results, err
|
return models, nil
|
||||||
}
|
}
|
||||||
|
@ -66,7 +66,7 @@ var _ = Describe("FlipKick Converter", func() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
It("converts an Entity to a Model", func() {
|
It("converts an Entity to a Model", func() {
|
||||||
models, err := converter.ToModels([]flip_kick.FlipKickEntity{test_data.FlipKickEntity})
|
models, err := converter.ToModels([]interface{}{test_data.FlipKickEntity})
|
||||||
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
Expect(len(models)).To(Equal(1))
|
Expect(len(models)).To(Equal(1))
|
||||||
@ -74,11 +74,11 @@ var _ = Describe("FlipKick Converter", func() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
It("handles nil values", func() {
|
It("handles nil values", func() {
|
||||||
models, err := converter.ToModels([]flip_kick.FlipKickEntity{emptyEntity})
|
models, err := converter.ToModels([]interface{}{emptyEntity})
|
||||||
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
Expect(len(models)).To(Equal(1))
|
Expect(len(models)).To(Equal(1))
|
||||||
model := models[0]
|
model := models[0].(flip_kick.FlipKickModel)
|
||||||
Expect(model.BidId).To(Equal("1"))
|
Expect(model.BidId).To(Equal("1"))
|
||||||
Expect(model.Lot).To(Equal(emptyString))
|
Expect(model.Lot).To(Equal(emptyString))
|
||||||
Expect(model.Bid).To(Equal(emptyString))
|
Expect(model.Bid).To(Equal(emptyString))
|
||||||
@ -91,9 +91,16 @@ var _ = Describe("FlipKick Converter", func() {
|
|||||||
|
|
||||||
It("returns an error if the flip kick event id is nil", func() {
|
It("returns an error if the flip kick event id is nil", func() {
|
||||||
emptyEntity.Id = nil
|
emptyEntity.Id = nil
|
||||||
_, err := converter.ToModels([]flip_kick.FlipKickEntity{emptyEntity})
|
_, err := converter.ToModels([]interface{}{emptyEntity})
|
||||||
|
|
||||||
Expect(err).To(HaveOccurred())
|
Expect(err).To(HaveOccurred())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("returns an error if the wrong entity type is passed in", func() {
|
||||||
|
_, err := converter.ToModels([]interface{}{test_data.WrongEntity{}})
|
||||||
|
|
||||||
|
Expect(err).To(HaveOccurred())
|
||||||
|
Expect(err.Error()).To(ContainSubstring("entity of type"))
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -1,52 +0,0 @@
|
|||||||
// Copyright 2018 Vulcanize
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package flip_kick_test
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
|
||||||
. "github.com/onsi/ginkgo"
|
|
||||||
. "github.com/onsi/gomega"
|
|
||||||
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/geth"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data"
|
|
||||||
)
|
|
||||||
|
|
||||||
var _ = Describe("Integration tests", func() {
|
|
||||||
It("unpacks an event log", func() {
|
|
||||||
address := common.HexToAddress(shared.FlipperContractAddress)
|
|
||||||
abi, err := geth.ParseAbi(shared.FlipperABI)
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
|
||||||
|
|
||||||
contract := bind.NewBoundContract(address, abi, nil, nil, nil)
|
|
||||||
entity := &flip_kick.FlipKickEntity{}
|
|
||||||
|
|
||||||
var eventLog = test_data.EthFlipKickLog
|
|
||||||
|
|
||||||
err = contract.UnpackLog(entity, "Kick", eventLog)
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
|
||||||
|
|
||||||
expectedEntity := test_data.FlipKickEntity
|
|
||||||
Expect(entity.Id).To(Equal(expectedEntity.Id))
|
|
||||||
Expect(entity.Lot).To(Equal(expectedEntity.Lot))
|
|
||||||
Expect(entity.Bid).To(Equal(expectedEntity.Bid))
|
|
||||||
Expect(entity.Gal).To(Equal(expectedEntity.Gal))
|
|
||||||
Expect(entity.End).To(Equal(expectedEntity.End))
|
|
||||||
Expect(entity.Urn).To(Equal(expectedEntity.Urn))
|
|
||||||
Expect(entity.Tab).To(Equal(expectedEntity.Tab))
|
|
||||||
})
|
|
||||||
})
|
|
@ -21,29 +21,24 @@ import (
|
|||||||
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Repository interface {
|
|
||||||
Create(headerId int64, flipKicks []FlipKickModel) error
|
|
||||||
MarkHeaderChecked(headerId int64) error
|
|
||||||
MissingHeaders(startingBlockNumber, endingBlockNumber int64) ([]core.Header, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
type FlipKickRepository struct {
|
type FlipKickRepository struct {
|
||||||
DB *postgres.DB
|
db *postgres.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewFlipKickRepository(db *postgres.DB) FlipKickRepository {
|
func (fkr FlipKickRepository) Create(headerId int64, models []interface{}) error {
|
||||||
return FlipKickRepository{DB: db}
|
tx, err := fkr.db.Begin()
|
||||||
}
|
|
||||||
func (fkr FlipKickRepository) Create(headerId int64, flipKicks []FlipKickModel) error {
|
|
||||||
tx, err := fkr.DB.Begin()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
for _, flipKick := range flipKicks {
|
for _, model := range models {
|
||||||
|
flipKickModel, ok := model.(FlipKickModel)
|
||||||
|
if !ok {
|
||||||
|
return fmt.Errorf("model of type %T, not %T", model, FlipKickModel{})
|
||||||
|
}
|
||||||
_, err := tx.Exec(
|
_, err := tx.Exec(
|
||||||
`INSERT into maker.flip_kick (header_id, bid_id, lot, bid, gal, "end", urn, tab, tx_idx, log_idx, raw_log)
|
`INSERT into maker.flip_kick (header_id, bid_id, lot, bid, gal, "end", urn, tab, tx_idx, log_idx, raw_log)
|
||||||
VALUES($1, $2::NUMERIC, $3::NUMERIC, $4::NUMERIC, $5, $6, $7, $8::NUMERIC, $9, $10, $11)`,
|
VALUES($1, $2::NUMERIC, $3::NUMERIC, $4::NUMERIC, $5, $6, $7, $8::NUMERIC, $9, $10, $11)`,
|
||||||
headerId, flipKick.BidId, flipKick.Lot, flipKick.Bid, flipKick.Gal, flipKick.End, flipKick.Urn, flipKick.Tab, flipKick.TransactionIndex, flipKick.LogIndex, flipKick.Raw,
|
headerId, flipKickModel.BidId, flipKickModel.Lot, flipKickModel.Bid, flipKickModel.Gal, flipKickModel.End, flipKickModel.Urn, flipKickModel.Tab, flipKickModel.TransactionIndex, flipKickModel.LogIndex, flipKickModel.Raw,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
tx.Rollback()
|
tx.Rollback()
|
||||||
@ -62,7 +57,7 @@ func (fkr FlipKickRepository) Create(headerId int64, flipKicks []FlipKickModel)
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (fkr FlipKickRepository) MarkHeaderChecked(headerId int64) error {
|
func (fkr FlipKickRepository) MarkHeaderChecked(headerId int64) error {
|
||||||
_, err := fkr.DB.Exec(`INSERT INTO public.checked_headers (header_id, flip_kick_checked)
|
_, err := fkr.db.Exec(`INSERT INTO public.checked_headers (header_id, flip_kick_checked)
|
||||||
VALUES ($1, $2)
|
VALUES ($1, $2)
|
||||||
ON CONFLICT (header_id) DO
|
ON CONFLICT (header_id) DO
|
||||||
UPDATE SET flip_kick_checked = $2`, headerId, true)
|
UPDATE SET flip_kick_checked = $2`, headerId, true)
|
||||||
@ -71,7 +66,7 @@ func (fkr FlipKickRepository) MarkHeaderChecked(headerId int64) error {
|
|||||||
|
|
||||||
func (fkr FlipKickRepository) MissingHeaders(startingBlockNumber, endingBlockNumber int64) ([]core.Header, error) {
|
func (fkr FlipKickRepository) MissingHeaders(startingBlockNumber, endingBlockNumber int64) ([]core.Header, error) {
|
||||||
var result []core.Header
|
var result []core.Header
|
||||||
err := fkr.DB.Select(
|
err := fkr.db.Select(
|
||||||
&result,
|
&result,
|
||||||
`SELECT headers.id, headers.block_number FROM headers
|
`SELECT headers.id, headers.block_number FROM headers
|
||||||
LEFT JOIN checked_headers on headers.id = header_id
|
LEFT JOIN checked_headers on headers.id = header_id
|
||||||
@ -81,7 +76,7 @@ func (fkr FlipKickRepository) MissingHeaders(startingBlockNumber, endingBlockNum
|
|||||||
AND headers.eth_node_fingerprint = $3`,
|
AND headers.eth_node_fingerprint = $3`,
|
||||||
startingBlockNumber,
|
startingBlockNumber,
|
||||||
endingBlockNumber,
|
endingBlockNumber,
|
||||||
fkr.DB.Node.ID,
|
fkr.db.Node.ID,
|
||||||
)
|
)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -91,3 +86,7 @@ func (fkr FlipKickRepository) MissingHeaders(startingBlockNumber, endingBlockNum
|
|||||||
|
|
||||||
return result, nil
|
return result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (fkr *FlipKickRepository) SetDB(db *postgres.DB) {
|
||||||
|
fkr.db = db
|
||||||
|
}
|
||||||
|
@ -37,7 +37,8 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
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)
|
||||||
flipKickRepository = flip_kick.FlipKickRepository{DB: db}
|
flipKickRepository = flip_kick.FlipKickRepository{}
|
||||||
|
flipKickRepository.SetDB(db)
|
||||||
blockNumber = GinkgoRandomSeed()
|
blockNumber = GinkgoRandomSeed()
|
||||||
headerId = createHeader(db, blockNumber)
|
headerId = createHeader(db, blockNumber)
|
||||||
|
|
||||||
@ -47,18 +48,18 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
|
|
||||||
Describe("Create", func() {
|
Describe("Create", func() {
|
||||||
AfterEach(func() {
|
AfterEach(func() {
|
||||||
_, err := db.Exec(`DELETE from headers;`)
|
_, err := db.Exec(`DELETE from headers`)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("persists flip_kick records", func() {
|
It("persists flip_kick records", func() {
|
||||||
err := flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{flipKick})
|
err := flipKickRepository.Create(headerId, []interface{}{flipKick})
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
assertDBRecordCount(db, "maker.flip_kick", 1)
|
assertDBRecordCount(db, "maker.flip_kick", 1)
|
||||||
|
|
||||||
dbResult := test_data.FlipKickDBRow{}
|
dbResult := test_data.FlipKickDBRow{}
|
||||||
err = flipKickRepository.DB.QueryRowx(`SELECT * FROM maker.flip_kick`).StructScan(&dbResult)
|
err = db.QueryRowx(`SELECT * FROM maker.flip_kick`).StructScan(&dbResult)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
Expect(dbResult.HeaderId).To(Equal(headerId))
|
Expect(dbResult.HeaderId).To(Equal(headerId))
|
||||||
Expect(dbResult.BidId).To(Equal(flipKick.BidId))
|
Expect(dbResult.BidId).To(Equal(flipKick.BidId))
|
||||||
@ -74,7 +75,7 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
It("marks header checked", func() {
|
It("marks header checked", func() {
|
||||||
err := flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{flipKick})
|
err := flipKickRepository.Create(headerId, []interface{}{flipKick})
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
var headerChecked bool
|
var headerChecked bool
|
||||||
@ -86,7 +87,7 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
It("updates the header to checked if checked headers row already exists", func() {
|
It("updates the header to checked if checked headers row already exists", func() {
|
||||||
_, err := db.Exec(`INSERT INTO public.checked_headers (header_id) VALUES ($1)`, headerId)
|
_, err := db.Exec(`INSERT INTO public.checked_headers (header_id) VALUES ($1)`, headerId)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
err = flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{flipKick})
|
err = flipKickRepository.Create(headerId, []interface{}{flipKick})
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
var headerChecked bool
|
var headerChecked bool
|
||||||
@ -96,10 +97,10 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
It("returns an error if inserting the flip_kick record fails", func() {
|
It("returns an error if inserting the flip_kick record fails", func() {
|
||||||
err := flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{flipKick})
|
err := flipKickRepository.Create(headerId, []interface{}{flipKick})
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
err = flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{flipKick})
|
err = flipKickRepository.Create(headerId, []interface{}{flipKick})
|
||||||
Expect(err).To(HaveOccurred())
|
Expect(err).To(HaveOccurred())
|
||||||
Expect(err.Error()).To(ContainSubstring("pq: duplicate key value violates unique constraint"))
|
Expect(err.Error()).To(ContainSubstring("pq: duplicate key value violates unique constraint"))
|
||||||
})
|
})
|
||||||
@ -107,13 +108,13 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
It("allows for multiple flip kick events in one transaction if they have different log indexes", func() {
|
It("allows for multiple flip kick events in one transaction if they have different log indexes", func() {
|
||||||
newFlipKick := test_data.FlipKickModel
|
newFlipKick := test_data.FlipKickModel
|
||||||
newFlipKick.LogIndex = newFlipKick.LogIndex + 1
|
newFlipKick.LogIndex = newFlipKick.LogIndex + 1
|
||||||
err := flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{newFlipKick})
|
err := flipKickRepository.Create(headerId, []interface{}{newFlipKick})
|
||||||
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("deletes the flip_kick records if its corresponding header record is deleted", func() {
|
It("deletes the flip_kick records if its corresponding header record is deleted", func() {
|
||||||
err := flipKickRepository.Create(headerId, []flip_kick.FlipKickModel{flipKick})
|
err := flipKickRepository.Create(headerId, []interface{}{flipKick})
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
assertDBRecordCount(db, "maker.flip_kick", 1)
|
assertDBRecordCount(db, "maker.flip_kick", 1)
|
||||||
assertDBRecordCount(db, "headers", 1)
|
assertDBRecordCount(db, "headers", 1)
|
||||||
@ -124,6 +125,13 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
assertDBRecordCount(db, "headers", 0)
|
assertDBRecordCount(db, "headers", 0)
|
||||||
assertDBRecordCount(db, "maker.flip_kick", 0)
|
assertDBRecordCount(db, "maker.flip_kick", 0)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("returns an error if the wrong model type is passed in", func() {
|
||||||
|
err := flipKickRepository.Create(headerId, []interface{}{test_data.WrongModel{}})
|
||||||
|
|
||||||
|
Expect(err).To(HaveOccurred())
|
||||||
|
Expect(err.Error()).To(ContainSubstring("model of type"))
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
Describe("MarkHeaderChecked", func() {
|
Describe("MarkHeaderChecked", func() {
|
||||||
@ -164,7 +172,8 @@ var _ = Describe("FlipKick Repository", func() {
|
|||||||
ClientName: "Geth/v1.7.2-stable-1db4ecdc/darwin-amd64/go1.9",
|
ClientName: "Geth/v1.7.2-stable-1db4ecdc/darwin-amd64/go1.9",
|
||||||
}
|
}
|
||||||
db2 = test_config.NewTestDB(node2)
|
db2 = test_config.NewTestDB(node2)
|
||||||
flipKickRepository2 = flip_kick.FlipKickRepository{DB: db2}
|
flipKickRepository2 = flip_kick.FlipKickRepository{}
|
||||||
|
flipKickRepository2.SetDB(db2)
|
||||||
createHeader(db2, blockNumber)
|
createHeader(db2, blockNumber)
|
||||||
|
|
||||||
_, err := db2.Exec(`DELETE from maker.flip_kick;`)
|
_, err := db2.Exec(`DELETE from maker.flip_kick;`)
|
||||||
|
@ -1,131 +0,0 @@
|
|||||||
// Copyright 2018 Vulcanize
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package flip_kick
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"log"
|
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
|
||||||
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
|
||||||
)
|
|
||||||
|
|
||||||
type FlipKickTransformer struct {
|
|
||||||
Fetcher shared.LogFetcher
|
|
||||||
Converter Converter
|
|
||||||
Repository Repository
|
|
||||||
Config shared.TransformerConfig
|
|
||||||
}
|
|
||||||
|
|
||||||
type FlipKickTransformerInitializer struct {
|
|
||||||
Config shared.TransformerConfig
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i FlipKickTransformerInitializer) NewFlipKickTransformer(db *postgres.DB, blockChain core.BlockChain) shared.Transformer {
|
|
||||||
fetcher := shared.NewFetcher(blockChain)
|
|
||||||
repository := NewFlipKickRepository(db)
|
|
||||||
transformer := FlipKickTransformer{
|
|
||||||
Fetcher: fetcher,
|
|
||||||
Repository: repository,
|
|
||||||
Converter: FlipKickConverter{},
|
|
||||||
Config: i.Config,
|
|
||||||
}
|
|
||||||
|
|
||||||
return transformer
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fkt *FlipKickTransformer) SetConfig(config shared.TransformerConfig) {
|
|
||||||
fkt.Config = config
|
|
||||||
}
|
|
||||||
|
|
||||||
const (
|
|
||||||
FetcherError = "Error fetching FlipKick log events for block number %d: %s"
|
|
||||||
LogToEntityError = "Error converting eth log to FlipKick entity for block number %d: %s"
|
|
||||||
EntityToModelError = "Error converting eth log to FlipKick entity for block number %d: %s"
|
|
||||||
RepositoryError = "Error creating flip_kick record for block number %d: %s"
|
|
||||||
TransformerError = "There has been %d error(s) transforming FlipKick event logs, see the logs for more details."
|
|
||||||
)
|
|
||||||
|
|
||||||
type transformerError struct {
|
|
||||||
err string
|
|
||||||
blockNumber int64
|
|
||||||
msg string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (te *transformerError) Error() string {
|
|
||||||
return fmt.Sprintf(te.msg, te.blockNumber, te.err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func newTransformerError(err error, blockNumber int64, msg string) error {
|
|
||||||
e := transformerError{err.Error(), blockNumber, msg}
|
|
||||||
log.Println(e.Error())
|
|
||||||
return &e
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fkt FlipKickTransformer) Execute() error {
|
|
||||||
config := fkt.Config
|
|
||||||
topics := [][]common.Hash{{common.HexToHash(shared.FlipKickSignature)}}
|
|
||||||
|
|
||||||
headers, err := fkt.Repository.MissingHeaders(config.StartingBlockNumber, config.EndingBlockNumber)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("Error:", err)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
log.Printf("Fetching flip kick event logs for %d headers \n", len(headers))
|
|
||||||
var resultingErrors []error
|
|
||||||
for _, header := range headers {
|
|
||||||
ethLogs, err := fkt.Fetcher.FetchLogs(config.ContractAddresses, topics, header.BlockNumber)
|
|
||||||
if err != nil {
|
|
||||||
resultingErrors = append(resultingErrors, newTransformerError(err, header.BlockNumber, FetcherError))
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(ethLogs) < 1 {
|
|
||||||
err := fkt.Repository.MarkHeaderChecked(header.Id)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
entities, err := fkt.Converter.ToEntities(config.ContractAbi, ethLogs)
|
|
||||||
if err != nil {
|
|
||||||
resultingErrors = append(resultingErrors, newTransformerError(err, header.BlockNumber, LogToEntityError))
|
|
||||||
}
|
|
||||||
models, err := fkt.Converter.ToModels(entities)
|
|
||||||
if err != nil {
|
|
||||||
resultingErrors = append(resultingErrors, newTransformerError(err, header.BlockNumber, EntityToModelError))
|
|
||||||
}
|
|
||||||
|
|
||||||
err = fkt.Repository.Create(header.Id, models)
|
|
||||||
if err != nil {
|
|
||||||
resultingErrors = append(resultingErrors, newTransformerError(err, header.BlockNumber, RepositoryError))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(resultingErrors) > 0 {
|
|
||||||
for _, err := range resultingErrors {
|
|
||||||
log.Println(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
msg := fmt.Sprintf(TransformerError, len(resultingErrors))
|
|
||||||
return errors.New(msg)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
@ -15,59 +15,57 @@
|
|||||||
package flip_kick_test
|
package flip_kick_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"math/rand"
|
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"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"
|
||||||
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/core"
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/factories"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/mocks"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/mocks"
|
||||||
flip_kick_mocks "github.com/vulcanize/vulcanizedb/pkg/transformers/test_data/mocks/flip_kick"
|
"math/rand"
|
||||||
)
|
)
|
||||||
|
|
||||||
var _ = Describe("FlipKick Transformer", func() {
|
var _ = Describe("FlipKick Transformer", func() {
|
||||||
var transformer flip_kick.FlipKickTransformer
|
var (
|
||||||
var fetcher mocks.MockLogFetcher
|
transformer shared.Transformer
|
||||||
var converter flip_kick_mocks.MockFlipKickConverter
|
fetcher mocks.MockLogFetcher
|
||||||
var repository flip_kick_mocks.MockFlipKickRepository
|
converter mocks.MockConverter
|
||||||
var blockNumber int64
|
repository mocks.MockRepository
|
||||||
var headerId int64
|
blockNumber int64
|
||||||
var headers []core.Header
|
headerId int64
|
||||||
var logs []types.Log
|
headers []core.Header
|
||||||
|
logs []types.Log
|
||||||
|
config = flip_kick.FlipKickConfig
|
||||||
|
)
|
||||||
|
|
||||||
BeforeEach(func() {
|
BeforeEach(func() {
|
||||||
fetcher = mocks.MockLogFetcher{}
|
fetcher = mocks.MockLogFetcher{}
|
||||||
converter = flip_kick_mocks.MockFlipKickConverter{}
|
converter = mocks.MockConverter{}
|
||||||
repository = flip_kick_mocks.MockFlipKickRepository{}
|
repository = mocks.MockRepository{}
|
||||||
transformer = flip_kick.FlipKickTransformer{
|
transformer = factories.Transformer{
|
||||||
Fetcher: &fetcher,
|
Fetcher: &fetcher,
|
||||||
Converter: &converter,
|
Converter: &converter,
|
||||||
Repository: &repository,
|
Repository: &repository,
|
||||||
|
Config: config,
|
||||||
}
|
}
|
||||||
transformer.SetConfig(flip_kick.FlipKickConfig)
|
|
||||||
|
|
||||||
blockNumber = rand.Int63()
|
blockNumber = rand.Int63()
|
||||||
headerId = rand.Int63()
|
headerId = rand.Int63()
|
||||||
|
logs = []types.Log{test_data.EthFlipKickLog}
|
||||||
headers = []core.Header{{
|
headers = []core.Header{{
|
||||||
Id: headerId,
|
Id: headerId,
|
||||||
BlockNumber: blockNumber,
|
BlockNumber: blockNumber,
|
||||||
Hash: "0x",
|
Hash: "0x",
|
||||||
Raw: nil,
|
Raw: nil,
|
||||||
}}
|
}}
|
||||||
|
|
||||||
repository.SetHeadersToReturn(headers)
|
|
||||||
|
|
||||||
logs = []types.Log{test_data.EthFlipKickLog}
|
|
||||||
fetcher.SetFetchedLogs(logs)
|
|
||||||
})
|
})
|
||||||
|
|
||||||
It("fetches logs with the configured contract and topic(s) for each block", func() {
|
It("fetches logs with the configured contract and topic(s) for each block", func() {
|
||||||
|
repository.SetMissingHeaders(headers)
|
||||||
expectedTopics := [][]common.Hash{{common.HexToHash(shared.FlipKickSignature)}}
|
expectedTopics := [][]common.Hash{{common.HexToHash(shared.FlipKickSignature)}}
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
@ -79,42 +77,26 @@ var _ = Describe("FlipKick Transformer", func() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
It("returns an error if the fetcher fails", func() {
|
It("returns an error if the fetcher fails", func() {
|
||||||
|
repository.SetMissingHeaders(headers)
|
||||||
fetcher.SetFetcherError(fakes.FakeError)
|
fetcher.SetFetcherError(fakes.FakeError)
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
Expect(err).To(HaveOccurred())
|
Expect(err).To(HaveOccurred())
|
||||||
Expect(err.Error()).To(ContainSubstring("error(s) transforming FlipKick event logs"))
|
Expect(err.Error()).To(ContainSubstring("failed"))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("marks header checked if no logs returned", func() {
|
It("marks header checked if no logs returned", func() {
|
||||||
mockConverter := &flip_kick_mocks.MockFlipKickConverter{}
|
repository.SetMissingHeaders([]core.Header{{Id: headerId}})
|
||||||
mockRepository := &flip_kick_mocks.MockFlipKickRepository{}
|
|
||||||
headerID := int64(123)
|
|
||||||
mockRepository.SetHeadersToReturn([]core.Header{{Id: headerID}})
|
|
||||||
mockFetcher := &mocks.MockLogFetcher{}
|
|
||||||
transformer := flip_kick.FlipKickTransformer{
|
|
||||||
Converter: mockConverter,
|
|
||||||
Fetcher: mockFetcher,
|
|
||||||
Repository: mockRepository,
|
|
||||||
}
|
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
|
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
mockRepository.AssertMarkHeaderCheckedCalledWith(headerID)
|
repository.AssertMarkHeaderCheckedCalledWith(headerId)
|
||||||
})
|
})
|
||||||
|
|
||||||
It("returns error if marking header checked returns err", func() {
|
It("returns error if marking header checked returns err", func() {
|
||||||
mockConverter := &flip_kick_mocks.MockFlipKickConverter{}
|
repository.SetMissingHeaders([]core.Header{{Id: headerId}})
|
||||||
mockRepository := &flip_kick_mocks.MockFlipKickRepository{}
|
repository.SetMarkHeaderCheckedError(fakes.FakeError)
|
||||||
mockRepository.SetHeadersToReturn([]core.Header{{Id: int64(123)}})
|
|
||||||
mockRepository.SetMarkHeaderCheckedErr(fakes.FakeError)
|
|
||||||
mockFetcher := &mocks.MockLogFetcher{}
|
|
||||||
transformer := flip_kick.FlipKickTransformer{
|
|
||||||
Converter: mockConverter,
|
|
||||||
Fetcher: mockFetcher,
|
|
||||||
Repository: mockRepository,
|
|
||||||
}
|
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
|
|
||||||
@ -123,49 +105,64 @@ var _ = Describe("FlipKick Transformer", func() {
|
|||||||
})
|
})
|
||||||
|
|
||||||
It("converts the logs", func() {
|
It("converts the logs", func() {
|
||||||
err := transformer.Execute()
|
repository.SetMissingHeaders([]core.Header{{BlockNumber: 1}})
|
||||||
Expect(err).NotTo(HaveOccurred())
|
fetcher.SetFetchedLogs(logs)
|
||||||
|
|
||||||
Expect(converter.ConverterContracts).To(Equal(flip_kick.FlipKickConfig.ContractAddresses))
|
err := transformer.Execute()
|
||||||
Expect(converter.ConverterAbi).To(Equal(flip_kick.FlipKickConfig.ContractAbi))
|
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
Expect(converter.ContractAbi).To(Equal(flip_kick.FlipKickConfig.ContractAbi))
|
||||||
Expect(converter.LogsToConvert).To(Equal(logs))
|
Expect(converter.LogsToConvert).To(Equal(logs))
|
||||||
Expect(converter.EntitiesToConvert).To(Equal([]flip_kick.FlipKickEntity{test_data.FlipKickEntity}))
|
|
||||||
})
|
})
|
||||||
|
|
||||||
It("returns an error if converting the geth log fails", func() {
|
It("returns an error if converting the geth log fails", func() {
|
||||||
converter.SetConverterError(fakes.FakeError)
|
repository.SetMissingHeaders(headers)
|
||||||
|
fetcher.SetFetchedLogs(logs)
|
||||||
|
converter.ToEntitiesError = fakes.FakeError
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
|
|
||||||
Expect(err).To(HaveOccurred())
|
Expect(err).To(HaveOccurred())
|
||||||
|
Expect(err.Error()).To(ContainSubstring("failed"))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("persists a flip_kick record", func() {
|
It("persists a flip_kick record", func() {
|
||||||
err := transformer.Execute()
|
repository.SetMissingHeaders(headers)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
fetcher.SetFetchedLogs(logs)
|
||||||
|
converter.ModelsToReturn = []interface{}{test_data.FlipKickModel}
|
||||||
|
|
||||||
Expect(repository.HeaderIds).To(Equal([]int64{headerId}))
|
err := transformer.Execute()
|
||||||
Expect(repository.FlipKicksCreated).To(Equal([]flip_kick.FlipKickModel{test_data.FlipKickModel}))
|
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
Expect(repository.PassedHeaderID).To(Equal(headerId))
|
||||||
|
Expect(repository.PassedModels[0]).To(Equal(test_data.FlipKickModel))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("returns an error if persisting a record fails", func() {
|
It("returns an error if persisting a record fails", func() {
|
||||||
repository.SetCreateRecordError(fakes.FakeError)
|
repository.SetCreateError(fakes.FakeError)
|
||||||
|
repository.SetMissingHeaders(headers)
|
||||||
|
fetcher.SetFetchedLogs(logs)
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
|
|
||||||
Expect(err).To(HaveOccurred())
|
Expect(err).To(HaveOccurred())
|
||||||
|
Expect(err.Error()).To(ContainSubstring("failed"))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("returns an error if fetching missing headers fails", func() {
|
It("returns an error if fetching missing headers fails", func() {
|
||||||
repository.SetMissingHeadersError(fakes.FakeError)
|
repository.SetMissingHeadersError(fakes.FakeError)
|
||||||
|
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
|
|
||||||
Expect(err).To(HaveOccurred())
|
Expect(err).To(HaveOccurred())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("gets missing headers for blocks between the configured block number range", func() {
|
It("gets missing headers for blocks between the configured block number range", func() {
|
||||||
|
repository.SetMissingHeaders(headers)
|
||||||
err := transformer.Execute()
|
err := transformer.Execute()
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
Expect(repository.StartingBlockNumber).To(Equal(flip_kick.FlipKickConfig.StartingBlockNumber))
|
Expect(repository.PassedStartingBlockNumber).To(Equal(flip_kick.FlipKickConfig.StartingBlockNumber))
|
||||||
Expect(repository.EndingBlockNumber).To(Equal(flip_kick.FlipKickConfig.EndingBlockNumber))
|
Expect(repository.PassedEndingBlockNumber).To(Equal(flip_kick.FlipKickConfig.EndingBlockNumber))
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -18,12 +18,41 @@ import (
|
|||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
|
|
||||||
|
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
||||||
|
"github.com/ethereum/go-ethereum/common"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/geth"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/factories"
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
||||||
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data"
|
||||||
"github.com/vulcanize/vulcanizedb/test_config"
|
"github.com/vulcanize/vulcanizedb/test_config"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var _ = Describe("FlipKick Transformer", func() {
|
var _ = Describe("FlipKick Transformer", func() {
|
||||||
|
It("unpacks an event log", func() {
|
||||||
|
address := common.HexToAddress(shared.FlipperContractAddress)
|
||||||
|
abi, err := geth.ParseAbi(shared.FlipperABI)
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
|
contract := bind.NewBoundContract(address, abi, nil, nil, nil)
|
||||||
|
entity := &flip_kick.FlipKickEntity{}
|
||||||
|
|
||||||
|
var eventLog = test_data.EthFlipKickLog
|
||||||
|
|
||||||
|
err = contract.UnpackLog(entity, "Kick", eventLog)
|
||||||
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
|
expectedEntity := test_data.FlipKickEntity
|
||||||
|
Expect(entity.Id).To(Equal(expectedEntity.Id))
|
||||||
|
Expect(entity.Lot).To(Equal(expectedEntity.Lot))
|
||||||
|
Expect(entity.Bid).To(Equal(expectedEntity.Bid))
|
||||||
|
Expect(entity.Gal).To(Equal(expectedEntity.Gal))
|
||||||
|
Expect(entity.End).To(Equal(expectedEntity.End))
|
||||||
|
Expect(entity.Urn).To(Equal(expectedEntity.Urn))
|
||||||
|
Expect(entity.Tab).To(Equal(expectedEntity.Tab))
|
||||||
|
})
|
||||||
|
|
||||||
It("fetches and transforms a FlipKick event from Kovan chain", func() {
|
It("fetches and transforms a FlipKick event from Kovan chain", func() {
|
||||||
blockNumber := int64(8956476)
|
blockNumber := int64(8956476)
|
||||||
config := flip_kick.FlipKickConfig
|
config := flip_kick.FlipKickConfig
|
||||||
@ -41,8 +70,13 @@ var _ = Describe("FlipKick Transformer", func() {
|
|||||||
err = persistHeader(db, blockNumber)
|
err = persistHeader(db, blockNumber)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
initializer := flip_kick.FlipKickTransformerInitializer{Config: config}
|
initializer := factories.Transformer{
|
||||||
transformer := initializer.NewFlipKickTransformer(db, blockchain)
|
Config: flip_kick.FlipKickConfig,
|
||||||
|
Converter: &flip_kick.FlipKickConverter{},
|
||||||
|
Repository: &flip_kick.FlipKickRepository{},
|
||||||
|
Fetcher: &shared.Fetcher{},
|
||||||
|
}
|
||||||
|
transformer := initializer.NewTransformer(db, blockchain)
|
||||||
err = transformer.Execute()
|
err = transformer.Execute()
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
|
|
||||||
|
@ -1,48 +0,0 @@
|
|||||||
// Copyright 2018 Vulcanize
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package flip_kick
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/ethereum/go-ethereum/core/types"
|
|
||||||
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/test_data"
|
|
||||||
)
|
|
||||||
|
|
||||||
type MockFlipKickConverter struct {
|
|
||||||
ConverterContracts []string
|
|
||||||
ConverterAbi string
|
|
||||||
LogsToConvert []types.Log
|
|
||||||
EntitiesToConvert []flip_kick.FlipKickEntity
|
|
||||||
ConverterError error
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkc *MockFlipKickConverter) ToEntities(contractAbi string, ethLogs []types.Log) ([]flip_kick.FlipKickEntity, error) {
|
|
||||||
for _, log := range ethLogs {
|
|
||||||
mfkc.ConverterContracts = append(mfkc.ConverterContracts, log.Address.Hex())
|
|
||||||
}
|
|
||||||
mfkc.ConverterAbi = contractAbi
|
|
||||||
mfkc.LogsToConvert = append(mfkc.LogsToConvert, ethLogs...)
|
|
||||||
return []flip_kick.FlipKickEntity{test_data.FlipKickEntity}, mfkc.ConverterError
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkc *MockFlipKickConverter) ToModels(flipKickEntities []flip_kick.FlipKickEntity) ([]flip_kick.FlipKickModel, error) {
|
|
||||||
mfkc.EntitiesToConvert = append(mfkc.EntitiesToConvert, flipKickEntities...)
|
|
||||||
return []flip_kick.FlipKickModel{test_data.FlipKickModel}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkc *MockFlipKickConverter) SetConverterError(err error) {
|
|
||||||
mfkc.ConverterError = err
|
|
||||||
}
|
|
@ -1,73 +0,0 @@
|
|||||||
// Copyright 2018 Vulcanize
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package flip_kick
|
|
||||||
|
|
||||||
import (
|
|
||||||
. "github.com/onsi/gomega"
|
|
||||||
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
||||||
"github.com/vulcanize/vulcanizedb/pkg/transformers/flip_kick"
|
|
||||||
)
|
|
||||||
|
|
||||||
type MockFlipKickRepository struct {
|
|
||||||
CreateRecordError error
|
|
||||||
EndingBlockNumber int64
|
|
||||||
FlipKicksCreated []flip_kick.FlipKickModel
|
|
||||||
HeaderIds []int64
|
|
||||||
HeadersToReturn []core.Header
|
|
||||||
MissingHeadersError error
|
|
||||||
StartingBlockNumber int64
|
|
||||||
markHeaderCheckedErr error
|
|
||||||
markHeaderCheckedPassedHeaderId int64
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) Create(headerId int64, flipKick []flip_kick.FlipKickModel) error {
|
|
||||||
mfkr.HeaderIds = append(mfkr.HeaderIds, headerId)
|
|
||||||
mfkr.FlipKicksCreated = append(mfkr.FlipKicksCreated, flipKick...)
|
|
||||||
|
|
||||||
return mfkr.CreateRecordError
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) MarkHeaderChecked(headerId int64) error {
|
|
||||||
mfkr.markHeaderCheckedPassedHeaderId = headerId
|
|
||||||
return mfkr.markHeaderCheckedErr
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) MissingHeaders(startingBlockNumber, endingBlockNumber int64) ([]core.Header, error) {
|
|
||||||
mfkr.StartingBlockNumber = startingBlockNumber
|
|
||||||
mfkr.EndingBlockNumber = endingBlockNumber
|
|
||||||
|
|
||||||
return mfkr.HeadersToReturn, mfkr.MissingHeadersError
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) SetHeadersToReturn(headers []core.Header) {
|
|
||||||
mfkr.HeadersToReturn = headers
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) SetCreateRecordError(err error) {
|
|
||||||
mfkr.CreateRecordError = err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) SetMarkHeaderCheckedErr(err error) {
|
|
||||||
mfkr.markHeaderCheckedErr = err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) SetMissingHeadersError(err error) {
|
|
||||||
mfkr.MissingHeadersError = err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mfkr *MockFlipKickRepository) AssertMarkHeaderCheckedCalledWith(headerId int64) {
|
|
||||||
Expect(mfkr.markHeaderCheckedPassedHeaderId).To(Equal(headerId))
|
|
||||||
}
|
|
@ -118,8 +118,14 @@ var (
|
|||||||
Fetcher: &shared.Fetcher{},
|
Fetcher: &shared.Fetcher{},
|
||||||
}.NewLogNoteTransformer
|
}.NewLogNoteTransformer
|
||||||
|
|
||||||
FlipKickTransformerInitializer = flip_kick.FlipKickTransformerInitializer{Config: flip_kick.FlipKickConfig}.NewFlipKickTransformer
|
FlipKickTransformerInitializer = factories.Transformer{
|
||||||
FlogTransformerInitializer = factories.LogNoteTransformer{
|
Config: flip_kick.FlipKickConfig,
|
||||||
|
Converter: &flip_kick.FlipKickConverter{},
|
||||||
|
Repository: &flip_kick.FlipKickRepository{},
|
||||||
|
Fetcher: &shared.Fetcher{},
|
||||||
|
}.NewTransformer
|
||||||
|
|
||||||
|
FlogTransformerInitializer = factories.LogNoteTransformer{
|
||||||
Config: vow_flog.VowFlogConfig,
|
Config: vow_flog.VowFlogConfig,
|
||||||
Converter: &vow_flog.VowFlogConverter{},
|
Converter: &vow_flog.VowFlogConverter{},
|
||||||
Repository: &vow_flog.VowFlogRepository{},
|
Repository: &vow_flog.VowFlogRepository{},
|
||||||
|
Loading…
Reference in New Issue
Block a user