Make --force the default behaviour for manual recovery
Remove the force flag. There is a resume command that tries to gracefully restarts the protocol and tries to execute the happy path. Remove e2e tests which test the --force flag.pull/721/head
parent
54061f941b
commit
f511ff093c
@ -1,110 +0,0 @@
|
|||||||
pub mod harness;
|
|
||||||
|
|
||||||
use harness::alice_run_until::is_xmr_lock_transaction_sent;
|
|
||||||
use harness::bob_run_until::is_btc_locked;
|
|
||||||
use harness::SlowCancelConfig;
|
|
||||||
use swap::asb::FixedRate;
|
|
||||||
use swap::protocol::alice::AliceState;
|
|
||||||
use swap::protocol::bob::BobState;
|
|
||||||
use swap::protocol::{alice, bob};
|
|
||||||
use swap::{asb, cli};
|
|
||||||
|
|
||||||
#[tokio::test]
|
|
||||||
async fn given_alice_and_bob_manually_force_cancel_when_timelock_not_expired_errors() {
|
|
||||||
harness::setup_test(SlowCancelConfig, |mut ctx| async move {
|
|
||||||
let (bob_swap, bob_join_handle) = ctx.bob_swap().await;
|
|
||||||
let swap_id = bob_swap.id;
|
|
||||||
let bob_swap = tokio::spawn(bob::run_until(bob_swap, is_btc_locked));
|
|
||||||
|
|
||||||
let alice_swap = ctx.alice_next_swap().await;
|
|
||||||
let alice_swap = tokio::spawn(alice::run_until(
|
|
||||||
alice_swap,
|
|
||||||
is_xmr_lock_transaction_sent,
|
|
||||||
FixedRate::default(),
|
|
||||||
));
|
|
||||||
|
|
||||||
let bob_state = bob_swap.await??;
|
|
||||||
assert!(matches!(bob_state, BobState::BtcLocked { .. }));
|
|
||||||
|
|
||||||
let (bob_swap, bob_join_handle) = ctx
|
|
||||||
.stop_and_resume_bob_from_db(bob_join_handle, swap_id)
|
|
||||||
.await;
|
|
||||||
assert!(matches!(bob_swap.state, BobState::BtcLocked { .. }));
|
|
||||||
|
|
||||||
let alice_state = alice_swap.await??;
|
|
||||||
assert!(matches!(
|
|
||||||
alice_state,
|
|
||||||
AliceState::XmrLockTransactionSent { .. }
|
|
||||||
));
|
|
||||||
|
|
||||||
// Bob tries but fails to manually cancel
|
|
||||||
let result = cli::cancel(bob_swap.id, bob_swap.bitcoin_wallet, bob_swap.db, true).await;
|
|
||||||
assert!(matches!(result, Err(_)));
|
|
||||||
|
|
||||||
ctx.restart_alice().await;
|
|
||||||
let alice_swap = ctx.alice_next_swap().await;
|
|
||||||
assert!(matches!(
|
|
||||||
alice_swap.state,
|
|
||||||
AliceState::XmrLockTransactionSent { .. }
|
|
||||||
));
|
|
||||||
|
|
||||||
// Alice tries but fails manual cancel
|
|
||||||
let is_outer_err = asb::cancel(
|
|
||||||
alice_swap.swap_id,
|
|
||||||
alice_swap.bitcoin_wallet,
|
|
||||||
alice_swap.db,
|
|
||||||
true,
|
|
||||||
)
|
|
||||||
.await
|
|
||||||
.is_err();
|
|
||||||
assert!(is_outer_err);
|
|
||||||
|
|
||||||
let (bob_swap, bob_join_handle) = ctx
|
|
||||||
.stop_and_resume_bob_from_db(bob_join_handle, swap_id)
|
|
||||||
.await;
|
|
||||||
assert!(matches!(bob_swap.state, BobState::BtcLocked { .. }));
|
|
||||||
|
|
||||||
// Bob tries but fails to manually refund
|
|
||||||
let is_outer_err = cli::refund(bob_swap.id, bob_swap.bitcoin_wallet, bob_swap.db, true)
|
|
||||||
.await
|
|
||||||
.is_err();
|
|
||||||
assert!(is_outer_err);
|
|
||||||
|
|
||||||
let (bob_swap, _) = ctx
|
|
||||||
.stop_and_resume_bob_from_db(bob_join_handle, swap_id)
|
|
||||||
.await;
|
|
||||||
assert!(matches!(bob_swap.state, BobState::BtcLocked { .. }));
|
|
||||||
|
|
||||||
ctx.restart_alice().await;
|
|
||||||
let alice_swap = ctx.alice_next_swap().await;
|
|
||||||
assert!(matches!(
|
|
||||||
alice_swap.state,
|
|
||||||
AliceState::XmrLockTransactionSent { .. }
|
|
||||||
));
|
|
||||||
|
|
||||||
// Alice tries but fails manual cancel
|
|
||||||
let refund_tx_not_published_yet = asb::refund(
|
|
||||||
alice_swap.swap_id,
|
|
||||||
alice_swap.bitcoin_wallet,
|
|
||||||
alice_swap.monero_wallet,
|
|
||||||
alice_swap.db,
|
|
||||||
true,
|
|
||||||
)
|
|
||||||
.await?
|
|
||||||
.unwrap_err();
|
|
||||||
assert!(matches!(
|
|
||||||
refund_tx_not_published_yet,
|
|
||||||
asb::refund::Error::RefundTransactionNotPublishedYet(..)
|
|
||||||
));
|
|
||||||
|
|
||||||
ctx.restart_alice().await;
|
|
||||||
let alice_swap = ctx.alice_next_swap().await;
|
|
||||||
assert!(matches!(
|
|
||||||
alice_swap.state,
|
|
||||||
AliceState::XmrLockTransactionSent { .. }
|
|
||||||
));
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
})
|
|
||||||
.await;
|
|
||||||
}
|
|
Loading…
Reference in New Issue