2021-11-19 15:59:26 +00:00
|
|
|
package blockchain
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
testDB "github.com/prysmaticlabs/prysm/beacon-chain/db/testing"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/forkchoice/protoarray"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/state/stategen"
|
|
|
|
)
|
|
|
|
|
|
|
|
func testServiceOptsWithDB(t *testing.T) []Option {
|
|
|
|
beaconDB := testDB.SetupDB(t)
|
2022-05-22 18:37:01 +00:00
|
|
|
fcs := protoarray.New(0, 0)
|
2021-11-19 15:59:26 +00:00
|
|
|
return []Option{
|
|
|
|
WithDatabase(beaconDB),
|
|
|
|
WithStateGen(stategen.New(beaconDB)),
|
|
|
|
WithForkChoiceStore(fcs),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-12 15:25:44 +00:00
|
|
|
// WARNING: only use these opts when you are certain there are no db calls
|
2021-11-19 15:59:26 +00:00
|
|
|
// in your code path. this is a lightweight way to satisfy the stategen/beacondb
|
|
|
|
// initialization requirements w/o the overhead of db init.
|
|
|
|
func testServiceOptsNoDB() []Option {
|
|
|
|
return []Option{
|
|
|
|
withStateBalanceCache(satisfactoryStateBalanceCache()),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type mockStateByRooter struct {
|
|
|
|
state state.BeaconState
|
|
|
|
err error
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ stateByRooter = &mockStateByRooter{}
|
|
|
|
|
|
|
|
func (m mockStateByRooter) StateByRoot(_ context.Context, _ [32]byte) (state.BeaconState, error) {
|
|
|
|
return m.state, m.err
|
|
|
|
}
|
|
|
|
|
|
|
|
// returns an instance of the state balance cache that can be used
|
|
|
|
// to satisfy the requirement for one in NewService, but which will
|
|
|
|
// always return an error if used.
|
|
|
|
func satisfactoryStateBalanceCache() *stateBalanceCache {
|
|
|
|
err := errors.New("satisfactoryStateBalanceCache doesn't perform real caching")
|
|
|
|
return &stateBalanceCache{stateGen: mockStateByRooter{err: err}}
|
|
|
|
}
|