2019-01-24 20:41:30 +00:00
|
|
|
// VulcanizeDB
|
2019-03-12 15:46:42 +00:00
|
|
|
// Copyright © 2019 Vulcanize
|
2019-01-24 20:41:30 +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/>.
|
2018-08-07 15:51:34 +00:00
|
|
|
|
2019-01-31 23:14:42 +00:00
|
|
|
package fetcher_test
|
2018-08-07 15:51:34 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ethereum/go-ethereum"
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
|
2019-04-24 20:05:57 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/libraries/shared/fetcher"
|
2018-11-21 15:30:00 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
2018-08-07 15:51:34 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/fakes"
|
|
|
|
)
|
|
|
|
|
2019-04-24 20:05:57 +00:00
|
|
|
var _ = Describe("LogFetcher", func() {
|
2018-08-07 15:51:34 +00:00
|
|
|
Describe("FetchLogs", func() {
|
|
|
|
It("fetches logs based on the given query", func() {
|
2018-08-09 21:55:02 +00:00
|
|
|
blockChain := fakes.NewMockBlockChain()
|
2019-04-24 20:05:57 +00:00
|
|
|
logFetcher := fetcher.NewLogFetcher(blockChain)
|
2018-11-21 15:30:00 +00:00
|
|
|
header := fakes.FakeHeader
|
|
|
|
|
2018-12-04 15:04:13 +00:00
|
|
|
addresses := []common.Address{
|
|
|
|
common.HexToAddress("0xfakeAddress"),
|
|
|
|
common.HexToAddress("0xanotherFakeAddress"),
|
|
|
|
}
|
|
|
|
|
|
|
|
topicZeros := []common.Hash{common.BytesToHash([]byte{1, 2, 3, 4, 5})}
|
2018-08-09 21:55:02 +00:00
|
|
|
|
2019-04-24 20:05:57 +00:00
|
|
|
_, err := logFetcher.FetchLogs(addresses, topicZeros, header)
|
2018-08-07 15:51:34 +00:00
|
|
|
|
2018-09-27 15:12:29 +00:00
|
|
|
address1 := common.HexToAddress("0xfakeAddress")
|
|
|
|
address2 := common.HexToAddress("0xanotherFakeAddress")
|
2018-08-09 21:55:02 +00:00
|
|
|
Expect(err).NotTo(HaveOccurred())
|
2018-11-21 15:30:00 +00:00
|
|
|
|
|
|
|
blockHash := common.HexToHash(header.Hash)
|
2018-08-09 21:55:02 +00:00
|
|
|
expectedQuery := ethereum.FilterQuery{
|
2018-11-21 15:30:00 +00:00
|
|
|
BlockHash: &blockHash,
|
2018-09-27 15:12:29 +00:00
|
|
|
Addresses: []common.Address{address1, address2},
|
2018-12-04 15:04:13 +00:00
|
|
|
Topics: [][]common.Hash{topicZeros},
|
2018-08-07 15:51:34 +00:00
|
|
|
}
|
2018-08-09 21:55:02 +00:00
|
|
|
blockChain.AssertGetEthLogsWithCustomQueryCalledWith(expectedQuery)
|
2018-08-07 15:51:34 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
It("returns an error if fetching the logs fails", func() {
|
2018-08-09 21:55:02 +00:00
|
|
|
blockChain := fakes.NewMockBlockChain()
|
2018-07-24 16:38:49 +00:00
|
|
|
blockChain.SetGetEthLogsWithCustomQueryErr(fakes.FakeError)
|
2019-04-24 20:05:57 +00:00
|
|
|
logFetcher := fetcher.NewLogFetcher(blockChain)
|
2018-08-09 21:55:02 +00:00
|
|
|
|
2019-04-24 20:05:57 +00:00
|
|
|
_, err := logFetcher.FetchLogs([]common.Address{}, []common.Hash{}, core.Header{})
|
2018-08-09 21:55:02 +00:00
|
|
|
|
2018-08-07 15:51:34 +00:00
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
Expect(err).To(MatchError(fakes.FakeError))
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|