From d2aa93d70111fad805877a88cf236734465cfcf6 Mon Sep 17 00:00:00 2001 From: Richard Pringle Date: Thu, 14 Nov 2024 18:40:54 -0500 Subject: [PATCH] Mock the reward functionality of the native-manager --- .../NativeTokenStakingManagerTests.t.sol | 31 ++++++++++--------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/contracts/validator-manager/tests/NativeTokenStakingManagerTests.t.sol b/contracts/validator-manager/tests/NativeTokenStakingManagerTests.t.sol index e0ac95b16..140fe31e4 100644 --- a/contracts/validator-manager/tests/NativeTokenStakingManagerTests.t.sol +++ b/contracts/validator-manager/tests/NativeTokenStakingManagerTests.t.sol @@ -5,6 +5,7 @@ pragma solidity 0.8.25; +import {Test} from "@forge-std/Test.sol"; import {PoSValidatorManagerTest} from "./PoSValidatorManagerTests.t.sol"; import {NativeTokenStakingManager} from "../NativeTokenStakingManager.sol"; import {PoSValidatorManager} from "../PoSValidatorManager.sol"; @@ -249,25 +250,15 @@ contract NativeTokenStakingManagerTest is PoSValidatorManagerTest { } function _expectRewardIssuance(address account, uint256 amount) internal override { - vm.mockCall( - address(app.NATIVE_MINTER()), - abi.encodeCall(INativeMinter.mintNativeCoin, (account, amount)), - "" - ); - // empty calldata implies the receive function will be called: - vm.mockCall({ - callee: account, - msgValue: amount, - data: "", // implies receive() - returnData: "" - }); - // Units tests don't have access to the native minter precompile, so use vm.deal instead. - vm.deal(account, account.balance + amount); + address nativeMinter = address(app.NATIVE_MINTER()); + bytes memory callData = abi.encodeCall(INativeMinter.mintNativeCoin, (account, amount)); + vm.mockCall(nativeMinter, callData, ""); + vm.expectCall(nativeMinter, callData); } function _setUp() internal override returns (IValidatorManager) { // Construct the object under test - app = new NativeTokenStakingManager(ICMInitializable.Allowed); + app = new TestableNativeTokenStakingManager(ICMInitializable.Allowed); rewardCalculator = new ExampleRewardCalculator(DEFAULT_REWARD_RATE); app.initialize( PoSValidatorManagerSettings({ @@ -294,3 +285,13 @@ contract NativeTokenStakingManagerTest is PoSValidatorManagerTest { return account.balance; } } + +contract TestableNativeTokenStakingManager is NativeTokenStakingManager, Test { + constructor(ICMInitializable init) NativeTokenStakingManager(init) {} + + function _reward(address account, uint256 amount) internal virtual override { + super._reward(account, amount); + // Units tests don't have access to the native minter precompile, so use vm.deal instead. + vm.deal(account, account.balance + amount); + } +}