Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

### Features

- program: stricter logic for atomic fills [#2042](https://github.com/drift-labs/protocol-v2/pull/2042)

### Fixes

### Breaking
Expand Down
29 changes: 25 additions & 4 deletions programs/drift/src/controller/orders/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13075,7 +13075,7 @@ mod order_is_low_risk_for_amm {
let mm_oracle_delay = 10i64;

let is_low = order
.is_low_risk_for_amm(mm_oracle_delay, clock_slot, false)
.is_low_risk_for_amm(mm_oracle_delay, clock_slot, false, true)
.unwrap();
assert!(is_low);
}
Expand All @@ -13088,15 +13088,17 @@ mod order_is_low_risk_for_amm {
let mm_oracle_delay = 11i64;

let is_low = order
.is_low_risk_for_amm(mm_oracle_delay, clock_slot, false)
.is_low_risk_for_amm(mm_oracle_delay, clock_slot, false, true)
.unwrap();
assert!(!is_low);
}

#[test]
fn liquidation_always_low_risk() {
let order = base_perp_order();
let is_low = order.is_low_risk_for_amm(0, order.slot, true).unwrap();
let is_low = order
.is_low_risk_for_amm(0, order.slot, true, true)
.unwrap();
assert!(is_low);
}

Expand All @@ -13105,7 +13107,26 @@ mod order_is_low_risk_for_amm {
let mut order = base_perp_order();
order.add_bit_flag(OrderBitFlag::SafeTriggerOrder);

let is_low = order.is_low_risk_for_amm(0, order.slot, false).unwrap();
let is_low = order
.is_low_risk_for_amm(0, order.slot, false, true)
.unwrap();
assert!(is_low);
}

#[test]
fn user_can_skip_auction_duration() {
let order = base_perp_order();
let clock_slot = 110u64;
let mm_oracle_delay = 10i64;

let is_low = order
.is_low_risk_for_amm(mm_oracle_delay, clock_slot, false, true)
.unwrap();
assert!(is_low);

let is_low = order
.is_low_risk_for_amm(mm_oracle_delay, clock_slot, false, false)
.unwrap();
assert!(!is_low);
}
}
1 change: 1 addition & 0 deletions programs/drift/src/state/perp_market.rs
Original file line number Diff line number Diff line change
Expand Up @@ -948,6 +948,7 @@ impl PerpMarket {
safe_oracle_price_data.delay,
clock_slot,
fill_mode.is_liquidation(),
user_can_skip_auction_duration,
)?;

// Proceed if order is low risk and we can fill it. Otherwise check if we can higher risk order immediately
Expand Down
7 changes: 6 additions & 1 deletion programs/drift/src/state/user.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1531,14 +1531,19 @@ impl Order {
mm_oracle_delay: i64,
clock_slot: u64,
is_liquidation: bool,
user_can_skip_auction_duration: bool,
) -> DriftResult<bool> {
if self.market_type == MarketType::Spot {
return Ok(false);
}

let order_older_than_oracle_delay = {
let clock_minus_delay = clock_slot.cast::<i64>()?.safe_sub(mm_oracle_delay)?;
clock_minus_delay >= self.slot.cast::<i64>()?
if user_can_skip_auction_duration {
clock_minus_delay >= self.slot.cast::<i64>()?
} else {
clock_minus_delay > self.slot.cast::<i64>()?
}
};

Ok(order_older_than_oracle_delay
Expand Down
Loading