ipld-eth-server/pkg/transformers/shared/log_fetcher_test.go

69 lines
2.2 KiB
Go
Raw Normal View History

2018-08-07 15:51:34 +00:00
// 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.
2018-08-09 21:55:02 +00:00
package shared_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/pkg/core"
2018-08-07 15:51:34 +00:00
"github.com/vulcanize/vulcanizedb/pkg/fakes"
2018-08-09 21:55:02 +00:00
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
2018-08-07 15:51:34 +00:00
)
var _ = Describe("Fetcher", func() {
Describe("FetchLogs", func() {
It("fetches logs based on the given query", func() {
2018-08-09 21:55:02 +00:00
blockChain := fakes.NewMockBlockChain()
fetcher := shared.NewFetcher(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 := fetcher.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)
2018-08-09 21:55:02 +00:00
fetcher := shared.NewFetcher(blockChain)
_, err := fetcher.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))
})
})
})