ba071ef13f
- Migrate various mocks of core namespaces to shared version in `fakes` pkg - Err on the side of making test doubles less sophisticated - Don't pull over mocks of namespaces that are only used in example code
41 lines
1.4 KiB
Go
41 lines
1.4 KiB
Go
package fakes
|
|
|
|
import (
|
|
. "github.com/onsi/gomega"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
)
|
|
|
|
type MockHeaderRepository struct {
|
|
createOrUpdateBlockNumbersCallCount int
|
|
createOrUpdateBlockNumbersPassedBlockNumbers []int64
|
|
missingBlockNumbers []int64
|
|
}
|
|
|
|
func NewMockHeaderRepository() *MockHeaderRepository {
|
|
return &MockHeaderRepository{}
|
|
}
|
|
|
|
func (repository *MockHeaderRepository) SetMissingBlockNumbers(blockNumbers []int64) {
|
|
repository.missingBlockNumbers = blockNumbers
|
|
}
|
|
|
|
func (repository *MockHeaderRepository) CreateOrUpdateHeader(header core.Header) (int64, error) {
|
|
repository.createOrUpdateBlockNumbersCallCount++
|
|
repository.createOrUpdateBlockNumbersPassedBlockNumbers = append(repository.createOrUpdateBlockNumbersPassedBlockNumbers, header.BlockNumber)
|
|
return 0, nil
|
|
}
|
|
|
|
func (*MockHeaderRepository) GetHeader(blockNumber int64) (core.Header, error) {
|
|
return core.Header{BlockNumber: blockNumber}, nil
|
|
}
|
|
|
|
func (repository *MockHeaderRepository) MissingBlockNumbers(startingBlockNumber, endingBlockNumber int64, nodeID string) []int64 {
|
|
return repository.missingBlockNumbers
|
|
}
|
|
|
|
func (repository *MockHeaderRepository) AssertCreateOrUpdateHeaderCallCountAndPassedBlockNumbers(times int, blockNumbers []int64) {
|
|
Expect(repository.createOrUpdateBlockNumbersCallCount).To(Equal(times))
|
|
Expect(repository.createOrUpdateBlockNumbersPassedBlockNumbers).To(Equal(blockNumbers))
|
|
}
|