mirror of
https://github.com/comit-network/xmr-btc-swap.git
synced 2024-10-01 01:45:40 -04:00
1597f5336b
Alice was attempting to create a new event loop using the same listen addr as the old one which was still running. This commit aborts the event loop before creating a new one.
31 lines
1019 B
Rust
31 lines
1019 B
Rust
pub mod testutils;
|
|
|
|
use swap::protocol::{alice, bob, bob::BobState};
|
|
use testutils::bob_run_until::is_encsig_sent;
|
|
|
|
#[tokio::test]
|
|
async fn given_bob_restarts_after_encsig_is_sent_resume_swap() {
|
|
testutils::setup_test(|mut ctx| async move {
|
|
let (alice_swap, _) = ctx.new_swap_as_alice().await;
|
|
let (bob_swap, bob_join_handle) = ctx.new_swap_as_bob().await;
|
|
|
|
let alice = alice::run(alice_swap);
|
|
let alice_handle = tokio::spawn(alice);
|
|
|
|
let bob_state = bob::run_until(bob_swap, is_encsig_sent).await.unwrap();
|
|
|
|
assert!(matches!(bob_state, BobState::EncSigSent {..}));
|
|
|
|
let bob_swap = ctx.stop_and_resume_bob_from_db(bob_join_handle).await;
|
|
assert!(matches!(bob_swap.state, BobState::EncSigSent {..}));
|
|
|
|
let bob_state = bob::run(bob_swap).await.unwrap();
|
|
|
|
ctx.assert_bob_redeemed(bob_state).await;
|
|
|
|
let alice_state = alice_handle.await.unwrap();
|
|
ctx.assert_alice_redeemed(alice_state.unwrap()).await;
|
|
})
|
|
.await;
|
|
}
|