* greedy approach to lane verification * docs * base lane testing * mev lane testing nits * abci top level testing done * network spamming in E2E * removing logs from testing * nit
36 lines
1.3 KiB
Go
36 lines
1.3 KiB
Go
package block
|
|
|
|
import (
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
"github.com/skip-mev/block-sdk/block/proposals"
|
|
)
|
|
|
|
type (
|
|
// PrepareLanesHandler wraps all of the lanes' PrepareLane function into a single chained
|
|
// function. You can think of it like an AnteHandler, but for preparing proposals in the
|
|
// context of lanes instead of modules.
|
|
PrepareLanesHandler func(ctx sdk.Context, proposal proposals.Proposal) (proposals.Proposal, error)
|
|
|
|
// ProcessLanesHandler wraps all of the lanes' ProcessLane functions into a single chained
|
|
// function. You can think of it like an AnteHandler, but for processing proposals in the
|
|
// context of lanes instead of modules.
|
|
ProcessLanesHandler func(ctx sdk.Context, proposal proposals.Proposal, txs []sdk.Tx) (proposals.Proposal, error)
|
|
)
|
|
|
|
// NoOpPrepareLanesHandler returns a no-op prepare lanes handler.
|
|
// This should only be used for testing.
|
|
func NoOpPrepareLanesHandler() PrepareLanesHandler {
|
|
return func(ctx sdk.Context, proposal proposals.Proposal) (proposals.Proposal, error) {
|
|
return proposal, nil
|
|
}
|
|
}
|
|
|
|
// NoOpProcessLanesHandler returns a no-op process lanes handler.
|
|
// This should only be used for testing.
|
|
func NoOpProcessLanesHandler() ProcessLanesHandler {
|
|
return func(_ sdk.Context, p proposals.Proposal, _ []sdk.Tx) (proposals.Proposal, error) {
|
|
return p, nil
|
|
}
|
|
}
|