Skip to content

Commit

Permalink
[executor/contract] add get methods and tests (#1260)
Browse files Browse the repository at this point in the history
* add methods and tests

* add sequence check
  • Loading branch information
Dev Kalra authored Jan 30, 2024
1 parent 343c784 commit 11c1fa7
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 2 deletions.
14 changes: 13 additions & 1 deletion target_chains/ethereum/contracts/contracts/executor/Executor.sol
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ contract Executor {
// whose payload is a serialized GovernanceInstruction.
function execute(
bytes memory encodedVm
) public returns (bytes memory response) {
) public payable returns (bytes memory response) {
IWormhole.VM memory vm = verifyGovernanceVM(encodedVm);

GovernanceInstruction memory gi = parseGovernanceInstruction(
Expand Down Expand Up @@ -179,4 +179,16 @@ contract Executor {
encodedInstruction.length - index
);
}

function getOwnerChainId() public view returns (uint64) {
return ownerEmitterChainId;
}

function getOwnerEmitterAddress() public view returns (bytes32) {
return ownerEmitterAddress;
}

function getLastExecutedSequence() public view returns (uint64) {
return lastExecutedSequence;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,6 @@ contract ExecutorUpgradable is
}

function version() public pure returns (string memory) {
return "0.1.0";
return "0.1.1";
}
}
62 changes: 62 additions & 0 deletions target_chains/ethereum/contracts/forge-test/Executor.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,16 @@ contract ExecutorTest is Test, WormholeTestUtils {
);
}

function testExecutorOwnerChainId() public {
uint chainId = executor.getOwnerChainId();
assertEq(chainId, OWNER_CHAIN_ID);
}

function testExecutorOwnerEmitterAddress() public {
bytes32 ownerEmitterAddress = executor.getOwnerEmitterAddress();
assertEq(ownerEmitterAddress, OWNER_EMITTER);
}

function testExecutorOwner() public {
assertEq(address(executor), executor.owner());
}
Expand Down Expand Up @@ -123,6 +133,58 @@ contract ExecutorTest is Test, WormholeTestUtils {
executor.execute(vaa);
}

function testLastExecutedSequenceUpdateOnSucceed() public {
callable.reset();

uint32 c = callable.fooCount();
uint oldSequence = executor.getLastExecutedSequence();
uint64 sequence = 1;
assertEq(callable.lastCaller(), address(bytes20(0)));
testExecute(
address(callable),
abi.encodeWithSelector(ICallable.foo.selector),
sequence,
0
);
uint newSequence = executor.getLastExecutedSequence();

assertGt(newSequence, oldSequence);
assertEq(newSequence, sequence);
assertEq(callable.fooCount(), c + 1);
assertEq(callable.lastCaller(), address(executor));
// Sanity check to make sure the check above is meaningful.
assert(address(executor) != address(this));
}

function testLastExecutedSequenceNoChangeOnFail() public {
uint oldSequence = executor.getLastExecutedSequence();

bytes memory payload = abi.encodePacked(
uint32(0x5054474d),
PythGovernanceInstructions.GovernanceModule.EvmExecutor,
Executor.ExecutorAction.Execute,
CHAIN_ID,
address(executor),
address(callable),
uint(0),
abi.encodeWithSelector(ICallable.reverts.selector)
);

bytes memory vaa = generateVaa(
uint32(block.timestamp),
OWNER_CHAIN_ID,
OWNER_EMITTER,
1,
payload,
NUM_SIGNERS
);

vm.expectRevert("call should revert");
executor.execute(vaa);
uint newSequence = executor.getLastExecutedSequence();
assertEq(newSequence, oldSequence);
}

function testCallSucceeds() public {
callable.reset();

Expand Down

0 comments on commit 11c1fa7

Please sign in to comment.