From 362bf1218f5f46269ca2b88a78596a4ea481bb45 Mon Sep 17 00:00:00 2001 From: Filipp Makarov Date: Tue, 22 Oct 2024 21:39:53 +0300 Subject: [PATCH] add tests --- .../sponsorship/BiconomySponsorshipPaymaster.sol | 11 ----------- test/unit/concrete/TestSponsorshipPaymaster.t.sol | 13 +++---------- 2 files changed, 3 insertions(+), 21 deletions(-) diff --git a/contracts/sponsorship/BiconomySponsorshipPaymaster.sol b/contracts/sponsorship/BiconomySponsorshipPaymaster.sol index d5ef981..3c304b3 100644 --- a/contracts/sponsorship/BiconomySponsorshipPaymaster.sol +++ b/contracts/sponsorship/BiconomySponsorshipPaymaster.sol @@ -14,8 +14,6 @@ import { IERC20 } from "@openzeppelin/contracts/token/ERC20/IERC20.sol"; import { SafeTransferLib } from "solady/utils/SafeTransferLib.sol"; import { IBiconomySponsorshipPaymaster } from "../interfaces/IBiconomySponsorshipPaymaster.sol"; -import "forge-std/console2.sol"; - /** * @title BiconomySponsorshipPaymaster * @author livingrockrises @@ -332,8 +330,6 @@ contract BiconomySponsorshipPaymaster is // Include unaccountedGas since EP doesn't include this in actualGasCost // unaccountedGas = postOpGas + EP overhead gas + estimated penalty actualGasCost = actualGasCost + (unaccountedGas * actualUserOpFeePerGas); - console2.log("gas at pm.postOp sent by EP + unaccountedGas ", actualGasCost); - console2.log("actual unaccountedGas (postOp overload) units at pm.postOp ", unaccountedGas); // Apply the price markup uint256 adjustedGasCost = (actualGasCost * priceMarkup) / _PRICE_DENOMINATOR; @@ -344,11 +340,9 @@ contract BiconomySponsorshipPaymaster is if (prechargedAmount > adjustedGasCost) { // If overcharged refund the excess - console2.log("overcharged ", prechargedAmount - adjustedGasCost); paymasterIdBalances[paymasterId] += (prechargedAmount - adjustedGasCost); } else { // deduct what needs to be deducted from paymasterId - console2.log("undercharged ", (adjustedGasCost - prechargedAmount)); paymasterIdBalances[paymasterId] -= (adjustedGasCost - prechargedAmount); } // here adjustedGasCost does not account for gasPenalty. prechargedAmount accounts for penalty with maxGasPenalty @@ -425,11 +419,6 @@ contract BiconomySponsorshipPaymaster is ) * 10 * userOp.unpackMaxFeePerGas() ) / 100; - console2.log("call gas limit in pm ", uint128(uint256(userOp.accountGasLimits))); - console2.log("pm gas limit in pm", uint128(bytes16(userOp.paymasterAndData[_PAYMASTER_POSTOP_GAS_OFFSET:_PAYMASTER_DATA_OFFSET]))); - - console2.log("max penalty ", maxPenalty); - // Deduct the max gas cost. uint256 effectiveCost = (((requiredPreFund + unaccountedGas * userOp.unpackMaxFeePerGas()) * priceMarkup) / _PRICE_DENOMINATOR); diff --git a/test/unit/concrete/TestSponsorshipPaymaster.t.sol b/test/unit/concrete/TestSponsorshipPaymaster.t.sol index 0b0ed5b..13529d0 100644 --- a/test/unit/concrete/TestSponsorshipPaymaster.t.sol +++ b/test/unit/concrete/TestSponsorshipPaymaster.t.sol @@ -12,6 +12,7 @@ contract TestSponsorshipPaymasterWithPriceMarkup is TestBase { uint256 public constant WITHDRAWAL_DELAY = 3600; uint256 public constant MIN_DEPOSIT = 1e15; + uint256 public constant UNACCOUNTED_GAS = 15e3; function setUp() public { setupPaymasterTestEnvironment(); @@ -21,7 +22,7 @@ contract TestSponsorshipPaymasterWithPriceMarkup is TestBase { entryPointArg: ENTRYPOINT, verifyingSignerArg: PAYMASTER_SIGNER.addr, feeCollectorArg: PAYMASTER_FEE_COLLECTOR.addr, - unaccountedGasArg: 15e3, //if set too low, PM will lose money + unaccountedGasArg: UNACCOUNTED_GAS, //if set too low, PM will lose money paymasterIdWithdrawalDelayArg: WITHDRAWAL_DELAY, minDepositArg: MIN_DEPOSIT }); @@ -78,7 +79,7 @@ contract TestSponsorshipPaymasterWithPriceMarkup is TestBase { assertEq(address(bicoPaymaster.entryPoint()), ENTRYPOINT_ADDRESS); assertEq(bicoPaymaster.verifyingSigner(), PAYMASTER_SIGNER.addr); assertEq(bicoPaymaster.feeCollector(), PAYMASTER_FEE_COLLECTOR.addr); - assertEq(bicoPaymaster.unaccountedGas(), 7e3); + assertEq(bicoPaymaster.unaccountedGas(), UNACCOUNTED_GAS); } function test_OwnershipTransfer() external prankModifier(PAYMASTER_OWNER.addr) { @@ -241,9 +242,6 @@ contract TestSponsorshipPaymasterWithPriceMarkup is TestBase { } // try to use balance while request is cleared - - // This doesn't pass as maxPenalty calculation is wrong - function test_executeWithdrawalRequest_Withdraws_WhateverIsLeft() external prankModifier(DAPP_ACCOUNT.addr) { uint256 depositAmount = 1 ether; bicoPaymaster.depositFor{ value: depositAmount }(DAPP_ACCOUNT.addr); @@ -253,7 +251,6 @@ contract TestSponsorshipPaymasterWithPriceMarkup is TestBase { PackedUserOperation[] memory ops = new PackedUserOperation[](1); (PackedUserOperation memory userOp, bytes32 userOpHash) = createUserOp(ALICE, bicoPaymaster, 1e6, 55_000); ops[0] = userOp; - console2.log("================"); startPrank(BUNDLER.addr); ENTRYPOINT.handleOps(ops, payable(BUNDLER.addr)); stopPrank(); @@ -265,10 +262,6 @@ contract TestSponsorshipPaymasterWithPriceMarkup is TestBase { IStakeManager.DepositInfo memory depositInfo = ENTRYPOINT.getDepositInfo(address(bicoPaymaster)); uint256 PAYMASTER_POSTOP_GAS_OFFSET = 36; uint256 PAYMASTER_DATA_OFFSET = 52; - // console2.log("deposit in EP ", depositInfo.deposit); - // console2.log("payId Bal Aft ", dappPaymasterBalanceAfter); - console2.log("max gas fee ", uint128(uint256(userOp.gasFees))); - //console2.log("max gas ", this.getGasLimit(userOp)); vm.warp(block.timestamp + WITHDRAWAL_DELAY + 1); bicoPaymaster.executeWithdrawalRequest(DAPP_ACCOUNT.addr);