// VulcanizeDB // Copyright © 2018 Vulcanize // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . package integration_tests import ( . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" "strconv" "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/bite" "github.com/vulcanize/vulcanizedb/pkg/transformers/factories" "github.com/vulcanize/vulcanizedb/pkg/transformers/shared" "github.com/vulcanize/vulcanizedb/pkg/transformers/shared/constants" "github.com/vulcanize/vulcanizedb/pkg/transformers/test_data" "github.com/vulcanize/vulcanizedb/test_config" ) var testBiteConfig = shared.TransformerConfig{ TransformerName: constants.BiteLabel, ContractAddresses: []string{test_data.KovanCatContractAddress}, ContractAbi: test_data.KovanCatABI, Topic: test_data.KovanBiteSignature, StartingBlockNumber: 0, EndingBlockNumber: -1, } var _ = Describe("Bite Transformer", func() { It("fetches and transforms a Bite event from Kovan chain", func() { blockNumber := int64(8956422) config := testBiteConfig config.StartingBlockNumber = blockNumber config.EndingBlockNumber = blockNumber rpcClient, ethClient, err := getClients(ipc) Expect(err).NotTo(HaveOccurred()) blockChain, err := getBlockChain(rpcClient, ethClient) Expect(err).NotTo(HaveOccurred()) db := test_config.NewTestDB(blockChain.Node()) test_config.CleanTestDB(db) header, err := persistHeader(db, blockNumber, blockChain) Expect(err).NotTo(HaveOccurred()) initializer := factories.Transformer{ Config: config, Converter: &bite.BiteConverter{}, Repository: &bite.BiteRepository{}, } transformer := initializer.NewTransformer(db) fetcher := shared.NewFetcher(blockChain) logs, err := fetcher.FetchLogs( []common.Address{common.HexToAddress(config.ContractAddresses[0])}, []common.Hash{common.HexToHash(config.Topic)}, header) Expect(err).NotTo(HaveOccurred()) err = transformer.Execute(logs, header, constants.HeaderMissing) Expect(err).NotTo(HaveOccurred()) var dbResult []bite.BiteModel err = db.Select(&dbResult, `SELECT art, iart, ilk, ink, nflip, tab, urn from maker.bite`) Expect(err).NotTo(HaveOccurred()) Expect(len(dbResult)).To(Equal(1)) Expect(dbResult[0].Art).To(Equal("149846666666666655744")) Expect(dbResult[0].IArt).To(Equal("1645356666666666655736")) ilkID, err := shared.GetOrCreateIlk("4554480000000000000000000000000000000000000000000000000000000000", db) Expect(err).NotTo(HaveOccurred()) Expect(dbResult[0].Ilk).To(Equal(strconv.Itoa(ilkID))) Expect(dbResult[0].Ink).To(Equal("1000000000000000000")) Expect(dbResult[0].NFlip).To(Equal("2")) Expect(dbResult[0].Tab).To(Equal("149846666666666655744")) Expect(dbResult[0].Urn).To(Equal("0000000000000000000000000000d8b4147eda80fec7122ae16da2479cbd7ffb")) }) It("unpacks an event log", func() { address := common.HexToAddress(test_data.KovanCatContractAddress) abi, err := geth.ParseAbi(test_data.KovanCatABI) Expect(err).NotTo(HaveOccurred()) contract := bind.NewBoundContract(address, abi, nil, nil, nil) entity := &bite.BiteEntity{} var eventLog = test_data.EthBiteLog err = contract.UnpackLog(entity, "Bite", eventLog) Expect(err).NotTo(HaveOccurred()) expectedEntity := test_data.BiteEntity Expect(entity.Art).To(Equal(expectedEntity.Art)) Expect(entity.Ilk).To(Equal(expectedEntity.Ilk)) Expect(entity.Ink).To(Equal(expectedEntity.Ink)) }) It("rechecks header for bite event", func() { blockNumber := int64(8956422) config := testBiteConfig config.StartingBlockNumber = blockNumber config.EndingBlockNumber = blockNumber rpcClient, ethClient, err := getClients(ipc) Expect(err).NotTo(HaveOccurred()) blockChain, err := getBlockChain(rpcClient, ethClient) Expect(err).NotTo(HaveOccurred()) db := test_config.NewTestDB(blockChain.Node()) test_config.CleanTestDB(db) header, err := persistHeader(db, blockNumber, blockChain) Expect(err).NotTo(HaveOccurred()) initializer := factories.Transformer{ Config: config, Converter: &bite.BiteConverter{}, Repository: &bite.BiteRepository{}, } transformer := initializer.NewTransformer(db) fetcher := shared.NewFetcher(blockChain) logs, err := fetcher.FetchLogs( []common.Address{common.HexToAddress(config.ContractAddresses[0])}, []common.Hash{common.HexToHash(config.Topic)}, header) Expect(err).NotTo(HaveOccurred()) err = transformer.Execute(logs, header, constants.HeaderMissing) Expect(err).NotTo(HaveOccurred()) err = transformer.Execute(logs, header, constants.HeaderRecheck) Expect(err).NotTo(HaveOccurred()) var headerID int64 err = db.Get(&headerID, `SELECT id FROM public.headers WHERE block_number = $1`, blockNumber) Expect(err).NotTo(HaveOccurred()) var biteChecked []int err = db.Select(&biteChecked, `SELECT bite_checked FROM public.checked_headers WHERE header_id = $1`, headerID) Expect(err).NotTo(HaveOccurred()) Expect(biteChecked[0]).To(Equal(2)) }) It("unpacks an event log", func() { address := common.HexToAddress(test_data.KovanCatContractAddress) abi, err := geth.ParseAbi(test_data.KovanCatABI) Expect(err).NotTo(HaveOccurred()) contract := bind.NewBoundContract(address, abi, nil, nil, nil) entity := &bite.BiteEntity{} var eventLog = test_data.EthBiteLog err = contract.UnpackLog(entity, "Bite", eventLog) Expect(err).NotTo(HaveOccurred()) expectedEntity := test_data.BiteEntity Expect(entity.Art).To(Equal(expectedEntity.Art)) Expect(entity.Ilk).To(Equal(expectedEntity.Ilk)) Expect(entity.Ink).To(Equal(expectedEntity.Ink)) }) })