diff --git a/lib/statemanager.js b/lib/statemanager.js index 13aaedd8af..6d6b7ad76b 100644 --- a/lib/statemanager.js +++ b/lib/statemanager.js @@ -815,6 +815,8 @@ StateManager.prototype.revert = function(snapshotId, callback) { this.logger.log("Reverting to snapshot #" + snapshotId); if (snapshotId > this.snapshots.length) { + // the snapshot doesn't exist now, or it has already been reverted + callback(null, false); return false; } diff --git a/test/snapshotting.js b/test/snapshotting.js index 5ab627522f..8514e66d06 100644 --- a/test/snapshotting.js +++ b/test/snapshotting.js @@ -69,6 +69,21 @@ describe("Checkpointing / Reverting", function() { assert.strictEqual(oldReceipt, null, "Receipt should be null as it should have been removed"); }); + it("returns false when reverting a snapshot that doesn't exist", async() => { + const { send } = context; + + const snapShotId1 = await send("evm_snapshot"); + const snapShotId2 = await send("evm_snapshot"); + const response1 = await send("evm_revert", snapShotId1.result); + assert.strictEqual(response1.result, true, "Reverting a snapshot that exists does not work"); + const response2 = await send("evm_revert", snapShotId2.result); + assert.strictEqual(response2.result, false, "Reverting a snapshot that no longer exists does not work"); + const response3 = await send("evm_revert", snapShotId1.result); + assert.strictEqual(response3.result, false, "Reverting a snapshot that hasn't already been reverted does not work"); + const response4 = await send("evm_revert", 999); + assert.strictEqual(response4.result, false, "Reverting a snapshot that has never existed does not work"); + }); + it("checkpoints and reverts without persisting contract storage", async() => { const { accounts, instance, send } = context;