Skip to content

Commit

Permalink
fix: proposer's bond should not be released when dispute is lost
Browse files Browse the repository at this point in the history
  • Loading branch information
gas1cent committed Nov 13, 2024
1 parent 822962a commit 506a405
Show file tree
Hide file tree
Showing 3 changed files with 5 additions and 18 deletions.
8 changes: 1 addition & 7 deletions solidity/contracts/modules/dispute/BondedDisputeModule.sol
Original file line number Diff line number Diff line change
Expand Up @@ -83,20 +83,14 @@ contract BondedDisputeModule is Module, IBondedDisputeModule {
_amount: _params.bondSize
});
} else if (_status == IOracle.DisputeStatus.Lost) {
// Disputer lost, we pay the proposer and release their bond
// Disputer lost, we pay the proposer
_params.accountingExtension.pay({
_requestId: _dispute.requestId,
_payer: _dispute.disputer,
_receiver: _dispute.proposer,
_token: _params.bondToken,
_amount: _params.bondSize
});
_params.accountingExtension.release({
_bonder: _dispute.proposer,
_requestId: _dispute.requestId,
_token: _params.bondToken,
_amount: _params.bondSize
});
}

emit DisputeStatusChanged({_disputeId: _disputeId, _dispute: _dispute, _status: _status});
Expand Down
8 changes: 4 additions & 4 deletions solidity/test/integration/Arbitration.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -106,9 +106,9 @@ contract Integration_Arbitration is IntegrationBase {
// Check: is the dispute updated as lost?
assertEq(uint256(_disputeStatus), uint256(IOracle.DisputeStatus.Lost));

// Check: does the disputer receive the disputer's bond?
// Check: does the proposer receive the disputer's bond?
uint256 _proposerBalance = _accountingExtension.balanceOf(proposer, usdc);
assertEq(_proposerBalance, _expectedBondSize * 2);
assertEq(_proposerBalance, _expectedBondSize);

// Check: does the disputer get its bond slashed?
uint256 _disputerBondedAmount = _accountingExtension.bondedAmountOf(disputer, usdc, _getId(mockRequest));
Expand Down Expand Up @@ -139,9 +139,9 @@ contract Integration_Arbitration is IntegrationBase {
// Check: is the dispute updated as lost?
assertEq(uint256(_disputeStatus), uint256(IOracle.DisputeStatus.Lost));

// Check: does the disputer receive the disputer's bond?
// Check: does the proposer receive the disputer's bond?
uint256 _proposerBalance = _accountingExtension.balanceOf(proposer, usdc);
assertEq(_proposerBalance, _expectedBondSize * 2);
assertEq(_proposerBalance, _expectedBondSize);

// Check: does the disputer get its bond slashed?
uint256 _disputerBondedAmount = _accountingExtension.bondedAmountOf(disputer, usdc, _getId(mockRequest));
Expand Down
7 changes: 0 additions & 7 deletions solidity/test/unit/modules/dispute/BondedDisputeModule.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -113,13 +113,6 @@ contract BondedDisputeModule_Unit_OnDisputeStatusChange is BaseTest {
abi.encode()
);

// Mock and expect the call to release, to the disputer
_mockAndExpect(
address(accountingExtension),
abi.encodeCall(accountingExtension.release, (mockResponse.proposer, _requestId, _token, _bondSize)),
abi.encode()
);

vm.prank(address(oracle));
bondedDisputeModule.onDisputeStatusChange(_getId(mockDispute), mockRequest, mockResponse, mockDispute);
}
Expand Down

0 comments on commit 506a405

Please sign in to comment.