-
Notifications
You must be signed in to change notification settings - Fork 44
/
Copy pathBadConvertToAssetsRounding.sol
60 lines (48 loc) · 2.31 KB
/
BadConvertToAssetsRounding.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// SPDX-License-Identifier: AGPL-3.0-or-later
pragma solidity ^0.8.0;
import {ERC20} from "solmate/src/tokens/ERC20.sol";
import {ERC4626} from "solmate/src/mixins/ERC4626.sol";
import {FixedPointMathLib} from "solmate/src/utils/FixedPointMathLib.sol";
import {CryticERC4626PropertyTests} from "../../ERC4626PropertyTests.sol";
import {TestERC20Token} from "../../util/TestERC20Token.sol";
import {CryticERC4626RedeemUsingApproval} from "../../properties/RedeemUsingApprovalProps.sol";
import {CryticERC4626SenderIndependent} from "../../properties/SenderIndependentProps.sol";
import {CryticERC4626MustNotRevert} from "../../properties/MustNotRevertProps.sol";
import {CryticERC4626FunctionalAccounting} from "../../properties/FunctionalAccountingProps.sol";
import {CryticERC4626Rounding} from "../../properties/RoundingProps.sol";
import {CryticERC4626VaultProxy} from "../../properties/VaultProxy.sol";
contract BadConvertToAssetsRounding is ERC4626 {
using FixedPointMathLib for uint256;
uint256 private _totalAssets;
constructor(ERC20 _asset) ERC4626(_asset, "Test Vault", _asset.symbol()) {}
function totalAssets() public view virtual override returns (uint256) {
return _totalAssets;
}
function beforeWithdraw(uint256 assets, uint256) internal override {
_totalAssets = _totalAssets - assets;
}
function afterDeposit(uint256 assets, uint256) internal override {
_totalAssets = _totalAssets + assets;
}
function convertToAssets(
uint256 shares
) public view override returns (uint256) {
uint256 supply = totalSupply; // Saves an extra SLOAD if totalSupply is non-zero.
return supply == 0 ? shares : shares.mulDivUp(totalAssets(), supply);
}
function recognizeProfit(uint256 profit) public {
TestERC20Token(address(asset)).mint(address(this), profit);
_totalAssets += profit;
}
function recognizeLoss(uint256 loss) public {
TestERC20Token(address(asset)).burn(address(this), loss);
_totalAssets -= loss;
}
}
contract TestHarness is CryticERC4626Rounding {
constructor() {
TestERC20Token _asset = new TestERC20Token("Test Token", "TT", 18);
ERC4626 _vault = new BadConvertToAssetsRounding(ERC20(address(_asset)));
initialize(address(_vault), address(_asset), true);
}
}