187 lines
7.0 KiB
Go
187 lines
7.0 KiB
Go
// VulcanizeDB
|
|
// Copyright © 2019 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 <http://www.gnu.org/licenses/>.
|
|
|
|
package converter_test
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/common"
|
|
"github.com/ethereum/go-ethereum/core/types"
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/header/converter"
|
|
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/contract"
|
|
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/helpers"
|
|
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/helpers/test_helpers"
|
|
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/helpers/test_helpers/mocks"
|
|
)
|
|
|
|
var _ = Describe("Converter", func() {
|
|
var con *contract.Contract
|
|
var tusdWantedEvents = []string{"Transfer", "Mint"}
|
|
var ensWantedEvents = []string{"NewOwner"}
|
|
var marketPlaceWantedEvents = []string{"OrderCreated"}
|
|
var molochWantedEvents = []string{"SubmitVote"}
|
|
var err error
|
|
|
|
Describe("Update", func() {
|
|
It("Updates contract info held by the converter", func() {
|
|
con = test_helpers.SetupTusdContract(tusdWantedEvents, []string{})
|
|
c := converter.Converter{}
|
|
c.Update(con)
|
|
Expect(c.ContractInfo).To(Equal(con))
|
|
|
|
info := test_helpers.SetupTusdContract([]string{}, []string{})
|
|
c.Update(info)
|
|
Expect(c.ContractInfo).To(Equal(info))
|
|
})
|
|
})
|
|
|
|
Describe("Convert", func() {
|
|
It("Converts a watched event log to mapping of event input names to values", func() {
|
|
con = test_helpers.SetupTusdContract(tusdWantedEvents, []string{})
|
|
_, ok := con.Events["Approval"]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
event, ok := con.Events["Transfer"]
|
|
Expect(ok).To(Equal(true))
|
|
|
|
c := converter.Converter{}
|
|
c.Update(con)
|
|
logs, err := c.Convert([]types.Log{mocks.MockTransferLog1, mocks.MockTransferLog2}, event, 232)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
Expect(len(logs)).To(Equal(2))
|
|
|
|
sender1 := common.HexToAddress("0x9dd48110dcc444fdc242510c09bbbbe21a5975cac061d82f7b843bce061ba391")
|
|
sender2 := common.HexToAddress("0x000000000000000000000000000000000000000000000000000000000000af21")
|
|
value := helpers.BigFromString("1097077688018008265106216665536940668749033598146")
|
|
|
|
Expect(logs[0].Values["to"]).To(Equal(sender1.String()))
|
|
Expect(logs[0].Values["from"]).To(Equal(sender2.String()))
|
|
Expect(logs[0].Values["value"]).To(Equal(value.String()))
|
|
Expect(logs[0].ID).To(Equal(int64(232)))
|
|
Expect(logs[1].Values["to"]).To(Equal(sender2.String()))
|
|
Expect(logs[1].Values["from"]).To(Equal(sender1.String()))
|
|
Expect(logs[1].Values["value"]).To(Equal(value.String()))
|
|
Expect(logs[1].ID).To(Equal(int64(232)))
|
|
})
|
|
|
|
It("Keeps track of addresses it sees if they will be used for method polling", func() {
|
|
con = test_helpers.SetupTusdContract(tusdWantedEvents, []string{"balanceOf"})
|
|
event, ok := con.Events["Transfer"]
|
|
Expect(ok).To(Equal(true))
|
|
|
|
c := converter.Converter{}
|
|
c.Update(con)
|
|
_, err := c.Convert([]types.Log{mocks.MockTransferLog1, mocks.MockTransferLog2}, event, 232)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
b, ok := con.EmittedAddrs[common.HexToAddress("0x000000000000000000000000000000000000Af21")]
|
|
Expect(ok).To(Equal(true))
|
|
Expect(b).To(Equal(true))
|
|
|
|
b, ok = con.EmittedAddrs[common.HexToAddress("0x09BbBBE21a5975cAc061D82f7b843bCE061BA391")]
|
|
Expect(ok).To(Equal(true))
|
|
Expect(b).To(Equal(true))
|
|
|
|
_, ok = con.EmittedAddrs[common.HexToAddress("0x")]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
_, ok = con.EmittedAddrs[""]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
_, ok = con.EmittedAddrs[common.HexToAddress("0x09THISE21a5IS5cFAKE1D82fAND43bCE06MADEUP")]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
_, ok = con.EmittedHashes[common.HexToHash("0x000000000000000000000000c02aaa39b223helloa0e5c4f27ead9083c752553")]
|
|
Expect(ok).To(Equal(false))
|
|
})
|
|
|
|
It("Keeps track of hashes it sees if they will be used for method polling", func() {
|
|
con = test_helpers.SetupENSContract(ensWantedEvents, []string{"owner"})
|
|
event, ok := con.Events["NewOwner"]
|
|
Expect(ok).To(Equal(true))
|
|
|
|
c := converter.Converter{}
|
|
c.Update(con)
|
|
_, err := c.Convert([]types.Log{mocks.MockNewOwnerLog1, mocks.MockNewOwnerLog2}, event, 232)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
Expect(len(con.EmittedHashes)).To(Equal(3))
|
|
|
|
b, ok := con.EmittedHashes[common.HexToHash("0x000000000000000000000000c02aaa39b223helloa0e5c4f27ead9083c752553")]
|
|
Expect(ok).To(Equal(true))
|
|
Expect(b).To(Equal(true))
|
|
|
|
b, ok = con.EmittedHashes[common.HexToHash("0x9dd48110dcc444fdc242510c09bbbbe21a5975cac061d82f7b843bce061ba391")]
|
|
Expect(ok).To(Equal(true))
|
|
Expect(b).To(Equal(true))
|
|
|
|
b, ok = con.EmittedHashes[common.HexToHash("0x9dd48110dcc444fdc242510c09bbbbe21a5975cac061d82f7b843bce061ba400")]
|
|
Expect(ok).To(Equal(true))
|
|
Expect(b).To(Equal(true))
|
|
|
|
_, ok = con.EmittedHashes[common.HexToHash("0x9dd48thiscc444isc242510c0made03upa5975cac061dhashb843bce061ba400")]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
_, ok = con.EmittedHashes[common.HexToAddress("0x")]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
_, ok = con.EmittedHashes[""]
|
|
Expect(ok).To(Equal(false))
|
|
|
|
// Does not keep track of emitted addresses if the methods provided will not use them
|
|
_, ok = con.EmittedAddrs[common.HexToAddress("0x000000000000000000000000000000000000Af21")]
|
|
Expect(ok).To(Equal(false))
|
|
})
|
|
|
|
It("correctly parses bytes32", func() {
|
|
con = test_helpers.SetupMarketPlaceContract(marketPlaceWantedEvents, []string{})
|
|
event, ok := con.Events["OrderCreated"]
|
|
Expect(ok).To(BeTrue())
|
|
|
|
c := converter.Converter{}
|
|
c.Update(con)
|
|
result, err := c.Convert([]types.Log{mocks.MockOrderCreatedLog}, event, 232)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
Expect(len(result)).To(Equal(1))
|
|
Expect(result[0].Values["id"]).To(Equal("0x633f94affdcabe07c000231f85c752c97b9cc43966b432ec4d18641e6d178233"))
|
|
})
|
|
|
|
It("correctly parses uint8", func() {
|
|
con = test_helpers.SetupMolochContract(molochWantedEvents, []string{})
|
|
event, ok := con.Events["SubmitVote"]
|
|
Expect(ok).To(BeTrue())
|
|
|
|
c := converter.Converter{}
|
|
c.Update(con)
|
|
result, err := c.Convert([]types.Log{mocks.MockSubmitVoteLog}, event, 232)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
Expect(len(result)).To(Equal(1))
|
|
Expect(result[0].Values["uintVote"]).To(Equal("1"))
|
|
})
|
|
|
|
It("Fails with an empty contract", func() {
|
|
event := con.Events["Transfer"]
|
|
c := converter.Converter{}
|
|
c.Update(&contract.Contract{})
|
|
_, err = c.Convert([]types.Log{mocks.MockTransferLog1}, event, 232)
|
|
Expect(err).To(HaveOccurred())
|
|
})
|
|
})
|
|
})
|