From 61309c8f38b2f86f45bf3dd567b0521c41d4eda4 Mon Sep 17 00:00:00 2001 From: Omar Date: Wed, 3 Jan 2024 16:13:44 +0300 Subject: [PATCH] More tests for protocol logic for opening liquidity positions --- unit-tests/tests/protocol.rs | 78 ++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) diff --git a/unit-tests/tests/protocol.rs b/unit-tests/tests/protocol.rs index 92e741e3..5f417b7d 100644 --- a/unit-tests/tests/protocol.rs +++ b/unit-tests/tests/protocol.rs @@ -96,6 +96,84 @@ fn cant_open_a_liquidity_position_to_a_registered_pool_with_no_adapter( Ok(()) } +#[test] +fn cant_open_a_liquidity_position_on_a_pool_that_is_not_registered( +) -> Result<(), RuntimeError> { + // Arrange + let Environment { + environment: ref mut env, + mut resources, + mut protocol, + ociswap, + } = Environment::new()?; + protocol + .olympus + .remove_allowed_pool(ociswap.bitcoin_pool.try_into().unwrap(), env)?; + + protocol + .oracle + .set_price(resources.bitcoin.0, XRD, dec!(1), env)?; + + // Act + let bitcoin_contribution_amount = dec!(0.1); + let bitcoin_bucket = resources + .bitcoin + .mint_fungible(bitcoin_contribution_amount, env)?; + let rtn = protocol.olympus.open_liquidity_position( + ociswap.bitcoin_pool.try_into().unwrap(), + FungibleBucket(bitcoin_bucket), + LockupPeriod::from_months(6), + env, + ); + + // Assert + assert_is_open_liquidity_position_pool_not_allowed_error(&rtn); + + Ok(()) +} + +#[test] +fn cant_open_a_liquidity_position_with_an_undefined_lockup_period( +) -> Result<(), RuntimeError> { + // Arrange + let Environment { + environment: ref mut env, + mut resources, + mut protocol, + ociswap, + } = Environment::new()?; + + let xrd_price = dec!(0.04204); + let bitcoin_price = dec!(45108.32); + let price_bitcoin_base_xrd_quote = bitcoin_price / xrd_price; + + let lockup_period = LockupPeriod::from_months(1); + + protocol.oracle.set_price( + resources.bitcoin.0, + XRD, + price_bitcoin_base_xrd_quote, + env, + )?; + + // Act + let bitcoin_contribution_amount = dec!(0.1); + let bitcoin_bucket = resources + .bitcoin + .mint_fungible(bitcoin_contribution_amount, env)?; + let rtn = protocol.olympus.open_liquidity_position( + ociswap.bitcoin_pool.try_into().unwrap(), + FungibleBucket(bitcoin_bucket), + lockup_period, + env, + ); + + // Assert + assert_is_open_liquidity_position_not_a_valid_lockup_period_error(&rtn); + + Ok(()) +} + #[test] fn can_open_position_on_an_ociswap_pool() -> Result<(), RuntimeError> { // Arrange