2018-11-07 21:50:43 +00:00
// VulcanizeDB
2019-03-12 15:46:42 +00:00
// Copyright © 2019 Vulcanize
2018-11-07 21:50:43 +00:00
// 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/>.
2019-03-14 21:49:27 +00:00
package integration_test
2018-11-07 21:50:43 +00:00
import (
2018-11-20 16:38:23 +00:00
"fmt"
2018-12-07 15:38:46 +00:00
"github.com/ethereum/go-ethereum/common"
2018-11-07 21:50:43 +00:00
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
2020-01-29 19:00:07 +00:00
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/constants"
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/contract"
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/helpers/test_helpers"
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/poller"
"github.com/vulcanize/vulcanizedb/pkg/eth/contract_watcher/shared/types"
"github.com/vulcanize/vulcanizedb/pkg/eth/core"
"github.com/vulcanize/vulcanizedb/pkg/eth/datastore/postgres"
2018-11-07 21:50:43 +00:00
)
var _ = Describe ( "Poller" , func ( ) {
2019-03-14 21:49:27 +00:00
var contractPoller poller . Poller
2018-11-07 21:50:43 +00:00
var con * contract . Contract
2018-11-20 16:38:23 +00:00
var db * postgres . DB
var bc core . BlockChain
2018-11-07 21:50:43 +00:00
2018-11-20 16:38:23 +00:00
AfterEach ( func ( ) {
test_helpers . TearDown ( db )
2018-11-07 21:50:43 +00:00
} )
2018-11-24 04:26:07 +00:00
Describe ( "Full sync mode" , func ( ) {
BeforeEach ( func ( ) {
db , bc = test_helpers . SetupDBandBC ( )
2019-03-14 21:49:27 +00:00
contractPoller = poller . NewPoller ( bc , db , types . FullSync )
2018-11-20 16:38:23 +00:00
} )
2018-11-24 04:26:07 +00:00
Describe ( "PollContract" , func ( ) {
2018-12-19 18:42:59 +00:00
It ( "Polls specified contract methods using contract's argument list" , func ( ) {
2018-11-24 04:26:07 +00:00
con = test_helpers . SetupTusdContract ( nil , [ ] string { "balanceOf" } )
Expect ( con . Abi ) . To ( Equal ( constants . TusdAbiString ) )
con . StartingBlock = 6707322
2018-12-07 15:38:46 +00:00
con . AddEmittedAddr ( common . HexToAddress ( "0xfE9e8709d3215310075d67E3ed32A380CCf451C8" ) , common . HexToAddress ( "0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE" ) )
2018-11-24 04:26:07 +00:00
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContract ( * con , 6707323 )
2018-11-24 04:26:07 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . BalanceOf { }
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.balanceof_method WHERE who_ = '0xfE9e8709d3215310075d67E3ed32A380CCf451C8' AND block = '6707322'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "66386309548896882859581786" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.balanceof_method WHERE who_ = '0xfE9e8709d3215310075d67E3ed32A380CCf451C8' AND block = '6707323'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "66386309548896882859581786" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.balanceof_method WHERE who_ = '0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE' AND block = '6707322'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "17982350181394112023885864" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.balanceof_method WHERE who_ = '0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE' AND block = '6707323'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "17982350181394112023885864" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
} )
2018-12-14 17:52:02 +00:00
It ( "Polls specified contract methods using contract's hash list" , func ( ) {
con = test_helpers . SetupENSContract ( nil , [ ] string { "owner" } )
Expect ( con . Abi ) . To ( Equal ( constants . ENSAbiString ) )
Expect ( len ( con . Methods ) ) . To ( Equal ( 1 ) )
con . AddEmittedHash ( common . HexToHash ( "0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae" ) , common . HexToHash ( "0x7e74a86b6e146964fb965db04dc2590516da77f720bb6759337bf5632415fd86" ) )
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContractAt ( * con , 6885877 )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . Owner { }
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.owner_method WHERE node_ = '0x7e74a86b6e146964fb965db04dc2590516da77f720bb6759337bf5632415fd86' AND block = '6885877'" , constants . EnsContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Address ) . To ( Equal ( "0x546aA2EaE2514494EeaDb7bbb35243348983C59d" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "ENS-Registry" ) )
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.owner_method WHERE node_ = '0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae' AND block = '6885877'" , constants . EnsContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Address ) . To ( Equal ( "0x6090A6e47849629b7245Dfa1Ca21D94cd15878Ef" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "ENS-Registry" ) )
} )
2018-11-24 04:26:07 +00:00
It ( "Does not poll and persist any methods if none are specified" , func ( ) {
con = test_helpers . SetupTusdContract ( nil , nil )
Expect ( con . Abi ) . To ( Equal ( constants . TusdAbiString ) )
con . StartingBlock = 6707322
2018-12-07 15:38:46 +00:00
con . AddEmittedAddr ( common . HexToAddress ( "0xfE9e8709d3215310075d67E3ed32A380CCf451C8" ) , common . HexToAddress ( "0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE" ) )
2018-11-24 04:26:07 +00:00
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContract ( * con , 6707323 )
2018-11-24 04:26:07 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . BalanceOf { }
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM full_%s.balanceof_method WHERE who_ = '0xfE9e8709d3215310075d67E3ed32A380CCf451C8' AND block = '6707322'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
Expect ( err ) . To ( HaveOccurred ( ) )
} )
2018-11-07 21:50:43 +00:00
} )
2018-12-19 18:42:59 +00:00
Describe ( "FetchContractData" , func ( ) {
It ( "Calls a single contract method" , func ( ) {
2018-11-24 04:26:07 +00:00
var name = new ( string )
2019-03-14 21:49:27 +00:00
err := contractPoller . FetchContractData ( constants . TusdAbiString , constants . TusdContractAddress , "name" , nil , & name , 6197514 )
2018-11-24 04:26:07 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( * name ) . To ( Equal ( "TrueUSD" ) )
} )
2018-11-07 21:50:43 +00:00
} )
} )
2018-12-14 17:52:02 +00:00
2019-05-01 06:02:30 +00:00
Describe ( "Header sync mode" , func ( ) {
2018-12-14 17:52:02 +00:00
BeforeEach ( func ( ) {
db , bc = test_helpers . SetupDBandBC ( )
2019-05-01 06:02:30 +00:00
contractPoller = poller . NewPoller ( bc , db , types . HeaderSync )
2018-12-14 17:52:02 +00:00
} )
Describe ( "PollContract" , func ( ) {
It ( "Polls specified contract methods using contract's token holder address list" , func ( ) {
con = test_helpers . SetupTusdContract ( nil , [ ] string { "balanceOf" } )
Expect ( con . Abi ) . To ( Equal ( constants . TusdAbiString ) )
con . StartingBlock = 6707322
con . AddEmittedAddr ( common . HexToAddress ( "0xfE9e8709d3215310075d67E3ed32A380CCf451C8" ) , common . HexToAddress ( "0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE" ) )
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContract ( * con , 6707323 )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . BalanceOf { }
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.balanceof_method WHERE who_ = '0xfE9e8709d3215310075d67E3ed32A380CCf451C8' AND block = '6707322'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "66386309548896882859581786" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.balanceof_method WHERE who_ = '0xfE9e8709d3215310075d67E3ed32A380CCf451C8' AND block = '6707323'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "66386309548896882859581786" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.balanceof_method WHERE who_ = '0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE' AND block = '6707322'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "17982350181394112023885864" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.balanceof_method WHERE who_ = '0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE' AND block = '6707323'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Balance ) . To ( Equal ( "17982350181394112023885864" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "TrueUSD" ) )
} )
It ( "Polls specified contract methods using contract's hash list" , func ( ) {
con = test_helpers . SetupENSContract ( nil , [ ] string { "owner" } )
Expect ( con . Abi ) . To ( Equal ( constants . ENSAbiString ) )
Expect ( len ( con . Methods ) ) . To ( Equal ( 1 ) )
con . AddEmittedHash ( common . HexToHash ( "0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae" ) , common . HexToHash ( "0x7e74a86b6e146964fb965db04dc2590516da77f720bb6759337bf5632415fd86" ) )
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContractAt ( * con , 6885877 )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . Owner { }
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.owner_method WHERE node_ = '0x7e74a86b6e146964fb965db04dc2590516da77f720bb6759337bf5632415fd86' AND block = '6885877'" , constants . EnsContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Address ) . To ( Equal ( "0x546aA2EaE2514494EeaDb7bbb35243348983C59d" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "ENS-Registry" ) )
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.owner_method WHERE node_ = '0x93cdeb708b7545dc668eb9280176169d1c33cfd8ed6f04690a0bcc88a93fc4ae' AND block = '6885877'" , constants . EnsContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Address ) . To ( Equal ( "0x6090A6e47849629b7245Dfa1Ca21D94cd15878Ef" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "ENS-Registry" ) )
} )
It ( "Does not poll and persist any methods if none are specified" , func ( ) {
con = test_helpers . SetupTusdContract ( nil , nil )
Expect ( con . Abi ) . To ( Equal ( constants . TusdAbiString ) )
con . StartingBlock = 6707322
con . AddEmittedAddr ( common . HexToAddress ( "0xfE9e8709d3215310075d67E3ed32A380CCf451C8" ) , common . HexToAddress ( "0x3f5CE5FBFe3E9af3971dD833D26bA9b5C936f0bE" ) )
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContract ( * con , 6707323 )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . BalanceOf { }
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.balanceof_method WHERE who_ = '0xfE9e8709d3215310075d67E3ed32A380CCf451C8' AND block = '6707322'" , constants . TusdContractAddress ) ) . StructScan ( & scanStruct )
2018-12-14 17:52:02 +00:00
Expect ( err ) . To ( HaveOccurred ( ) )
} )
2018-12-19 18:42:59 +00:00
It ( "Caches returned values of the appropriate types for downstream method polling if method piping is turned on" , func ( ) {
con = test_helpers . SetupENSContract ( nil , [ ] string { "resolver" } )
Expect ( con . Abi ) . To ( Equal ( constants . ENSAbiString ) )
con . StartingBlock = 6921967
con . EmittedAddrs = map [ interface { } ] bool { }
con . Piping = false
con . AddEmittedHash ( common . HexToHash ( "0x495b6e6efdedb750aa519919b5cf282bdaa86067b82a2293a3ff5723527141e8" ) )
2019-03-14 21:49:27 +00:00
err := contractPoller . PollContract ( * con , 6921968 )
2018-12-19 18:42:59 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
scanStruct := test_helpers . Resolver { }
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.resolver_method WHERE node_ = '0x495b6e6efdedb750aa519919b5cf282bdaa86067b82a2293a3ff5723527141e8' AND block = '6921967'" , constants . EnsContractAddress ) ) . StructScan ( & scanStruct )
2018-12-19 18:42:59 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Address ) . To ( Equal ( "0x5FfC014343cd971B7eb70732021E26C35B744cc4" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "ENS-Registry" ) )
Expect ( len ( con . EmittedAddrs ) ) . To ( Equal ( 0 ) ) // With piping off the address is not saved
test_helpers . TearDown ( db )
db , bc = test_helpers . SetupDBandBC ( )
2019-05-01 06:02:30 +00:00
contractPoller = poller . NewPoller ( bc , db , types . HeaderSync )
2018-12-19 18:42:59 +00:00
con . Piping = true
2019-03-14 21:49:27 +00:00
err = contractPoller . PollContract ( * con , 6921968 )
2018-12-19 18:42:59 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
2019-05-01 06:02:30 +00:00
err = db . QueryRowx ( fmt . Sprintf ( "SELECT * FROM header_%s.resolver_method WHERE node_ = '0x495b6e6efdedb750aa519919b5cf282bdaa86067b82a2293a3ff5723527141e8' AND block = '6921967'" , constants . EnsContractAddress ) ) . StructScan ( & scanStruct )
2018-12-19 18:42:59 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( scanStruct . Address ) . To ( Equal ( "0x5FfC014343cd971B7eb70732021E26C35B744cc4" ) )
Expect ( scanStruct . TokenName ) . To ( Equal ( "ENS-Registry" ) )
Expect ( len ( con . EmittedAddrs ) ) . To ( Equal ( 1 ) ) // With piping on it is saved
Expect ( con . EmittedAddrs [ common . HexToAddress ( "0x5FfC014343cd971B7eb70732021E26C35B744cc4" ) ] ) . To ( Equal ( true ) )
} )
2018-12-14 17:52:02 +00:00
} )
2018-12-19 18:42:59 +00:00
Describe ( "FetchContractData" , func ( ) {
It ( "Calls a single contract method" , func ( ) {
2018-12-14 17:52:02 +00:00
var name = new ( string )
2019-03-14 21:49:27 +00:00
err := contractPoller . FetchContractData ( constants . TusdAbiString , constants . TusdContractAddress , "name" , nil , & name , 6197514 )
2018-12-14 17:52:02 +00:00
Expect ( err ) . ToNot ( HaveOccurred ( ) )
Expect ( * name ) . To ( Equal ( "TrueUSD" ) )
} )
} )
} )
2018-11-07 21:50:43 +00:00
} )