Skip to content

Commit

Permalink
check interest over wider time scale for ezeth
Browse files Browse the repository at this point in the history
  • Loading branch information
dpaiton committed Oct 31, 2024
1 parent ab9969b commit 33c4717
Showing 1 changed file with 14 additions and 3 deletions.
17 changes: 14 additions & 3 deletions src/agent0/hyperfuzz/system_fuzz/invariant_checks.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
TOTAL_SHARES_EPSILON = 1e-9
NEGATIVE_INTEREST_EPSILON = FixedPoint(scaled_value=10) # 10 wei
PRESENT_VALUE_EPSILON = FixedPoint(scaled_value=1) # 1 wei
EZETH_NEG_INTEREST_TIME_DELTA = 12 * 60 * 60


def run_invariant_checks(
Expand Down Expand Up @@ -282,12 +283,22 @@ def _check_negative_interest(interface: HyperdriveReadInterface, pool_state: Poo
exception_data: dict[str, Any] = {}
log_level = None

# TODO we hack in a stateful variable into the interface here, since we need
# We hack in a stateful variable into the interface here, since we need
# to check between subsequent calls here.
# TODO: build in a way to store old pool states, e.g. a dict keyed by block time
# Initial call, we look to see if the attribute exists
previous_pool_state: PoolState | None = getattr(interface, "_negative_interest_previous_pool_state", None)
# Always set the new state here
setattr(interface, "_negative_interest_previous_pool_state", pool_state)

# We need to check interest over a longer time scale for ezETH
if interface.hyperdrive_name == "ElementDAO 182 Day ezETH Hyperdrive":
if (
previous_pool_state is not None
and pool_state.block_time - previous_pool_state.block_time > EZETH_NEG_INTEREST_TIME_DELTA
):
setattr(interface, "_negative_interest_previous_pool_state", pool_state)
else:
# Always set the new state for all other pools
setattr(interface, "_negative_interest_previous_pool_state", pool_state)

if previous_pool_state is None:
# Skip this check on initial call, not a failure
Expand Down

0 comments on commit 33c4717

Please sign in to comment.