-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
cmooney-20220805: Fixes for CS 5.4 Inconsistencies #84
Conversation
i'm not sure about the max borrow rate bounding on Aave. We already have this: dss-direct-deposit/src/plans/D3MAavePlan.sol Line 138 in e2bf302
@hexonaut might have thoughts too on the Aave side |
Ya I agree with @iamchrissmith here. 100% is pretty arbitrary. I think it only makes sense to bound by the actual reported bounds or leave it open. |
This reverts commit e2bf302.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm
Ready for review: Running 7 tests for src/tests/plans/D3MPlanBase.t.sol:D3MPlanBaseTest
[PASS] test_can_deny() (gas: 9155)
[PASS] test_can_rely() (gas: 33049)
[PASS] test_cannot_rely_without_auth() (gas: 12898)
[PASS] test_implements_active() (gas: 5485)
[PASS] test_implements_disable() (gas: 5354)
[PASS] test_implements_getTargetAssets() (gas: 5498)
[PASS] test_sets_creator_as_ward() (gas: 7823)
Test result: ok. 7 passed; 0 failed; finished in 863.38ms
Running 8 tests for src/tests/D3MOracle.t.sol:D3MOracleTest
[PASS] test_file_hub() (gas: 23675)
[PASS] test_peek() (gas: 38167)
[PASS] test_read() (gas: 57058)
[PASS] test_rely_deny() (gas: 24990)
[PASS] test_unauth_deny() (gas: 33857)
[PASS] test_unauth_file_hub() (gas: 9751)
[PASS] test_unauth_rely() (gas: 9523)
[PASS] test_vat_caged_file_hub() (gas: 15515)
Test result: ok. 8 passed; 0 failed; finished in 1.02s
Running 16 tests for src/tests/pools/D3MPoolBase.t.sol:D3MPoolBaseTest
[PASS] test_can_file_hub() (gas: 117438)
[PASS] test_can_rely_deny() (gas: 25012)
[PASS] test_cannot_deny_no_auth() (gas: 11993)
[PASS] test_cannot_file_hub_no_auth() (gas: 12196)
[PASS] test_cannot_file_hub_vat_caged() (gas: 18056)
[PASS] test_cannot_file_unknown_param() (gas: 17205)
[PASS] test_cannot_rely_no_auth() (gas: 12060)
[PASS] test_deposit_not_hub() (gas: 11584)
[PASS] test_hopes_on_hub() (gas: 12201)
[PASS] test_implements_postDebtChange() (gas: 5492)
[PASS] test_implements_preDebtChange() (gas: 5505)
[PASS] test_quit_no_auth() (gas: 12057)
[PASS] test_quit_vat_caged() (gas: 17829)
[PASS] test_sets_creator_as_ward() (gas: 7811)
[PASS] test_transfer_not_hub() (gas: 11755)
[PASS] test_withdraw_not_hub() (gas: 11518)
Test result: ok. 16 passed; 0 failed; finished in 210.77ms
Running 33 tests for src/tests/pools/D3MAavePool.t.sol:D3MAavePoolTest
[PASS] test_assetBalance_gets_adai_balanceOf_pool() (gas: 42087)
[PASS] test_can_file_hub() (gas: 118928)
[PASS] test_can_file_king() (gas: 38905)
[PASS] test_can_rely_deny() (gas: 25210)
[PASS] test_cannot_deny_no_auth() (gas: 12132)
[PASS] test_cannot_file_hub_no_auth() (gas: 12208)
[PASS] test_cannot_file_hub_vat_caged() (gas: 17964)
[PASS] test_cannot_file_king_no_auth() (gas: 9803)
[PASS] test_cannot_file_king_vat_caged() (gas: 15580)
[PASS] test_cannot_file_unknown_param() (gas: 17142)
[PASS] test_cannot_rely_no_auth() (gas: 12133)
[PASS] test_collect_claims_for_king() (gas: 147141)
[PASS] test_collect_no_king() (gas: 9992)
[PASS] test_deposit_calls_lending_pool_deposit() (gas: 185168)
[PASS] test_deposit_not_hub() (gas: 11572)
[PASS] test_hopes_on_hub() (gas: 12202)
[PASS] test_implements_postDebtChange() (gas: 5515)
[PASS] test_implements_preDebtChange() (gas: 5505)
[PASS] test_maxDeposit_returns_max_uint() (gas: 5541)
[PASS] test_maxWithdraw_gets_available_assets_assetBal() (gas: 47726)
[PASS] test_maxWithdraw_gets_available_assets_daiBal() (gas: 47825)
[PASS] test_quit_moves_balance() (gas: 41145)
[PASS] test_quit_no_auth() (gas: 12175)
[PASS] test_quit_vat_caged() (gas: 17932)
[PASS] test_redeemable_returns_adai() (gas: 7743)
[PASS] test_sets_creator_as_ward() (gas: 7831)
[PASS] test_sets_dai_value() (gas: 7875)
[PASS] test_transfer_adai() (gas: 69747)
[PASS] test_transfer_adai_vat_caged() (gas: 74103)
[PASS] test_transfer_not_hub() (gas: 11903)
[PASS] test_withdraw_calls_lending_pool_withdraw() (gas: 142145)
[PASS] test_withdraw_calls_lending_pool_withdraw_vat_caged() (gas: 142831)
[PASS] test_withdraw_not_hub() (gas: 11595)
Test result: ok. 33 passed; 0 failed; finished in 1.35s
Running 2 tests for src/tests/D3MMom.t.sol:D3MMomTest
[PASS] test_can_disable_plan_owner() (gas: 19104)
[PASS] test_disable_no_auth() (gas: 15848)
Test result: ok. 2 passed; 0 failed; finished in 1.58ms
Running 26 tests for src/tests/plans/D3MAavePlan.t.sol:D3MAavePlanTest
[PASS] test_bar_zero_not_active() (gas: 8627)
[PASS] test_can_deny() (gas: 9355)
[PASS] test_can_file_bar() (gas: 33080)
[PASS] test_can_file_interestStratgey() (gas: 18655)
[PASS] test_can_rely() (gas: 33259)
[PASS] test_cannot_file_unknown_address_param() (gas: 9623)
[PASS] test_cannot_file_unknown_uint_param() (gas: 9585)
[PASS] test_cannot_file_without_auth() (gas: 9612)
[PASS] test_cannot_rely_without_auth() (gas: 13063)
[PASS] test_disable_without_auth() (gas: 89100)
[PASS] test_getTargetAssets_bar_zero() (gas: 8684)
[PASS] test_implements_active() (gas: 7605)
[PASS] test_implements_disable() (gas: 28232)
[PASS] test_implements_getTargetAssets() (gas: 113831)
[PASS] test_interestStrategy_changed_not_active() (gas: 92678)
[PASS] test_interestStrategy_not_changed_active() (gas: 87117)
[PASS] test_interest_rate_calc() (gas: 2981283)
[PASS] test_set_bar_too_high_unwinds() (gas: 92178)
[PASS] test_set_bar_too_low_unwinds() (gas: 17688)
[PASS] test_sets_InterestStrategy() (gas: 9892)
[PASS] test_sets_adai() (gas: 7791)
[PASS] test_sets_adaiRevision_value() (gas: 5438)
[PASS] test_sets_creator_as_ward() (gas: 7831)
[PASS] test_sets_dai_value() (gas: 7776)
[PASS] test_sets_stableDebt() (gas: 38070)
[PASS] test_sets_variableDebt() (gas: 38136)
Test result: ok. 26 passed; 0 failed; finished in 2.83s
Running 28 tests for src/tests/integration/D3MCompound.t.sol:D3MCompoundTest
[PASS] test_barb_zero() (gas: 648896)
[PASS] test_cage_exit() (gas: 569983)
[PASS] test_cage_perm_insufficient_liquidity() (gas: 1088599)
[PASS] test_cage_temp_insufficient_liquidity() (gas: 1045468)
[PASS] test_collect_comp() (gas: 598493)
[PASS] test_collect_comp_king_not_set() (gas: 453446)
[PASS] test_collect_interest() (gas: 584699)
Logs:
dai: 2122867400782837600882000000000.000000000000000000
[PASS] test_direct_deposit_mom() (gas: 612384)
[PASS] test_fully_unwind_debt_paid_back() (gas: 771007)
[PASS] test_hit_debt_ceiling() (gas: 755284)
[PASS] test_insufficient_liquidity_for_reap_fees() (gas: 840602)
[PASS] test_insufficient_liquidity_for_unwind_fees() (gas: 1091144)
[PASS] test_quit_cull() (gas: 592222)
[PASS] test_quit_no_cull() (gas: 630692)
[PASS] test_reap_caged() (gas: 493060)
[PASS] test_set_tau_not_caged() (gas: 26331)
[PASS] test_shutdown_cant_cull() (gas: 483675)
[PASS] test_target_decrease() (gas: 479667)
[PASS] test_target_increase() (gas: 649619)
[PASS] test_target_increase_insufficient_liquidity() (gas: 216133)
[PASS] test_uncull_not_culled() (gas: 742968)
[PASS] test_uncull_not_shutdown() (gas: 495940)
[PASS] test_unwind_culled_then_mcd_caged() (gas: 1615060)
[PASS] test_unwind_mcd_caged_not_skimmed() (gas: 1358031)
[PASS] test_unwind_mcd_caged_skimmed() (gas: 1388313)
[PASS] test_unwind_mcd_caged_wait_done() (gas: 1059277)
[PASS] test_utilization_over_100_percent() (gas: 1024457)
[PASS] test_wind_partial_unwind_wind_debt_paid_back() (gas: 1017538)
Test result: ok. 28 passed; 0 failed; finished in 6.48s
Running 27 tests for src/tests/integration/D3MAave.t.sol:D3MAaveTest
[PASS] test_bar_zero() (gas: 775867)
[PASS] test_cage_exit() (gas: 666064)
[PASS] test_cage_perm_insufficient_liquidity() (gas: 1134824)
[PASS] test_cage_temp_insufficient_liquidity() (gas: 1095342)
[PASS] test_collect_interest() (gas: 658699)
Logs:
dai: 823798147152771843685000000000.000000000000000000
[PASS] test_collect_stkaave() (gas: 558633)
[PASS] test_collect_stkaave_king_not_set() (gas: 530366)
[PASS] test_direct_deposit_mom() (gas: 665156)
[PASS] test_fully_unwind_debt_paid_back() (gas: 900956)
[PASS] test_hit_debt_ceiling() (gas: 796291)
[PASS] test_insufficient_liquidity_for_reap_fees() (gas: 865095)
[PASS] test_insufficient_liquidity_for_unwind_fees() (gas: 1085834)
[PASS] test_quit_cull() (gas: 692548)
[PASS] test_quit_no_cull() (gas: 726357)
[PASS] test_reap_caged() (gas: 560738)
[PASS] test_set_tau_not_caged() (gas: 26331)
[PASS] test_shutdown_cant_cull() (gas: 551307)
[PASS] test_target_decrease() (gas: 650393)
[PASS] test_target_increase() (gas: 707432)
[PASS] test_target_increase_insufficient_liquidity() (gas: 211446)
[PASS] test_uncull_not_culled() (gas: 746706)
[PASS] test_uncull_not_shutdown() (gas: 550769)
[PASS] test_unwind_culled_then_mcd_caged() (gas: 1580004)
[PASS] test_unwind_mcd_caged_not_skimmed() (gas: 1358556)
[PASS] test_unwind_mcd_caged_skimmed() (gas: 1388775)
[PASS] test_unwind_mcd_caged_wait_done() (gas: 1088334)
[PASS] test_wind_partial_unwind_wind_debt_paid_back() (gas: 1068653)
Test result: ok. 27 passed; 0 failed; finished in 6.48s
Running 71 tests for src/tests/D3MHub.t.sol:D3MHubTest
[PASS] testFail_hub_upgrade_kills_old_hub() (gas: 3469258)
[PASS] test_approvals() (gas: 20086)
[PASS] test_cage_d3m_already_caged() (gas: 42069)
[PASS] test_cage_d3m_mcd_caged() (gas: 21863)
[PASS] test_cage_d3m_no_auth() (gas: 9588)
[PASS] test_cage_d3m_with_auth() (gas: 48402)
[PASS] test_cage_ilk_after_uncull() (gas: 734653)
[PASS] test_cage_ilk_before_uncull() (gas: 638280)
[PASS] test_can_file_end() (gas: 24071)
[PASS] test_can_file_plan() (gas: 34399)
[PASS] test_can_file_pool() (gas: 34331)
[PASS] test_can_file_tau() (gas: 26436)
[PASS] test_can_file_vow() (gas: 23899)
[PASS] test_cull() (gas: 419001)
[PASS] test_cull_debt_paid_back() (gas: 619751)
[PASS] test_cull_no_auth_time_passed() (gas: 427013)
[PASS] test_exec_lock_protection() (gas: 11453)
[PASS] test_exec_no_ilk() (gas: 43200)
[PASS] test_exec_rate_not_one() (gas: 65452)
[PASS] test_exec_spot_not_one() (gas: 58029)
[PASS] test_exit() (gas: 402021)
[PASS] test_exit_lock_protection() (gas: 11641)
[PASS] test_fully_unwind_after_debt_paid_back() (gas: 597531)
[PASS] test_hub_not_live_pool_file() (gas: 42473)
[PASS] test_hub_upgrade_new_d3ms() (gas: 5003146)
[PASS] test_hub_upgrade_same_d3ms() (gas: 3403466)
[PASS] test_no_cull_already_culled() (gas: 411944)
[PASS] test_no_cull_mcd_caged() (gas: 365067)
[PASS] test_no_cull_no_ilk() (gas: 14513)
[PASS] test_no_cull_pool_live() (gas: 335288)
[PASS] test_no_cull_unauth_too_soon() (gas: 365470)
[PASS] test_no_reap_mcd_caged() (gas: 639104)
[PASS] test_no_reap_plan_inactive() (gas: 372621)
[PASS] test_no_reap_pool_caged() (gas: 390548)
[PASS] test_no_uncull_mcd_live() (gas: 411901)
[PASS] test_no_uncull_not_culled() (gas: 366404)
[PASS] test_plan_upgrade() (gas: 862368)
[PASS] test_pool_upgrade_quit() (gas: 1676793)
[PASS] test_pool_upgrade_unwind_wind() (gas: 1650202)
[PASS] test_quit_culled() (gas: 444871)
[PASS] test_quit_not_culled() (gas: 469015)
[PASS] test_reap_available_liquidity() (gas: 445096)
[PASS] test_reap_debt_paid_back() (gas: 557963)
[PASS] test_reap_lock_protection() (gas: 11553)
[PASS] test_reap_not_enough_liquidity() (gas: 491265)
[PASS] test_unauth_file_pool() (gas: 10002)
[PASS] test_unauth_file_tau() (gas: 9857)
[PASS] test_uncull() (gas: 496614)
[PASS] test_unknown_address_file() (gas: 17068)
[PASS] test_unknown_ilk_address_file() (gas: 17112)
[PASS] test_unknown_uint256_file() (gas: 9455)
[PASS] test_unwind_bar_zero() (gas: 478481)
[PASS] test_unwind_fixes_after_debt_paid_back() (gas: 632730)
[PASS] test_unwind_global_Line_lowered() (gas: 488002)
[PASS] test_unwind_ilk_line_lowered() (gas: 487205)
[PASS] test_unwind_mcd_caged() (gas: 752432)
[PASS] test_unwind_mcd_caged_debt_paid_back() (gas: 840670)
[PASS] test_unwind_plan_not_active() (gas: 480294)
[PASS] test_unwind_pool_caged() (gas: 498208)
[PASS] test_unwind_pool_caged_debt_paid_back() (gas: 617934)
[PASS] test_unwind_target_less_amount() (gas: 480136)
[PASS] test_vat_not_live_address_file() (gas: 295214)
[PASS] test_vat_not_live_ilk_address_file() (gas: 302628)
[PASS] test_wind_after_debt_paid_back() (gas: 584686)
[PASS] test_wind_limited_Line() (gas: 348116)
[PASS] test_wind_limited_by_maxDeposit() (gas: 464224)
[PASS] test_wind_limited_by_pool_loss() (gas: 505743)
[PASS] test_wind_limited_ilk_line() (gas: 347467)
[PASS] test_wind_limited_to_zero_by_maxDeposit() (gas: 383481)
[PASS] test_wind_unwind_line_limited_debt_paid_back() (gas: 731091)
[PASS] test_wind_unwind_non_standard_token() (gas: 3178687)
Test result: ok. 71 passed; 0 failed; finished in 5.10s
Running 34 tests for src/tests/plans/D3MCompoundPlan.t.sol:D3MCompoundPlanTest
[PASS] test_barb_zero_not_active() (gas: 8496)
[PASS] test_calculate_above_normal_rate() (gas: 41815)
[PASS] test_calculate_base_rate() (gas: 30271)
[PASS] test_calculate_below_normal_rate() (gas: 39846)
[PASS] test_calculate_current_rate() (gas: 60939)
[PASS] test_calculate_exactly_normal_rate() (gas: 39696)
[PASS] test_calculate_extremely_high_rate() (gas: 41972)
[PASS] test_calculate_extremely_low_rate() (gas: 39800)
[PASS] test_calculate_zero_rate() (gas: 27432)
[PASS] test_can_deny() (gas: 9265)
[PASS] test_can_file_barb() (gas: 33018)
[PASS] test_can_file_delegate() (gas: 16542)
[PASS] test_can_file_rateModel() (gas: 18601)
[PASS] test_can_rely() (gas: 33191)
[PASS] test_cannot_file_address_without_auth() (gas: 11826)
[PASS] test_cannot_file_uint_without_auth() (gas: 11634)
[PASS] test_cannot_file_unknown_address_param() (gas: 9653)
[PASS] test_cannot_file_unknown_uint_param() (gas: 9475)
[PASS] test_cannot_rely_without_auth() (gas: 13106)
[PASS] test_delegate_changed_not_active() (gas: 59618)
[PASS] test_disable_without_auth() (gas: 51923)
[PASS] test_getTargetAssets_barb_zero() (gas: 8641)
[PASS] test_getTargetAssets_current_rate() (gas: 114029)
[PASS] test_implements_active() (gas: 7604)
[PASS] test_implements_disable() (gas: 23728)
[PASS] test_implements_getTargetAssets() (gas: 105857)
[PASS] test_interest_rate_calc() (gas: 2094216)
[PASS] test_rate_model_changed_not_active() (gas: 58489)
[PASS] test_rate_model_not_changed_active() (gas: 48012)
[PASS] test_sets_barb_too_high() (gas: 9319)
[PASS] test_sets_cdai() (gas: 7770)
[PASS] test_sets_creator_as_ward() (gas: 7808)
[PASS] test_sets_rateModel() (gas: 9871)
[PASS] test_very_high_utilization_supported() (gas: 37968)
Test result: ok. 34 passed; 0 failed; finished in 6.48s
Running 35 tests for src/tests/pools/D3MCompoundPool.t.sol:D3MCompoundPoolTest
[PASS] test_assetBalance_gets_dai_balanceOf_pool() (gas: 248252)
[PASS] test_can_file_hub() (gas: 118974)
[PASS] test_can_file_king() (gas: 38772)
[PASS] test_can_rely_deny() (gas: 25244)
[PASS] test_cannot_deny_no_auth() (gas: 12013)
[PASS] test_cannot_file_hub_no_auth() (gas: 12193)
[PASS] test_cannot_file_hub_vat_caged() (gas: 18009)
[PASS] test_cannot_file_king_no_auth() (gas: 11766)
[PASS] test_cannot_file_king_vat_caged() (gas: 15625)
[PASS] test_cannot_file_unknown_param() (gas: 17232)
[PASS] test_cannot_rely_no_auth() (gas: 12036)
[PASS] test_collect_claims_for_king() (gas: 2226705)
[PASS] test_collect_no_king() (gas: 12297)
[PASS] test_collect_without_claim() (gas: 357348)
[PASS] test_deposit_calls_cdai_deposit() (gas: 269175)
[PASS] test_deposit_not_hub() (gas: 11614)
[PASS] test_hopes_on_hub() (gas: 12245)
[PASS] test_implements_postDebtChange() (gas: 5537)
[PASS] test_implements_preDebtChange() (gas: 60871)
[PASS] test_maxDeposit_returns_max_uint() (gas: 5519)
[PASS] test_maxWithdraw_gets_available_assets() (gas: 253634)
[PASS] test_quit_moves_balance() (gas: 305979)
[PASS] test_quit_no_auth() (gas: 12010)
[PASS] test_quit_vat_caged() (gas: 17893)
[PASS] test_redeemable_returns_cdai() (gas: 7764)
[PASS] test_sets_cdai_value() (gas: 7833)
[PASS] test_sets_comptroller_value() (gas: 7743)
[PASS] test_sets_creator_as_ward() (gas: 7904)
[PASS] test_sets_dai_value() (gas: 7831)
[PASS] test_transfer_cdai() (gas: 324913)
[PASS] test_transfer_cdai_vat_caged() (gas: 325582)
[PASS] test_transfer_not_hub() (gas: 11774)
[PASS] test_withdraw_calls_cdai_withdraw() (gas: 280194)
[PASS] test_withdraw_calls_cdai_withdraw_vat_caged() (gas: 286597)
[PASS] test_withdraw_not_hub() (gas: 11570)
Test result: ok. 35 passed; 0 failed; finished in 13.87s |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
* cmooney-20220805: Fixes for CS 5.4 Inconsistencies * bound bar in AAVE plan to MAX_BORROW_RATE * Revert "bound bar in AAVE plan to MAX_BORROW_RATE" This reverts commit e2bf302.
* Modularize (#31) * initial separate into d3m target and d3m join contracts * initial update of tests and file reorg/rename * add approval for the join to allow the target to move gems and update the target withdraw to pull the adai first * update interfaces and require successful transferFrom" * update tests and fix reward claimer * allow filing a new target * minor clean up * remove unneeded interface * update interface and add validTarget helper * add missing arg * initial Test Target contract * update test forge path to accept new match arguments * add new line * update Target to not need wat parameter * add test gem for Join testing * allow for bar = 0 case in tests * add give allowance to test token and transfers to target * update Join to fix target cage bug * we don't need internal balance tracking for the test target * add a test rewards contract * add join specific tests for covering the interactions with the Vat * make targets joins and have them hold balance Co-authored-by: Julien <[email protected]> * update testing and d3m Join so that the Target holds the balances in ERC and Vat * rename Join to Hub * rename Target to Join * make Hub compatible with multiple d3m joins: * add balance check to join * update test for hub+joins model * update helper for Hub approach * update copyrights * update tests and require d3m be live for admin actions * use ilks instead * organize files and change Join->Pool * switch to pool internally on hub * update test to use Pool naming * initial update for separation of Plans from Pools * minor test updates * initial breakdown of pool into base * add Plan base * clean up * Update to Eip 4626 (#34) * initial update of tests and file reorg/rename * update tests and fix reward claimer * organize files and change Join->Pool * switch to pool internally on hub * initial update for separation of Plans from Pools * update language for EIP-4626 * fix tests after rename * maxWithdraw and asset balances - PR comments from @hexonaut * fix share transfer amounts * fix tests * remove helper function * remove helper function tests * fix unwind balance * fix asset balance in test pool * move bar to plan * use plan base * Fix tests * Modularize upd 325 (#37) * Clean up vars and add Cage event * Upd revert names * Upd revert names in Pool Base * emit Hope and Nope events on Pool Base * Add Quit event * Add emit for clarity * Add Exit event * uint => uint256 * rm math * wards ocd * start updating aave to use base * shorten names * remove chainlog from d3m hub * remove dai daiJoin from hub * make common interfaces to use in tests * remove ds-value submodule * update aave tests for no ds-value * add todos * do daiJoin work in hub @gbalabasquer * PR comments to clean up hub * clean up add TODO * join directly to vow * PR feedback @talbaneth and @gbalabasquer * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * remove collect and move plan to Hub from pool * abstract bar to individual plan implementations * read and assign end on when necessary * don't read the plan * adjust unwind daiJoin interaction to match wind * fix aave tests - WIP * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * PR clean up comments * add recover tokens function to pool * remove convertToAssets from base * PR comments: remove bar and pool from bases and gas efficiency * change aave assetBalance calc * fix mom bar filing * update test for Aave share balance transfer in exit * revert convert to shares in exit since we should already be dealing with shares in wad * fix permissionless repay aave test * fix remaining aave test * reorganize interfaces into tests * move constant * remove unused interface functions * remove maxBar from base * remove events * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * fix silly variable setting Co-authored-by: talbaneth <[email protected]> * move plans to separate folder * PR comments - update auths * move share to pools out of base * initial switch to returning target assets * WIP change to return targetAsset * accrued if needed before getting balance * integrate @hexonaut 's Aave calc fix * Delete empty file * plan base unit tests * add pool base tests * re-order accrueIfNeeded and maxWithdraw Co-authored-by: talbaneth <[email protected]> * remove unneeded math Co-authored-by: talbaneth <[email protected]> * consistent filing for ilks * better documentations of Ilk in Hub Co-authored-by: talbaneth <[email protected]> * remove unneeded safe math * don't store culled * unused return variable Co-authored-by: talbaneth <[email protected]> * update getTargetAssets * pr feedback * update share balance for aave to be scaled * Mom can disable plans * make files external * initial AaveDai plan tests * more AaveDaiPlan unit tests * add disable to plan base * fix missing override * check dai balance in wind * denominate shares in hub in dai/gems and add transferAllShares function * add approxEq for checking dai depositing * AaveDaiPool tests * move deposit check to pool * clean up remaining hub tests * add Mom tests * update base and share calculations * update aaave deposit checking * remove named return Co-authored-by: talbaneth <[email protected]> * remove debugging * update comments and errors * fix rounding error * fix possible bug with debt > debt ceiling * pr comments and clean up * add file events * pr comments on events and requires * add missing auth and test coverage * consolidate debt usage to totalDebt instead of adding it multiple times * update unwind comment Co-authored-by: talbaneth <[email protected]> * fix adai pool comment Co-authored-by: talbaneth <[email protected]> * update comment * remove hub cage * take global line into account and unwind if needed * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * fix indentation * add fees to unwind event * Some changes to exec (bit simplication and check vat.Line) (#40) * Some changes to exec (bit simplication and check vat.Line) * Add comments * Update src/DssDirectDepositHub.sol Co-authored-by: talbaneth <[email protected]> * Update src/DssDirectDepositHub.sol Co-authored-by: talbaneth <[email protected]> * Add tests Co-authored-by: talbaneth <[email protected]> * Add invalid target check to exec() normal path * add cull rebalancing * remove hub rely from pool * remove duplicate rely * remove live/cage from pool * ShareTokenLike -> ATokenLike * don't call internal transfer * type pool and adai * remove hub from pool base * remove params from collect * change plan base to interface * update errors and contract name for plan interface change * convert Pool Base to Interface * add maxDeposit to pools * account for maxDeposit in Hub.exec by either unwinding or limiting wind * remove extra space * revert hub interface integration * maxDeposit is per deposit call * remove validTarget add condition to disable for aave * add smaller maxDeposit test * update plan interface * update Pool Interface * remove extra cast * change from seth check to cast check for forge test * code clean up Co-authored-by: talbaneth <[email protected]> * pr comments clean up * inline amount for collect * catch up Test pool * update maxBar to be used where it should and be internal * add active() to plans * add active to Pools * add check in hub that pool and plan are active or unwind * allow filing interestStrategy Co-authored-by: Julien <[email protected]> Co-authored-by: Brian McMichael <[email protected]> Co-authored-by: talbaneth <[email protected]> Co-authored-by: Gonzalo Balabasquer <[email protected]> * add space * update spacing, visibility and location of RAY * add Natspec comments to base Pool, Plan and Hub contracts (#43) * add docs for Hub * add comments to plan interface * fix ilk cage docs * add pool docs * comment clean up * fix grammar Co-authored-by: talbaneth <[email protected]> * spelling Co-authored-by: talbaneth <[email protected]> * unify wrapping point and punctuation * clarify plan doc * pr comments * contract -> interface * update comments Co-authored-by: talbaneth <[email protected]> Co-authored-by: talbaneth <[email protected]> * Extract test_sets_dai_value from base tests. This is since `asset` is not part of the interface for plan/pool. For example in Compound I just call it `dai` (and not asset). * Remove redundant rely * grammar Co-authored-by: Kurt Barry <[email protected]> * fix if condition for block number (#48) * remove space * fix end address Co-authored-by: Nazzareno Massari <[email protected]> * update end in aave tests Co-authored-by: Nazzareno Massari <[email protected]> * improve skaave failure test * update pragma to be more flexible * add hope/nope to the pool to be able to update the hub * use interfaces in Hub * add nope to hub * add comments for hub.nope() * fix storage ordering and move auth functions * add tests for pool quit and unwind/wind upgrade paths * add test for plan swap * add hub upgrade tests * reorder events * remove unneeded cage event * add getter functions for d3m ilks * add ink/art to cull event * add wad to uncull event * add bar == 0 sets not active * add exec fail test for non-existant ilk * add pre and post hooks for exec and reap * Forge ci (#49) * try forge ci * add ETH_RPC_URL and rpc flags * remove check gas * remove nix * combine workflow commands * remove pull_request trigger * fix blocks * update step names Co-authored-by: Nazzareno Massari <[email protected]> Co-authored-by: Nazzareno Massari <[email protected]> * fix ordering of internal functions in hub * remove unneeded calculateTargetSupply public function * move aave integration test out of pool folder * fix comment typo Co-authored-by: Kurt Barry <[email protected]> * fix integration test relative paths * fix file function consistency * remove unneeded param from unwind * add rate == 1 require to exec * fix spacing * check active on pool/plan in reap * fix cull comment * store tic as timestamp + tau * remove tau cage test fail * fix requires in reap * add bool return to deposit and withdraw * add withdraw require to reap * remove unneeded approval for pool to aave pool for adai * change from recoverTokens to recoverDai for Pools * prevent dup caging of pool * use wad in pool functions * pin solc in ci * add test showing left over ink after cage if debt repaid * Solc upgrade (#47) * initial 0.8.13 upgrade changes * clear warnings * remove safe math from Hub * remove safe math from Test Gem * remove safe math from Dai Pool * remove safe math from dai plan * update ci nix * update dappPkg * update dapp tests for 0.8.13 * add quotes Co-authored-by: Nazzareno Massari <[email protected]> * update nix dapp version * change to 0.6.12 or greater * clean up Co-authored-by: talbaneth <[email protected]> Co-authored-by: Gonzalo Balabasquer <[email protected]> * lock pragma to ^0.8.14 * add unchecked to hub * add unchecked to Aave Plan * remove math functions * fix solc version in scripts Co-authored-by: Gonzalo Balabasquer <[email protected]> * update int overflow check * fix merge problems * fix makefile Co-authored-by: Nazzareno Massari <[email protected]> * add safe math comment back * pin solc in ci to 0.8.14 * fix order of operations Co-authored-by: Nazzareno Massari <[email protected]> * fix fake address Co-authored-by: Nazzareno Massari <[email protected]> * revert fake address change Co-authored-by: Nazzareno Massari <[email protected]> Co-authored-by: talbaneth <[email protected]> Co-authored-by: Gonzalo Balabasquer <[email protected]> * add test for wind/unwind token with less than 18 decimals * move unwind int overflow check to min from require * move int overflow for wind to min checks * refactor toWind to one assignment * make unwind params easier to read * add reentrancy protection in hub * add test that cull fails with no ilk * update mom events * rename intrestStrategy to tack * remove require in file and limit target rate to max bar * set rate to max of base or target rate * unwind if bar is out of bounds * remove make deploy * don't check adai address in constructor * emit gift for king * fix spacing Co-authored-by: talbaneth <[email protected]> * fix spacing Co-authored-by: talbaneth <[email protected]> * reorder pool plan variables * DssDirectDepositHub => D3MHub and D3MAaveDai => D3MAave (#61) * `MAXINT256` (#57) Co-authored-by: Gonzalo Balabasquer <[email protected]> * Fix error message * replace tack filing what * add higher level unchecked for aave plan math * add what param for pre/post debt changes * reorder hub immutables * add comments with links to aave contracts * get rewards claimer from adai * remove recoverDai function * add loss test by @hexonaut * remove hub.nope() * Add FileCopyRightText (#62) * Remove quit (#64) * remove unused var Co-authored-by: talbaneth <[email protected]> * update comment for transfer * add redeemable function for pools * clean up aave plan active * update comments in hub for multiple d3ms Co-authored-by: Julien <[email protected]> * RAY == 1 Co-authored-by: Gonzalo Balabasquer <[email protected]> * add require to prevent winding over MAXINT256 * replace divup with best practice version * remove return on deposit/withdraw * add mode protection * rename getter functions and clear shadow warnings (#65) * rename getter functions and clear shadow warnings * switch _ location * keep vow and end consistent with _ before in functions * fix overflow wind check * remove returns from transfers * remove Pool.active and clean up (#63) * add wild() to pools and plans and allow permissionless caging * add hub tests for wild caging and fix auth * make wild pure * add paused check on pools and plans to prevent any exec action * add ability to pause pool and ensure exec doesn't change * add ability to pause plan and ensure exec doesn't change * add ability to unpause pool and resume exec * add ability to unpause plan and resume exec * add pause to Mom * remove active from pools * remove pause and wild * clean up variables * remove unneeded events * remove spacing * align &s * Update README (#67) * update readme to v2 and add more detail * Update README.md Co-authored-by: Chris Smith <[email protected]> * Update README.md Co-authored-by: Chris Smith <[email protected]> * Update README.md Co-authored-by: Chris Smith <[email protected]> * Update README.md Co-authored-by: Chris Smith <[email protected]> * update image * add holds lp token Co-authored-by: Chris Smith <[email protected]> * fix imgur link to ipfs Co-authored-by: Nazzareno Massari <[email protected]> * fix spacing in aave plan * No governance after cage (#60) * Remove governance access from pool after shutdown * New modifier onlyHub * Remove spacing * Add more tests * Move some tests from AavePool to Base one * Update src/tests/stubs/D3MTestPool.sol Co-authored-by: Chris Smith <[email protected]> * Update src/pools/D3MAavePool.sol Co-authored-by: talbaneth <[email protected]> * Update src/pools/D3MAavePool.sol Co-authored-by: talbaneth <[email protected]> * No need vat.live check on deny * Fix interface message * Remove unnecessary local variable * transferAll => quit * Move more tests to base Co-authored-by: Chris Smith <[email protected]> Co-authored-by: talbaneth <[email protected]> * Add D3MOracle (#59) * Add D3MOracle * peek and read with same behaviour + better tests * Update src/D3MOracle.sol Co-authored-by: talbaneth <[email protected]> * Update src/D3MOracle.sol Co-authored-by: talbaneth <[email protected]> * Update src/D3MOracle.sol Co-authored-by: talbaneth <[email protected]> * Fix message * Add comment * Minor change Co-authored-by: talbaneth <[email protected]> * Assert revert (#72) * Implement AssertRevert * Use assertRevert in all the other test files * Add newline * No more special function * dapp uninstall ds-test * dapp install makerdao/dss-test * Use dss-test dependency * Move test files * rename asset to dai in aave pool * clean up items * enforce spot == RAY * add clarity comment for bar = 0 Co-authored-by: talbaneth <[email protected]> * Fix what filing * uint256 standard Co-authored-by: Gonzalo Balabasquer <[email protected]> * change enum name * do not pass vat to hub * minor clean up items in hub * dapp upgrade dss-test * Introduce _fix function and add tests (#70) * add initial debt repay tests * add test where we wind first * Introduce new function fix * Working on tests * Finish test * Fix reap test * Fix remaining tests and do some clean up in others * clean up hub tests * add test for fix during shutdown * show end fail case where we get bad gems * No fix after shutdown * add test for module cage with debt paid back and fix * More checks and fix some others * fix as internal function * Remove require * Update src/tests/interfaces/interfaces.sol Co-authored-by: talbaneth <[email protected]> * Update src/tests/D3MHub.t.sol Co-authored-by: talbaneth <[email protected]> * Add more checks * Improve test * Remove rebalance in cull as it isn't actually the most correct thing * fix comment * add to gitignore * Remove file * Replace min to require for MAXINT256 check * Fixes Co-authored-by: Gonzalo Balabasquer <[email protected]> Co-authored-by: talbaneth <[email protected]> * Fix FileCopyRightText + Cleanups (#75) * Align pool and plan code style to Compound * more alignemnts * Minor alignment changes and return comment * Move && a bit * return back from interface alignment * Update src/pools/D3MAavePool.sol Co-authored-by: Nazzareno Massari <[email protected]> * Compound (#51) * initial separate into d3m target and d3m join contracts * initial update of tests and file reorg/rename * add approval for the join to allow the target to move gems and update the target withdraw to pull the adai first * update interfaces and require successful transferFrom" * update tests and fix reward claimer * allow filing a new target * minor clean up * remove unneeded interface * update interface and add validTarget helper * add missing arg * initial Test Target contract * update test forge path to accept new match arguments * add new line * update Target to not need wat parameter * add test gem for Join testing * allow for bar = 0 case in tests * add give allowance to test token and transfers to target * update Join to fix target cage bug * we don't need internal balance tracking for the test target * add a test rewards contract * add join specific tests for covering the interactions with the Vat * make targets joins and have them hold balance Co-authored-by: Julien <[email protected]> * update testing and d3m Join so that the Target holds the balances in ERC and Vat * rename Join to Hub * rename Target to Join * make Hub compatible with multiple d3m joins: * add balance check to join * update test for hub+joins model * update helper for Hub approach * update copyrights * update tests and require d3m be live for admin actions * use ilks instead * organize files and change Join->Pool * switch to pool internally on hub * update test to use Pool naming * initial update for separation of Plans from Pools * minor test updates * initial breakdown of pool into base * add Plan base * clean up * Update to Eip 4626 (#34) * initial update of tests and file reorg/rename * update tests and fix reward claimer * organize files and change Join->Pool * switch to pool internally on hub * initial update for separation of Plans from Pools * update language for EIP-4626 * fix tests after rename * maxWithdraw and asset balances - PR comments from @hexonaut * fix share transfer amounts * fix tests * remove helper function * remove helper function tests * fix unwind balance * fix asset balance in test pool * move bar to plan * use plan base * Fix tests * Modularize upd 325 (#37) * Clean up vars and add Cage event * Upd revert names * Upd revert names in Pool Base * emit Hope and Nope events on Pool Base * Add Quit event * Add emit for clarity * Add Exit event * uint => uint256 * rm math * wards ocd * start updating aave to use base * shorten names * remove chainlog from d3m hub * remove dai daiJoin from hub * make common interfaces to use in tests * remove ds-value submodule * update aave tests for no ds-value * add todos * do daiJoin work in hub @gbalabasquer * PR comments to clean up hub * clean up add TODO * join directly to vow * PR feedback @talbaneth and @gbalabasquer * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * remove collect and move plan to Hub from pool * abstract bar to individual plan implementations * read and assign end on when necessary * don't read the plan * adjust unwind daiJoin interaction to match wind * fix aave tests - WIP * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * PR clean up comments * add recover tokens function to pool * remove convertToAssets from base * PR comments: remove bar and pool from bases and gas efficiency * change aave assetBalance calc * fix mom bar filing * update test for Aave share balance transfer in exit * revert convert to shares in exit since we should already be dealing with shares in wad * fix permissionless repay aave test * fix remaining aave test * reorganize interfaces into tests * move constant * remove unused interface functions * remove maxBar from base * remove events * Apply suggestions from code review Co-authored-by: talbaneth <[email protected]> * fix silly variable setting Co-authored-by: talbaneth <[email protected]> * move plans to separate folder * PR comments - update auths * move share to pools out of base * initial switch to returning target assets * WIP change to return targetAsset * accrued if needed before getting balance * integrate @hexonaut 's Aave calc fix * Delete empty file * plan base unit tests * add pool base tests * re-order accrueIfNeeded and maxWithdraw Co-authored-by: talbaneth <[email protected]> * remove unneeded math Co-authored-by: talbaneth <[email protected]> * consistent filing for ilks * better documentations of Ilk in Hub Co-authored-by: talbaneth <[email protected]> * remove unneeded safe math * don't store culled * unused return variable Co-authored-by: talbaneth <[email protected]> * update getTargetAssets * pr feedback * update share balance for aave to be scaled * Mom can disable plans * make files external * initial AaveDai plan tests * more AaveDaiPlan unit tests * add disable to plan base * fix missing override * check dai balance in wind * denominate shares in hub in dai/gems and add transferAllShares function * add approxEq for checking dai depositing * AaveDaiPool tests * move deposit check to pool * clean up remaining hub tests * add Mom tests * update base and share calculations * update aaave deposit checking * remove named return Co-authored-by: talbaneth <[email protected]> * remove debugging * update comments and errors * fix rounding error * fix possible bug with debt > debt ceiling * pr comments and clean up * add file events * pr comments on events and requires * add missing auth and test coverage * consolidate debt usage to totalDebt instead of adding it multiple times * update unwind comment Co-authored-by: talbaneth <[email protected]> * fix adai pool comment Co-authored-by: talbaneth <[email protected]> * update comment * D3MCompoundDaiPlan - initial implementation, untested * Neat * Add initial version of D3MCompoundDaiPool, missing logic and tests * More ppol work, actually add D3MCompoundDaiPool.sol * Test supply for current rate * D3MCompoundDaiPlan testing * Add test for calculating supplies * Align to latest modularize branch * Add accrueIfNeeded to compound pool * D3MCompoundDai.t.sol - WIP * Align to latest modularize changes * Remove auth modifier from compound's collect() * Support also 0 jump multiplier * Neat * Unify return values * Neat - fix indentation * Add plan test from hub * During test cleanup * Align to modularize latest changes * Support explicit disable() from mom * Make disable overriding on Compound Plan * Align to transferShares changes in hub * Align to modularize - validaion in deposit * Add underlying() validation also in plan ctr * Remove unused function in pool and add overrride * Align to modularize pool changes * Add Compound plan events * Add Compound pool auth and events * Align to compound-cd-audit fixes, commit fa793a3 This is the commit with the response to CS audit for Plan. The base plan and compound plan code are now identical to there. * Align to v2, wip * Align to v2, tests pass * Port test from cs-audit-fixes * Fix merge mistake with filing rate model * Finish porting all new plan tests * Add D3MCompoundDaiPool.t.sol * Align Compound plan test to run base plan tests * Cleare comparisons in D3MCompoundDai.t.sol * Simplify to use just _setRelBorrowTarget in D3MCompoundDai.t.sol * Align to use Like suffix for interfaces * Linter run - break require, remove test comment * Add clarification for Compound APY * Slightly improve plan comment + small neats * Add comp amount comparison to test * Refactors based on AAVE comments -Move administration parts to the top so wards will be in first slot. -Move internal functions to after external related ones. * Add amt to Compund's Collect() event * Fix merge of D3MAaveDaiPool.t.sol * Use compSupplySpeeds in comp claiming tests * Align line break style to rest of the file * Use internal constant, Add TODOs * add 2021 Nov Aave D3M Audit (#52) * fix end address Co-authored-by: Nazzareno Massari <[email protected]> * update end in aave tests Co-authored-by: Nazzareno Massari <[email protected]> * Update End address in D3MCompoundDai.t.sol * Fix typo * Tighten underlying dai comparisons, check deposit cdai * Add nope to compound pool, support hope/nope base tests * align to use >= in solidity pragma * Group storage together for Compound pool and plan * Flip expected and ectual in assertEqAbsolute * Align to V2 branch * Align layout of events/ctr/auth/math/admin to aave * Revert if getAccountSnapshot returns an error * Add TODOs * Add Compound links and explanation for using exchangeRateStored * Algin to V2 changes * Renamings and avoiding unused warning on hooks * Add SPDX-FileCopyrightText to Compound files * Align to V2 * deactivate if cdai implementation changes * Add boundary for barb * Make comp immutable, get dai from cdai * Support collect without claim. Since COMP can be claimed to the pool directly through Compound by a 3rd party make sure it can be recovered later even if comptroller would revert for some reason. * Improve interface links * align to v2 - wip * Finish aliging to asserRevert change * Align to V2 * Add Compound to README * Update to permanent links * Fix failures due to rounding * Validate delegate is not address(0) * Use address instead of token in cDai etherscan link Co-authored-by: Nazzareno Massari <[email protected]> * Move tau to general place in the Readme * Move _calculateTargetSupply up * Add comment about normal rate * Use _hub in pool ctr * Reorder cdai assignment and Avoid casting in plan * Support utilization > 100% * Comment why multiplierPerBlock != 0 and can de divided by * dapp upgrade dss-test (reverting un-intentional downgrade) * _assertEqApprox => assertEq Co-authored-by: Gonzalo Balabasquer <[email protected]> * Remove safe math in tests * Fix copyrights Co-authored-by: Nazzareno Massari <[email protected]> * Handle several review comments in tests * Fix copyrights also in Compound tests * Substract before addition * Neat - better spacings Co-authored-by: Chris Smith <[email protected]> Co-authored-by: Julien <[email protected]> Co-authored-by: Brian McMichael <[email protected]> Co-authored-by: Nazzareno Massari <[email protected]> Co-authored-by: Gonzalo Balabasquer <[email protected]> * Handle minor suggestions (#78) * Destroy Compound interface alignments to match aave * Use storage vars in ctr * Fix aave random failures (#77) * Fix aave random failures * Tighten error in test_unwind_culled_then_mcd_cage * Add reentrancy warning commnets for getTargetAssets (#80) * Add reentrancy warning commnets for getTargetAssets * false => zero * remove unneeded check in getTargetAssets tests * add withdraw DAI balance checks to Aave and Compound - CS Audit Question 7.1 * remove unneeded casting * add check on ATOKEN_REVISION for active * Remove reap, simplify _unwind and rebalance * Add missing frob in _fix * Fix README * Fix Hub tests * Fix Aave integration tests * Fix compound tests and minor changes to aave ones * No need of assetsBalance in unwind * New structure for exec + removing _fix and creating new _normal function * Limit amount of fixIlk * No more modes * cmooney-20220805: Fixes for CS 5.4 Inconsistencies (#84) * cmooney-20220805: Fixes for CS 5.4 Inconsistencies * bound bar in AAVE plan to MAX_BORROW_RATE * Revert "bound bar in AAVE plan to MAX_BORROW_RATE" This reverts commit e2bf302. * Call getTargetAssets once * Remove comment * Remove param in preDebtChange and postDebtChange * Change <= to < in one condition * only call getTargetAssets if plan is active * Minor changes art/Art with extra check * Use overloaded unwind * Move vat.slip * Remove comment * Fix tests * Fix tests failing on block 15308334 * Fix 15308526 * Add comment for rounding that may affect twice * Minor changes _normal structure * Improve readability and comments for fixInk * Use standard assertRevert for lock checks * Add Hub tests for checking art != Art * Add fixInk tests * Treat all the variables the same in normal path * Fix comments * Bit of restructure of normal function * Change order * Better use maxWithdraw for checks in tests * Add test and minor renaming * Add certora (#85) * Add Certora * Add DISPATCHER(true) * Add checks * Fix * Minor changes * less restrictive spec * Use real Vat, DaiJoin and Dai code with solc 0.5.12 * Use D3MTestPool and D3MTestPlan * More checks and CI setup * Move certora.yml to correct place * Fix some asserts * Add exec_exec rule and some minor changes in exec_normal * More checks * multi assert flag via conditional * Improve checks and add comments * Use staging and old certora-cli version until production gets fixed * More checks * Add exec_ilk_culled * check dai in vow for normal path * Add exec_vat_caged * Add cage and cull * Add uncull * Add exit * Add exit_revert * Add cage_revert * Remove unnecessary stuff of cage_revert * Add cull_revert * Add uncull_revert + some variables renaming * Add rely, rely_revert, deny and deny_revert * Add file_ilk_uint256 and file_ilk_uint256_revert * Add file_ilk_address and file_ilk_address_revert * Add ilk_getters * Add exec_vat_caged_revert + minor changes * Add exec_ilk_culled_revert and minor chanegs to exec_vat_caged_revert * Use main staging + split CI runs in several * Use matrix for running all the rules in CI * Fix CI config file * Certora CI only on pushes (for now) * Add to ignore * Add timeout flag * Add exec_normal_revert (without checking if all the revert cases are covered) * Stick to specific certora-cli-alpha-master version * Verify inkAfter can't be higher than max_int256 * Add missing end lines * Add unchecked * Removing some internal functions are renaming other * Move getters to the bottom * Some minor changes * art = ink outside of unchecked * Restrict all operation to maxint256 / RAY to avoid overflows * Bit better structure for _exec * Minor changes to _wipe and uncull * Tidy up * Use NoOp event also in _wipe * Minor renaming * Fix exec_exec * Add comment explaining the system cage path of exec * Fix D3MAavePool comment * More precise pool shares (#87) * More precise account for pools shares after shutdown + force unwinding if assets < ink * No more dapp * Minor changes * Rename test * Add exit tests * Fix exit and exit_revert specs * Fix exec_normal_revert expect with the new changes * Improve exit tests * Improving exec_normal spec * Fix comment * Enforce solc 0.8.14 in make test and use it for CI * Fix test rounding error * Remove unnecessary tests * 1e18 to wad and aave rounding (#88) * switch compound tests from 1e18 to WAD * fix aave test rounding issues * gonza fixing my assertEq dyslexia Co-authored-by: Gonzalo Balabasquer <[email protected]> Co-authored-by: Gonzalo Balabasquer <[email protected]> Co-authored-by: Chris Smith <[email protected]> * Fix spacing in Makefile * Fix for new version of solc-select which puts artifacts inside individual directories * Add test_borrow_apy (#91) * Add test_borrow_apy * hevm => vm * Make comment about Compound UI a bit clearer * Add back a test that was falsely removed Co-authored-by: rockyfour <[email protected]> * Certora: Use solc optimizations where corresponds * Be explicit about optimization options in test script * add final v2 audit * fix rounding expectation Co-authored-by: Julien <[email protected]> Co-authored-by: Brian McMichael <[email protected]> Co-authored-by: talbaneth <[email protected]> Co-authored-by: Gonzalo Balabasquer <[email protected]> Co-authored-by: Kurt Barry <[email protected]> Co-authored-by: Nazzareno Massari <[email protected]> Co-authored-by: Sam MacPherson <[email protected]> Co-authored-by: Christopher Mooney <[email protected]> Co-authored-by: rockyfour <[email protected]> Co-authored-by: rockyfour <[email protected]>
The following PR fixes two of the four inconsistencies brought up by ChainSecurity in section
5.4
.We won't fix this, but it's worth leaving a general comment on. Each plan and pool is a bespoke integration adapter that seeks to normalized differences in third-party interfaces and interactions between those protocols and the hub. For this general reason, while we are in full agreement that consistency between adapters should be maximized, in some cases there must be differences in the function and variable interfaces between adapters. In this particular case,
bar
is a per-year interest rate inRAY
units, whilebarb
is a per-block interest rate inWAD
units. To name these variables the same for consistency would likely cause spell crafters, risk, and governance to make a massive mistake in setting the target borrow rate in the future. For this reason, we named them differently. That is, they are deliberately inconsistent for safety and security reasons.This was an oversight that is resolved in this PR. Furthermore, formatting changes were made to make the code flow similar between the start of the two constructors.
I think this is a good point, but others should weigh in (@gbalabasquer). My second commit, which we can revert/change if needed, will bound the
bar
inD3MAavePlan
from being filed beyond100%
. We did boundbarb
in theD3MCompoundPlan
because it was using a wonky block based borrow rate, and that didn't feel intuitive to us. In order to prevent spell crafters and governance from shooting themselves in the foot, we bound this per-block borrow rate. That being said, our normal rates are per-second, and the AAVE borrow rate is normalized out to a per-year rate. This also is non-standard for us, and while more intuitive, one could argue we should also bound it so as not to make mistakes. Perhaps 100% is too low and we want to go higher, or perhaps this is intuitive enough and we don't want to bound it at all, either way, I would be interested in opinions here.We won't fix this one either. I'll echo my response to the first issue here, but as mentioned there we should seek to be maximally consistent. In this case, while a strict equality would be desired in the
D3MAavePool
, there is a1 wei
rounding error that pops up based on the state from block-to-block. To demonstrate this inconsistency, I changed the>=
check to a strict equality==
and found two blocks that produced different results (with and without the rounding error). You can see the results and reproduce them with the following test: