Skip to content

Commit

Permalink
feat(cosmic-swingset): add begin block check and transaction (#8432)
Browse files Browse the repository at this point in the history
* feat(cosmic-swingset): add being block check and transaction

* fixup! feat(cosmic-swingset): add being block check and transaction

---------

Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
  • Loading branch information
mhofman and mergify[bot] authored Oct 12, 2023
1 parent d4b32f1 commit a9d113a
Showing 1 changed file with 34 additions and 1 deletion.
35 changes: 34 additions & 1 deletion packages/cosmic-swingset/src/launch-chain.js
Original file line number Diff line number Diff line change
Expand Up @@ -497,6 +497,9 @@ export async function launch({
}

let savedHeight = Number(kvStore.get(getHostKey('height')) || 0);
let savedBeginHeight = Number(
kvStore.get(getHostKey('beginHeight')) || savedHeight,
);
let runTime = 0;
let chainTime;
let saveTime = 0;
Expand Down Expand Up @@ -711,6 +714,11 @@ export async function launch({
throw decohered;
}

function saveBeginHeight(blockHeight) {
savedBeginHeight = blockHeight;
kvStore.set(getHostKey('beginHeight'), `${savedBeginHeight}`);
}

async function afterCommit(blockHeight, blockTime) {
await waitUntilQuiescent()
.then(afterCommitCallback)
Expand Down Expand Up @@ -741,14 +749,17 @@ export async function launch({
// This only runs for the very first block on the chain.
if (isBootstrap) {
verboseBlocks && blockManagerConsole.info('block bootstrap');
savedHeight === 0 ||
(savedHeight === 0 && savedBeginHeight === 0) ||
Fail`Cannot run a bootstrap block at height ${savedHeight}`;
const bootstrapBlockParams = parseParams(params);
const blockHeight = 0;
controller.writeSlogObject({
type: 'cosmic-swingset-bootstrap-block-start',
blockTime,
});
// Start a block transaction, but without changing state
// for the upcoming begin block check
saveBeginHeight(savedBeginHeight);
await processAction(action.type, async () =>
bootstrapBlock(blockHeight, blockTime, bootstrapBlockParams),
);
Expand Down Expand Up @@ -780,6 +791,10 @@ export async function launch({
return undefined;
}

// Start a block transaction, but without changing state
// for the upcoming begin block check
saveBeginHeight(savedBeginHeight);

controller.writeSlogObject({
type: 'cosmic-swingset-upgrade-start',
blockHeight,
Expand Down Expand Up @@ -910,6 +925,17 @@ export async function launch({
blockManagerConsole.info('block', blockHeight, 'begin');
runTime = 0;

if (blockNeedsExecution(blockHeight)) {
if (savedBeginHeight === blockHeight) {
decohered = Error(
`Inconsistent committed state. Block ${blockHeight} had already began execution`,
);
throw decohered;
}
// Start a block transaction, recording which block height is executed
saveBeginHeight(blockHeight);
}

controller.writeSlogObject({
type: 'cosmic-swingset-begin-block',
blockHeight,
Expand Down Expand Up @@ -947,6 +973,13 @@ export async function launch({
throw e;
}
} else {
if (blockHeight !== savedBeginHeight) {
decohered = Error(
`Inconsistent committed state. Trying to end block ${blockHeight}, expected began block ${savedBeginHeight}`,
);
throw decohered;
}

// And now we actually process the queued actions down here, during
// END_BLOCK, but still reentrancy-protected.

Expand Down

0 comments on commit a9d113a

Please sign in to comment.