|
|
|
@ -6,9 +6,9 @@ pub mod testutils;
|
|
|
|
|
/// then also refunds.
|
|
|
|
|
#[tokio::test]
|
|
|
|
|
async fn given_alice_restarts_after_xmr_is_locked_abort_swap() {
|
|
|
|
|
testutils::setup_test(|test| async move {
|
|
|
|
|
let alice_swap = test.new_swap_as_alice().await;
|
|
|
|
|
let bob_swap = test.new_swap_as_bob().await;
|
|
|
|
|
testutils::setup_test(|ctx| async move {
|
|
|
|
|
let alice_swap = ctx.new_swap_as_alice().await;
|
|
|
|
|
let bob_swap = ctx.new_swap_as_bob().await;
|
|
|
|
|
|
|
|
|
|
let bob = bob::run(bob_swap);
|
|
|
|
|
let bob_handle = tokio::spawn(bob);
|
|
|
|
@ -22,7 +22,7 @@ async fn given_alice_restarts_after_xmr_is_locked_abort_swap() {
|
|
|
|
|
let bob_state = bob_handle.await.unwrap();
|
|
|
|
|
|
|
|
|
|
// Once bob has finished Alice is restarted and refunds as well
|
|
|
|
|
let alice_swap = test.recover_alice_from_db().await;
|
|
|
|
|
let alice_swap = ctx.recover_alice_from_db().await;
|
|
|
|
|
assert!(matches!(alice_swap.state, AliceState::XmrLocked {..}));
|
|
|
|
|
|
|
|
|
|
let alice_state = alice::run(alice_swap).await.unwrap();
|
|
|
|
@ -31,8 +31,8 @@ async fn given_alice_restarts_after_xmr_is_locked_abort_swap() {
|
|
|
|
|
// refunded, not at the end because this can cause side-effects!
|
|
|
|
|
// We have to properly wait for the refund tx's finality inside the assertion,
|
|
|
|
|
// which requires storing the refund_tx_id in the the state!
|
|
|
|
|
test.assert_bob_refunded(bob_state.unwrap()).await;
|
|
|
|
|
test.assert_alice_refunded(alice_state).await;
|
|
|
|
|
ctx.assert_bob_refunded(bob_state.unwrap()).await;
|
|
|
|
|
ctx.assert_alice_refunded(alice_state).await;
|
|
|
|
|
})
|
|
|
|
|
.await;
|
|
|
|
|
}
|
|
|
|
|