Require BeginBlock for NewContext

This commit is contained in:
Jae Kwon 2018-01-24 12:11:14 -08:00
parent a5fa1874c5
commit ac7fa3f59f
2 changed files with 18 additions and 7 deletions

View File

@ -50,7 +50,7 @@ type BaseApp struct {
msDeliver sdk.CacheMultiStore msDeliver sdk.CacheMultiStore
// Current block header // Current block header
header abci.Header header *abci.Header
// Cached validator changes from DeliverTx. // Cached validator changes from DeliverTx.
valUpdates []abci.Validator valUpdates []abci.Validator
@ -155,9 +155,9 @@ func (app *BaseApp) LastBlockHeight() int64 {
// Initializes the remaining logic from app.ms. // Initializes the remaining logic from app.ms.
func (app *BaseApp) initFromStore(mainKey sdk.StoreKey) error { func (app *BaseApp) initFromStore(mainKey sdk.StoreKey) error {
lastCommitID := app.ms.LastCommitID() var lastCommitID = app.ms.LastCommitID()
main := app.ms.GetKVStore(mainKey) var main = app.ms.GetKVStore(mainKey)
header := abci.Header{} var header *abci.Header
// Main store should exist. // Main store should exist.
if main == nil { if main == nil {
@ -171,7 +171,7 @@ func (app *BaseApp) initFromStore(mainKey sdk.StoreKey) error {
errStr := fmt.Sprintf("Version > 0 but missing key %s", mainHeaderKey) errStr := fmt.Sprintf("Version > 0 but missing key %s", mainHeaderKey)
return errors.New(errStr) return errors.New(errStr)
} }
err := proto.Unmarshal(headerBytes, &header) err := proto.Unmarshal(headerBytes, header)
if err != nil { if err != nil {
return errors.Wrap(err, "Failed to parse Header") return errors.Wrap(err, "Failed to parse Header")
} }
@ -225,9 +225,11 @@ func (app *BaseApp) Query(req abci.RequestQuery) (res abci.ResponseQuery) {
// Implements ABCI. // Implements ABCI.
func (app *BaseApp) BeginBlock(req abci.RequestBeginBlock) (res abci.ResponseBeginBlock) { func (app *BaseApp) BeginBlock(req abci.RequestBeginBlock) (res abci.ResponseBeginBlock) {
app.header = req.Header // NOTE: For consistency we should unset these upon EndBlock.
app.header = &req.Header
app.msDeliver = app.ms.CacheMultiStore() app.msDeliver = app.ms.CacheMultiStore()
app.msCheck = app.ms.CacheMultiStore() app.msCheck = app.ms.CacheMultiStore()
app.valUpdates = nil
return return
} }
@ -318,6 +320,9 @@ func (app *BaseApp) runTx(isCheckTx bool, txBytes []byte) (result sdk.Result) {
func (app *BaseApp) EndBlock(req abci.RequestEndBlock) (res abci.ResponseEndBlock) { func (app *BaseApp) EndBlock(req abci.RequestEndBlock) (res abci.ResponseEndBlock) {
res.ValidatorUpdates = app.valUpdates res.ValidatorUpdates = app.valUpdates
app.valUpdates = nil app.valUpdates = nil
app.header = nil
app.msDeliver = nil
app.msCheck = nil
return return
} }

View File

@ -11,11 +11,17 @@ func (app *BaseApp) NewContext(isCheckTx bool, txBytes []byte) sdk.Context {
} else { } else {
store = app.msDeliver store = app.msDeliver
} }
if store == nil {
panic("BaseApp.NewContext() requires BeginBlock(): missing store")
}
if app.header == nil {
panic("BaseApp.NewContext() requires BeginBlock(): missing header")
}
// Initialize arguments to Handler. // Initialize arguments to Handler.
var ctx = sdk.NewContext( var ctx = sdk.NewContext(
store, store,
app.header, *app.header,
isCheckTx, isCheckTx,
txBytes, txBytes,
) )