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

64 lines
2.1 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 (
"math/big"
"github.com/ethereum/go-ethereum"
"github.com/ethereum/go-ethereum/common"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
"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)
blockNumber := int64(123)
addresses := []string{"0xfakeAddress", "0xanotherFakeAddress"}
2018-08-09 21:55:02 +00:00
topicZeros := [][]common.Hash{{common.BytesToHash([]byte{1, 2, 3, 4, 5})}}
_, err := fetcher.FetchLogs(addresses, topicZeros, blockNumber)
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())
expectedQuery := ethereum.FilterQuery{
2018-08-07 15:51:34 +00:00
FromBlock: big.NewInt(blockNumber),
ToBlock: big.NewInt(blockNumber),
Addresses: []common.Address{address1, address2},
2018-08-07 15:51:34 +00:00
Topics: topicZeros,
}
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([]string{}, [][]common.Hash{}, int64(1))
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))
})
})
})