From 2d91875c17aecb11e2cee061ad59f522da47f35f Mon Sep 17 00:00:00 2001 From: xorsal Date: Wed, 2 Oct 2024 03:34:43 -0400 Subject: [PATCH] refactor: use block.timestamp instead of block.number (#63) --- package.json | 2 +- .../modules/dispute/BondEscalationModule.sol | 5 ++- .../modules/dispute/BondedDisputeModule.sol | 3 +- .../modules/dispute/CircuitResolverModule.sol | 3 +- .../dispute/RootVerificationModule.sol | 3 +- .../modules/response/BondedResponseModule.sol | 6 ++-- .../response/IBondedResponseModule.sol | 3 +- .../test/integration/BondEscalation.t.sol | 6 ++-- solidity/test/integration/Finalization.t.sol | 10 +++--- solidity/test/integration/IntegrationBase.sol | 5 +-- solidity/test/integration/Payments.t.sol | 4 +-- .../test/integration/RequestCreation.t.sol | 8 ++--- .../test/integration/ResponseDispute.t.sol | 4 +-- .../test/integration/ResponseProposal.t.sol | 4 +-- .../test/integration/RootVerification.t.sol | 2 +- .../dispute/BondEscalationModule.t.sol | 15 +++----- .../modules/dispute/BondedDisputeModule.t.sol | 8 ++--- .../dispute/CircuitResolverModule.t.sol | 9 ++--- .../dispute/RootVerificationModule.t.sol | 9 ++--- .../response/BondedResponseModule.t.sol | 36 ++++++++++--------- yarn.lock | 8 ++--- 21 files changed, 67 insertions(+), 86 deletions(-) diff --git a/package.json b/package.json index 2334cb94..2e2e4ff7 100644 --- a/package.json +++ b/package.json @@ -38,7 +38,7 @@ "package.json": "sort-package-json" }, "dependencies": { - "@defi-wonderland/prophet-core": "0.0.0-0954a47f", + "@defi-wonderland/prophet-core": "0.0.0-4d28a0ec", "@openzeppelin/contracts": "4.9.5", "solmate": "https://github.com/transmissions11/solmate.git#bfc9c25865a274a7827fea5abf6e4fb64fc64e6c" }, diff --git a/solidity/contracts/modules/dispute/BondEscalationModule.sol b/solidity/contracts/modules/dispute/BondEscalationModule.sol index e1cc5992..b213841d 100644 --- a/solidity/contracts/modules/dispute/BondEscalationModule.sol +++ b/solidity/contracts/modules/dispute/BondEscalationModule.sol @@ -36,7 +36,7 @@ contract BondEscalationModule is Module, IBondEscalationModule { RequestParameters memory _params = decodeRequestData(_request.disputeModuleData); BondEscalation storage _escalation = _escalations[_dispute.requestId]; - if (block.number > ORACLE.responseCreatedAt(_dispute.responseId) + _params.disputeWindow) { + if (block.timestamp > ORACLE.responseCreatedAt(_dispute.responseId) + _params.disputeWindow) { revert BondEscalationModule_DisputeWindowOver(); } @@ -51,8 +51,7 @@ contract BondEscalationModule is Module, IBondEscalationModule { _requestId: _dispute.requestId, _responseId: _dispute.responseId, _disputeId: _disputeId, - _dispute: _dispute, - _blockNumber: block.number + _dispute: _dispute }); // Only the first dispute of a request should go through the bond escalation diff --git a/solidity/contracts/modules/dispute/BondedDisputeModule.sol b/solidity/contracts/modules/dispute/BondedDisputeModule.sol index 527b3c07..42f8fd97 100644 --- a/solidity/contracts/modules/dispute/BondedDisputeModule.sol +++ b/solidity/contracts/modules/dispute/BondedDisputeModule.sol @@ -38,8 +38,7 @@ contract BondedDisputeModule is Module, IBondedDisputeModule { _requestId: _dispute.requestId, _responseId: _dispute.responseId, _disputeId: _getId(_dispute), - _dispute: _dispute, - _blockNumber: block.number + _dispute: _dispute }); } diff --git a/solidity/contracts/modules/dispute/CircuitResolverModule.sol b/solidity/contracts/modules/dispute/CircuitResolverModule.sol index bdd8e8f6..e4c955d9 100644 --- a/solidity/contracts/modules/dispute/CircuitResolverModule.sol +++ b/solidity/contracts/modules/dispute/CircuitResolverModule.sol @@ -85,8 +85,7 @@ contract CircuitResolverModule is Module, ICircuitResolverModule { _requestId: _response.requestId, _responseId: _dispute.responseId, _disputeId: _getId(_dispute), - _dispute: _dispute, - _blockNumber: block.number + _dispute: _dispute }); ORACLE.updateDisputeStatus(_request, _response, _dispute, _status); diff --git a/solidity/contracts/modules/dispute/RootVerificationModule.sol b/solidity/contracts/modules/dispute/RootVerificationModule.sol index dc05ae21..775d26b7 100644 --- a/solidity/contracts/modules/dispute/RootVerificationModule.sol +++ b/solidity/contracts/modules/dispute/RootVerificationModule.sol @@ -83,8 +83,7 @@ contract RootVerificationModule is Module, IRootVerificationModule { _requestId: _response.requestId, _responseId: _dispute.responseId, _disputeId: _getId(_dispute), - _dispute: _dispute, - _blockNumber: block.number + _dispute: _dispute }); ORACLE.updateDisputeStatus(_request, _response, _dispute, _status); diff --git a/solidity/contracts/modules/response/BondedResponseModule.sol b/solidity/contracts/modules/response/BondedResponseModule.sol index 635785c1..79f3d565 100644 --- a/solidity/contracts/modules/response/BondedResponseModule.sol +++ b/solidity/contracts/modules/response/BondedResponseModule.sol @@ -62,7 +62,7 @@ contract BondedResponseModule is Module, IBondedResponseModule { }); } - emit ResponseProposed(_response.requestId, _response, block.number); + emit ResponseProposed(_response.requestId, _response); } /// @inheritdoc IBondedResponseModule @@ -75,14 +75,14 @@ contract BondedResponseModule is Module, IBondedResponseModule { bool _isModule = ORACLE.allowedModule(_response.requestId, _finalizer); - if (!_isModule && block.number < _params.deadline) { + if (!_isModule && block.timestamp < _params.deadline) { revert BondedResponseModule_TooEarlyToFinalize(); } uint256 _responseCreatedAt = ORACLE.responseCreatedAt(_getId(_response)); if (_responseCreatedAt != 0) { - if (!_isModule && block.number < _responseCreatedAt + _params.disputeWindow) { + if (!_isModule && block.timestamp < _responseCreatedAt + _params.disputeWindow) { revert BondedResponseModule_TooEarlyToFinalize(); } diff --git a/solidity/interfaces/modules/response/IBondedResponseModule.sol b/solidity/interfaces/modules/response/IBondedResponseModule.sol index 4bae38f9..bacb55d0 100644 --- a/solidity/interfaces/modules/response/IBondedResponseModule.sol +++ b/solidity/interfaces/modules/response/IBondedResponseModule.sol @@ -20,9 +20,8 @@ interface IBondedResponseModule is IResponseModule { * * @param _requestId The ID of the request that the response was proposed * @param _response The proposed response - * @param _blockNumber The number of the block in which the response was proposed */ - event ResponseProposed(bytes32 indexed _requestId, IOracle.Response _response, uint256 indexed _blockNumber); + event ResponseProposed(bytes32 indexed _requestId, IOracle.Response _response); /** * @notice Emitted when an uncalled response is released diff --git a/solidity/test/integration/BondEscalation.t.sol b/solidity/test/integration/BondEscalation.t.sol index 12cfc827..b1704a96 100644 --- a/solidity/test/integration/BondEscalation.t.sol +++ b/solidity/test/integration/BondEscalation.t.sol @@ -152,7 +152,7 @@ contract Integration_BondEscalation is IntegrationBase { assertEq(_bondEscalationAccounting.balanceOf(disputer, usdc), 0, 'Mismatch: Disputer balance'); // Step 8: Finalize request and check balances again - vm.roll(_expectedDeadline + 1 days); + vm.warp(_expectedDeadline + 1 days); oracle.finalize(mockRequest, mockResponse); // Test: The requester has no balance because he has paid the proposer @@ -248,7 +248,7 @@ contract Integration_BondEscalation is IntegrationBase { _responseId = oracle.proposeResponse(mockRequest, _thirdResponse); // Step 11: It goes undisputed for three days, therefore it's deemed correct and final - vm.roll(_expectedDeadline + 1); + vm.warp(_expectedDeadline + 1); oracle.finalize(mockRequest, _thirdResponse); // Test: The requester has paid out the reward @@ -283,7 +283,7 @@ contract Integration_BondEscalation is IntegrationBase { // Step 12: Two days after the deadline, the resolution module says that Another proposer's answer was correct // So Another proposer gets paid Disputer's bond - vm.roll(_expectedDeadline + 2 days); + vm.warp(_expectedDeadline + 2 days); _mockArbitrator.setAnswer(IOracle.DisputeStatus.Lost); oracle.resolveDispute(mockRequest, _secondResponse, _secondDispute); diff --git a/solidity/test/integration/Finalization.t.sol b/solidity/test/integration/Finalization.t.sol index 4b0883d3..99df4b16 100644 --- a/solidity/test/integration/Finalization.t.sol +++ b/solidity/test/integration/Finalization.t.sol @@ -27,7 +27,7 @@ contract Integration_Finalization is IntegrationBase { _proposeResponse(); // Traveling to the end of the dispute window - vm.roll(_expectedDeadline + 1 + _baseDisputeWindow); + vm.warp(_expectedDeadline + 1 + _baseDisputeWindow); // Check: all external calls are made? vm.expectCall(address(_mockCallback), abi.encodeWithSelector(IProphetCallback.prophetCallback.selector, _calldata)); @@ -69,13 +69,13 @@ contract Integration_Finalization is IntegrationBase { /** * @notice Finalizing a request with a ongoing dispute reverts. */ - function test_revertFinalizeInDisputeWindow(uint256 _block) public { - _block = bound(_block, block.number, _expectedDeadline - _baseDisputeWindow - 1); + function test_revertFinalizeInDisputeWindow(uint256 _timestamp) public { + _timestamp = bound(_timestamp, block.timestamp, _expectedDeadline - _baseDisputeWindow - 1); _createRequest(); _proposeResponse(); - vm.roll(_block); + vm.warp(_timestamp); // Check: reverts if called during the dispute window? vm.expectRevert(IBondedResponseModule.BondedResponseModule_TooEarlyToFinalize.selector); @@ -96,7 +96,7 @@ contract Integration_Finalization is IntegrationBase { _proposeResponse(); // Traveling to the end of the dispute window - vm.roll(_expectedDeadline + 1 + _baseDisputeWindow); + vm.warp(_expectedDeadline + 1 + _baseDisputeWindow); vm.expectCall(address(_mockCallback), abi.encodeWithSelector(IProphetCallback.prophetCallback.selector, _calldata)); vm.prank(_finalizer); diff --git a/solidity/test/integration/IntegrationBase.sol b/solidity/test/integration/IntegrationBase.sol index 0cbd2f26..c918832e 100644 --- a/solidity/test/integration/IntegrationBase.sol +++ b/solidity/test/integration/IntegrationBase.sol @@ -81,9 +81,10 @@ contract IntegrationBase is DSTestPlus, TestConstants, Helpers { uint256 internal _expectedReward = 30 ether; uint256 internal _expectedDeadline; uint256 internal _expectedCallbackValue = 42; - uint256 internal _baseDisputeWindow = 120; // blocks + uint256 internal _baseDisputeWindow = 120 * BLOCK_TIME; bytes32 internal _ipfsHash = bytes32('QmR4uiJH654k3Ta2uLLQ8r'); uint256 internal _blocksDeadline = 600; + uint256 internal _timestampDeadline = _blocksDeadline * BLOCK_TIME; function setUp() public virtual { vm.createSelectFork(vm.rpcUrl('optimism'), FORK_BLOCK); @@ -135,7 +136,7 @@ contract IntegrationBase is DSTestPlus, TestConstants, Helpers { vm.stopPrank(); // Set the expected deadline - _expectedDeadline = block.timestamp + BLOCK_TIME * _blocksDeadline; + _expectedDeadline = block.timestamp + _timestampDeadline; // Configure the mock request mockRequest.requestModuleData = abi.encode( diff --git a/solidity/test/integration/Payments.t.sol b/solidity/test/integration/Payments.t.sol index 542233a9..7b4edab0 100644 --- a/solidity/test/integration/Payments.t.sol +++ b/solidity/test/integration/Payments.t.sol @@ -26,7 +26,7 @@ contract Integration_Payments is IntegrationBase { assertEq(_accountingExtension.bondedAmountOf(proposer, usdc, _requestId), _bondSize); // Warp to finalization time. - vm.roll(_expectedDeadline + _baseDisputeWindow); + vm.warp(_expectedDeadline + _baseDisputeWindow); // Finalize request/response oracle.finalize(mockRequest, mockResponse); @@ -66,7 +66,7 @@ contract Integration_Payments is IntegrationBase { assertEq(_accountingExtension.bondedAmountOf(proposer, weth, _requestId), _bondSize); // Warp to finalization time. - vm.roll(_expectedDeadline + _baseDisputeWindow); + vm.warp(_expectedDeadline + _baseDisputeWindow); // Finalize request/response. oracle.finalize(mockRequest, mockResponse); diff --git a/solidity/test/integration/RequestCreation.t.sol b/solidity/test/integration/RequestCreation.t.sol index c6d6e50f..30b0474f 100644 --- a/solidity/test/integration/RequestCreation.t.sol +++ b/solidity/test/integration/RequestCreation.t.sol @@ -34,8 +34,8 @@ contract Integration_RequestCreation is IntegrationBase { // Check: saved the correct nonce? assertEq(oracle.nonceToRequestId(mockRequest.nonce), _requestId); - // Check: saved the correct creation block? - assertEq(oracle.requestCreatedAt(_requestId), block.number); + // Check: saved the correct creation timestamp? + assertEq(oracle.requestCreatedAt(_requestId), block.timestamp); // Check: saved the allowed modules? assertTrue(oracle.allowedModule(_requestId, mockRequest.requestModule)); @@ -60,8 +60,8 @@ contract Integration_RequestCreation is IntegrationBase { // Check: saved the correct nonce? assertEq(oracle.nonceToRequestId(mockRequest.nonce), _requestId); - // Check: saved the correct creation block? - assertEq(oracle.requestCreatedAt(_requestId), block.number); + // Check: saved the correct creation timestamp? + assertEq(oracle.requestCreatedAt(_requestId), block.timestamp); // Check: saved the allowed modules? assertTrue(oracle.allowedModule(_requestId, mockRequest.requestModule)); diff --git a/solidity/test/integration/ResponseDispute.t.sol b/solidity/test/integration/ResponseDispute.t.sol index 9e859439..566cd303 100644 --- a/solidity/test/integration/ResponseDispute.t.sol +++ b/solidity/test/integration/ResponseDispute.t.sol @@ -39,7 +39,7 @@ contract Integration_ResponseDispute is IntegrationBase { assertEq(oracle.disputeOf(_getId(mockResponse)), _disputeId); // Check: creation time is correct? - assertEq(oracle.disputeCreatedAt(_disputeId), block.number); + assertEq(oracle.disputeCreatedAt(_disputeId), block.timestamp); } /** @@ -83,7 +83,7 @@ contract Integration_ResponseDispute is IntegrationBase { * @notice Disputing a finalized response should revert */ function test_disputeResponse_alreadyFinalized() public { - vm.roll(_expectedDeadline + _baseDisputeWindow); + vm.warp(_expectedDeadline + _baseDisputeWindow); oracle.finalize(mockRequest, mockResponse); vm.expectRevert(abi.encodeWithSelector(IOracle.Oracle_AlreadyFinalized.selector, _getId(mockRequest))); diff --git a/solidity/test/integration/ResponseProposal.t.sol b/solidity/test/integration/ResponseProposal.t.sol index e7decc7c..8a8ee1af 100644 --- a/solidity/test/integration/ResponseProposal.t.sol +++ b/solidity/test/integration/ResponseProposal.t.sol @@ -40,8 +40,8 @@ contract Integration_ResponseProposal is IntegrationBase { bytes32[] memory _getResponseIds = oracle.getResponseIds(_requestId); assertEq(_getResponseIds[0], _getId(mockResponse)); - // Check: the creation block is correct? - assertEq(oracle.responseCreatedAt(_getId(mockResponse)), block.number); + // Check: the creation timestamp is correct? + assertEq(oracle.responseCreatedAt(_getId(mockResponse)), block.timestamp); } /** diff --git a/solidity/test/integration/RootVerification.t.sol b/solidity/test/integration/RootVerification.t.sol index a5877b76..92dadd1f 100644 --- a/solidity/test/integration/RootVerification.t.sol +++ b/solidity/test/integration/RootVerification.t.sol @@ -106,7 +106,7 @@ contract Integration_RootVerification is IntegrationBase { vm.prank(proposer); oracle.proposeResponse(mockRequest, mockResponse); - vm.roll(_expectedDeadline + _baseDisputeWindow); + vm.warp(_expectedDeadline + _baseDisputeWindow); oracle.finalize(mockRequest, mockResponse); } diff --git a/solidity/test/unit/modules/dispute/BondEscalationModule.t.sol b/solidity/test/unit/modules/dispute/BondEscalationModule.t.sol index ce72dd90..31f18815 100644 --- a/solidity/test/unit/modules/dispute/BondEscalationModule.t.sol +++ b/solidity/test/unit/modules/dispute/BondEscalationModule.t.sol @@ -83,11 +83,7 @@ contract BaseTest is Test, Helpers { bytes32 indexed _requestId, bytes32 indexed _disputeId, IBondEscalationModule.BondEscalationStatus _status ); event ResponseDisputed( - bytes32 indexed _requestId, - bytes32 indexed _responseId, - bytes32 indexed _disputeId, - IOracle.Dispute _dispute, - uint256 _blockNumber + bytes32 indexed _requestId, bytes32 indexed _responseId, bytes32 indexed _disputeId, IOracle.Dispute _dispute ); event DisputeStatusChanged(bytes32 indexed _disputeId, IOracle.Dispute _dispute, IOracle.DisputeStatus _status); @@ -430,7 +426,7 @@ contract BondEscalationModule_Unit_DisputeResponse is BaseTest { mockDispute.responseId = _responseId; // Warp to a time after the disputeWindow is over. - vm.roll(block.number + _disputeWindow + 1); + vm.warp(block.timestamp + _disputeWindow + 1); // Mock and expect IOracle.responseCreatedAt to be called _mockAndExpect(address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_responseId)), abi.encode(1)); @@ -448,7 +444,7 @@ contract BondEscalationModule_Unit_DisputeResponse is BaseTest { uint256 _timestamp, IBondEscalationModule.RequestParameters memory _params ) public assumeFuzzable(address(_params.accountingExtension)) { - _timestamp = bound(_timestamp, 1, type(uint128).max); + _timestamp = bound(_timestamp, 1, 365 days); // Set deadline to timestamp so we are still in the bond escalation period _params.bondEscalationDeadline = _timestamp - 1; _params.disputeWindow = _timestamp + 1; @@ -522,8 +518,7 @@ contract BondEscalationModule_Unit_DisputeResponse is BaseTest { _requestId: _requestId, _responseId: _responseId, _disputeId: _disputeId, - _dispute: mockDispute, - _blockNumber: block.number + _dispute: mockDispute }); // Check: is the event emitted? @@ -578,7 +573,7 @@ contract BondEscalationModule_Unit_DisputeResponse is BaseTest { // Check: is the event emitted? vm.expectEmit(true, true, true, true, address(bondEscalationModule)); - emit ResponseDisputed(_requestId, _responseId, _disputeId, mockDispute, block.number); + emit ResponseDisputed(_requestId, _responseId, _disputeId, mockDispute); vm.prank(address(oracle)); bondEscalationModule.disputeResponse(mockRequest, mockResponse, mockDispute); diff --git a/solidity/test/unit/modules/dispute/BondedDisputeModule.t.sol b/solidity/test/unit/modules/dispute/BondedDisputeModule.t.sol index 5bfdf16a..4066ac4f 100644 --- a/solidity/test/unit/modules/dispute/BondedDisputeModule.t.sol +++ b/solidity/test/unit/modules/dispute/BondedDisputeModule.t.sol @@ -28,11 +28,7 @@ contract BaseTest is Test, Helpers { event DisputeStatusChanged(bytes32 indexed _disputeId, IOracle.Dispute _dispute, IOracle.DisputeStatus _status); event ResponseDisputed( - bytes32 indexed _requestId, - bytes32 indexed _responseId, - bytes32 indexed _disputeId, - IOracle.Dispute _dispute, - uint256 _blockNumber + bytes32 indexed _requestId, bytes32 indexed _responseId, bytes32 indexed _disputeId, IOracle.Dispute _dispute ); /** @@ -259,7 +255,7 @@ contract BondedDisputeModule_Unit_DisputeResponse is BaseTest { // Expect the event vm.expectEmit(true, true, true, true, address(bondedDisputeModule)); - emit ResponseDisputed(_requestId, _getId(mockResponse), _getId(mockDispute), mockDispute, block.number); + emit ResponseDisputed(_requestId, _getId(mockResponse), _getId(mockDispute), mockDispute); // Test: call disputeResponse vm.prank(address(oracle)); diff --git a/solidity/test/unit/modules/dispute/CircuitResolverModule.t.sol b/solidity/test/unit/modules/dispute/CircuitResolverModule.t.sol index f2ffb6c3..7d071dfd 100644 --- a/solidity/test/unit/modules/dispute/CircuitResolverModule.t.sol +++ b/solidity/test/unit/modules/dispute/CircuitResolverModule.t.sol @@ -43,11 +43,7 @@ contract BaseTest is Test, Helpers { // Events event DisputeStatusChanged(bytes32 indexed _disputeId, IOracle.Dispute _dispute, IOracle.DisputeStatus _status); event ResponseDisputed( - bytes32 indexed _requestId, - bytes32 indexed _responseId, - bytes32 indexed _disputeId, - IOracle.Dispute _dispute, - uint256 _blockNumber + bytes32 indexed _requestId, bytes32 indexed _responseId, bytes32 indexed _disputeId, IOracle.Dispute _dispute ); /** @@ -217,8 +213,7 @@ contract CircuitResolverModule_Unit_DisputeResponse is BaseTest { _requestId: mockResponse.requestId, _responseId: mockDispute.responseId, _disputeId: _getId(mockDispute), - _dispute: mockDispute, - _blockNumber: block.number + _dispute: mockDispute }); vm.prank(address(oracle)); diff --git a/solidity/test/unit/modules/dispute/RootVerificationModule.t.sol b/solidity/test/unit/modules/dispute/RootVerificationModule.t.sol index f19d0ce1..bf74e3bb 100644 --- a/solidity/test/unit/modules/dispute/RootVerificationModule.t.sol +++ b/solidity/test/unit/modules/dispute/RootVerificationModule.t.sol @@ -73,11 +73,7 @@ contract BaseTest is Test, Helpers { // Events event ResponseDisputed( - bytes32 indexed _requestId, - bytes32 indexed _responseId, - bytes32 indexed _disputeId, - IOracle.Dispute _dispute, - uint256 _blockNumber + bytes32 indexed _requestId, bytes32 indexed _responseId, bytes32 indexed _disputeId, IOracle.Dispute _dispute ); /** @@ -266,8 +262,7 @@ contract RootVerificationModule_Unit_DisputeResponse is BaseTest { _requestId: mockDispute.requestId, _responseId: mockDispute.responseId, _disputeId: _getId(mockDispute), - _dispute: mockDispute, - _blockNumber: block.number + _dispute: mockDispute }); vm.prank(address(oracle)); diff --git a/solidity/test/unit/modules/response/BondedResponseModule.t.sol b/solidity/test/unit/modules/response/BondedResponseModule.t.sol index ca7b7387..322e8207 100644 --- a/solidity/test/unit/modules/response/BondedResponseModule.t.sol +++ b/solidity/test/unit/modules/response/BondedResponseModule.t.sol @@ -30,7 +30,7 @@ contract BaseTest is Test, Helpers { uint256 internal _baseDisputeWindow = 12 hours; // Events - event ResponseProposed(bytes32 indexed _requestId, IOracle.Response _response, uint256 indexed _blockNumber); + event ResponseProposed(bytes32 indexed _requestId, IOracle.Response _response); event UnutilizedResponseReleased(bytes32 indexed _requestId, bytes32 indexed _responseId); /** @@ -170,7 +170,7 @@ contract BondedResponseModule_Unit_Propose is BaseTest { // Check: is the event emitted? vm.expectEmit(true, true, true, true, address(bondedResponseModule)); - emit ResponseProposed({_requestId: _requestId, _response: mockResponse, _blockNumber: block.number}); + emit ResponseProposed({_requestId: _requestId, _response: mockResponse}); vm.prank(address(oracle)); bondedResponseModule.propose(mockRequest, mockResponse, _proposer); @@ -231,19 +231,19 @@ contract BondedResponseModule_Unit_FinalizeRequest is BaseTest { } function test_revertsBeforeDeadline( - uint256 _responseCreationBlock, - uint256 _finalizationBlock, + uint256 _responseCreationTimestamp, + uint256 _finalizationTimestamp, uint256 _deadline, uint256 _disputeWindow ) public { // Amount of blocks to wait before finalizing a response _disputeWindow = bound(_disputeWindow, 10, 90_000); - // Last block in which a response can be proposed - _deadline = bound(_deadline, 100_000, type(uint128).max); + // Last timestamp in which a response can be proposed + _deadline = bound(_deadline, 100_000, 365 days); // Block in which the response was proposed - _responseCreationBlock = bound(_responseCreationBlock, _deadline - _disputeWindow + 1, _deadline - 1); + _responseCreationTimestamp = bound(_responseCreationTimestamp, _deadline - _disputeWindow + 1, _deadline - 1); // Block in which the request will be tried to be finalized - _finalizationBlock = bound(_finalizationBlock, _deadline, _responseCreationBlock + _disputeWindow - 1); + _finalizationTimestamp = bound(_finalizationTimestamp, _deadline, _responseCreationTimestamp + _disputeWindow - 1); // Check revert if deadline has not passed mockRequest.responseModuleData = abi.encode( @@ -265,7 +265,7 @@ contract BondedResponseModule_Unit_FinalizeRequest is BaseTest { // Check: does it revert if it's too early to finalize? vm.expectRevert(IBondedResponseModule.BondedResponseModule_TooEarlyToFinalize.selector); - vm.roll(_deadline - 1); + vm.warp(_deadline - 1); vm.prank(address(oracle)); bondedResponseModule.finalizeRequest(mockRequest, mockResponse, address(this)); @@ -278,13 +278,13 @@ contract BondedResponseModule_Unit_FinalizeRequest is BaseTest { _mockAndExpect( address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_getId(mockResponse))), - abi.encode(_responseCreationBlock) + abi.encode(_responseCreationTimestamp) ); // Check: does it revert if it's too early to finalize? vm.expectRevert(IBondedResponseModule.BondedResponseModule_TooEarlyToFinalize.selector); - vm.roll(_finalizationBlock); + vm.warp(_finalizationTimestamp); vm.prank(address(oracle)); bondedResponseModule.finalizeRequest(mockRequest, mockResponse, address(this)); } @@ -331,7 +331,7 @@ contract BondedResponseModule_Unit_FinalizeRequest is BaseTest { _disputeWindow = bound(_disputeWindow, 61, 365 days); // Check correct calls are made if deadline has passed - uint256 _deadline = block.number; + uint256 _deadline = block.timestamp; mockRequest.responseModuleData = abi.encode(accounting, _token, _bondSize, _deadline, _disputeWindow); bytes32 _requestId = _getId(mockRequest); mockResponse.requestId = _requestId; @@ -344,7 +344,7 @@ contract BondedResponseModule_Unit_FinalizeRequest is BaseTest { // Mock and expect IOracle.responseCreatedAt to be called _mockAndExpect( - address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_getId(mockResponse))), abi.encode(block.number) + address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_getId(mockResponse))), abi.encode(block.timestamp) ); // Mock and expect IAccountingExtension.release to be called @@ -358,7 +358,7 @@ contract BondedResponseModule_Unit_FinalizeRequest is BaseTest { vm.expectEmit(true, true, true, true, address(bondedResponseModule)); emit RequestFinalized({_requestId: _getId(mockRequest), _response: mockResponse, _finalizer: address(this)}); - vm.roll(block.number + _disputeWindow); + vm.warp(block.timestamp + _disputeWindow); vm.prank(address(oracle)); bondedResponseModule.finalizeRequest(mockRequest, mockResponse, address(this)); @@ -460,7 +460,9 @@ contract BondedResponseModule_Unit_ReleaseUnutilizedResponse is BaseTest { address(oracle), abi.encodeCall(IOracle.finalizedResponseId, (_requestId)), abi.encode(_finalizedResponseId) ); - _mockAndExpect(address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_responseId)), abi.encode(block.number)); + _mockAndExpect( + address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_responseId)), abi.encode(block.timestamp) + ); // Mock and expect IAccountingExtension.release to be called _mockAndExpect( @@ -500,7 +502,9 @@ contract BondedResponseModule_Unit_ReleaseUnutilizedResponse is BaseTest { // Mock and expect IOracle.finalizedResponseId to be called _mockAndExpect(address(oracle), abi.encodeCall(IOracle.finalizedResponseId, (_requestId)), abi.encode(0)); - _mockAndExpect(address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_responseId)), abi.encode(block.number)); + _mockAndExpect( + address(oracle), abi.encodeCall(IOracle.responseCreatedAt, (_responseId)), abi.encode(block.timestamp) + ); // Check: reverts? vm.expectRevert(IBondedResponseModule.BondedResponseModule_InvalidReleaseParameters.selector); diff --git a/yarn.lock b/yarn.lock index 11c7ce7c..a8aee5fa 100644 --- a/yarn.lock +++ b/yarn.lock @@ -193,10 +193,10 @@ dependencies: "@jridgewell/trace-mapping" "0.3.9" -"@defi-wonderland/prophet-core@0.0.0-0954a47f": - version "0.0.0-0954a47f" - resolved "https://registry.yarnpkg.com/@defi-wonderland/prophet-core/-/prophet-core-0.0.0-0954a47f.tgz#83124e103738a1d1d33b555ea774acbb90c0c153" - integrity sha512-MFJt7IQAkZys0wsJtFR4kt1x7zB1PMLr+jd40s14tLshlWm/7zrog8pfxUQ4EzYjVGkLKJm8jR8WcrEhCla39Q== +"@defi-wonderland/prophet-core@0.0.0-4d28a0ec": + version "0.0.0-4d28a0ec" + resolved "https://registry.yarnpkg.com/@defi-wonderland/prophet-core/-/prophet-core-0.0.0-4d28a0ec.tgz#228896bb7b9b239c6c25b4deefa8b204d87d7118" + integrity sha512-BF+gSf+nZWNByr9V2/eUvdt7zHlScP0hF47L+grlllMHRadm8T7Eboo6jpIHOgMpLkfNAEVsOyg2vfvgABzACQ== "@defi-wonderland/solidity-utils@0.0.0-3e9c8e8b": version "0.0.0-3e9c8e8b"