ipld-eth-server/libraries/shared/fetcher/log_fetcher_test.go

71 lines
2.3 KiB
Go
Raw Normal View History

2019-01-24 20:41:30 +00:00
// VulcanizeDB
// 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
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"
"github.com/vulcanize/vulcanizedb/libraries/shared/fetcher"
"github.com/vulcanize/vulcanizedb/pkg/core"
2018-08-07 15:51:34 +00:00
"github.com/vulcanize/vulcanizedb/pkg/fakes"
)
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()
logFetcher := fetcher.NewLogFetcher(blockChain)
header := fakes.FakeHeader
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
_, err := logFetcher.FetchLogs(addresses, topicZeros, header)
2018-08-07 15:51:34 +00:00
address1 := common.HexToAddress("0xfakeAddress")
address2 := common.HexToAddress("0xanotherFakeAddress")
2018-08-09 21:55:02 +00:00
Expect(err).NotTo(HaveOccurred())
blockHash := common.HexToHash(header.Hash)
2018-08-09 21:55:02 +00:00
expectedQuery := ethereum.FilterQuery{
BlockHash: &blockHash,
Addresses: []common.Address{address1, address2},
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)
logFetcher := fetcher.NewLogFetcher(blockChain)
2018-08-09 21:55:02 +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))
})
})
})