From fa828cf041ea0a5a95db743a68fb288d38e57661 Mon Sep 17 00:00:00 2001 From: Rob Mulholand Date: Thu, 18 Oct 2018 14:14:41 -0500 Subject: [PATCH] Add Tend integration test --- pkg/transformers/integration_tests/tend.go | 93 ++++++++++++++++++++++ 1 file changed, 93 insertions(+) create mode 100644 pkg/transformers/integration_tests/tend.go diff --git a/pkg/transformers/integration_tests/tend.go b/pkg/transformers/integration_tests/tend.go new file mode 100644 index 00000000..bacaed03 --- /dev/null +++ b/pkg/transformers/integration_tests/tend.go @@ -0,0 +1,93 @@ +// 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 integration_tests + +import ( + . "github.com/onsi/ginkgo" + . "github.com/onsi/gomega" + + "github.com/vulcanize/vulcanizedb/pkg/transformers/tend" + "github.com/vulcanize/vulcanizedb/test_config" +) + +var _ = Describe("Tend Transformer", func() { + It("fetches and transforms a Tend event from Kovan chain", func() { + blockNumber := int64(8935601) + config := tend.TendConfig + 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) + + err = persistHeader(rpcClient, db, blockNumber) + Expect(err).NotTo(HaveOccurred()) + + initializer := tend.TendTransformerInitializer{Config: config} + transformer := initializer.NewTendTransformer(db, blockchain) + err = transformer.Execute() + Expect(err).NotTo(HaveOccurred()) + + var dbResult []tend.TendModel + err = db.Select(&dbResult, `SELECT bid, bid_id, guy, lot, tic from maker.tend`) + Expect(err).NotTo(HaveOccurred()) + + Expect(len(dbResult)).To(Equal(1)) + Expect(dbResult[0].Bid).To(Equal("4000")) + Expect(dbResult[0].BidId).To(Equal("3")) + Expect(dbResult[0].Guy).To(Equal("0x0000d8b4147eDa80Fec7122AE16DA2479Cbd7ffB")) + Expect(dbResult[0].Lot).To(Equal("1000000000000000000")) + Expect(dbResult[0].Tic).To(Equal("0")) + }) + + It("fetches and transforms a subsequent Tend event from Kovan chain for the same auction", func() { + blockNumber := int64(8935731) + config := tend.TendConfig + 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) + + err = persistHeader(rpcClient, db, blockNumber) + Expect(err).NotTo(HaveOccurred()) + + initializer := tend.TendTransformerInitializer{Config: config} + transformer := initializer.NewTendTransformer(db, blockchain) + err = transformer.Execute() + Expect(err).NotTo(HaveOccurred()) + + var dbResult []tend.TendModel + err = db.Select(&dbResult, `SELECT bid, bid_id, guy, lot, tic from maker.tend`) + Expect(err).NotTo(HaveOccurred()) + + Expect(len(dbResult)).To(Equal(1)) + Expect(dbResult[0].Bid).To(Equal("4300")) + Expect(dbResult[0].BidId).To(Equal("3")) + Expect(dbResult[0].Guy).To(Equal("0x0000d8b4147eDa80Fec7122AE16DA2479Cbd7ffB")) + Expect(dbResult[0].Lot).To(Equal("1000000000000000000")) + Expect(dbResult[0].Tic).To(Equal("0")) + }) +})