Skip to content

Commit

Permalink
unelegant test
Browse files Browse the repository at this point in the history
  • Loading branch information
divagant-martian committed Nov 18, 2021
1 parent 2e73f1d commit 6007c98
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 0 deletions.
1 change: 1 addition & 0 deletions swarm/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ smallvec = "1.6.1"
void = "1"
futures-timer = "3.0.2"
instant = "0.1.11"
env_logger = "0.9.0"

[dev-dependencies]
libp2p = { path = "../", default-features = false, features = ["yamux", "plaintext"] }
Expand Down
56 changes: 56 additions & 0 deletions swarm/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1803,4 +1803,60 @@ mod tests {
}
}))
}

#[test]
fn test_banning_respects_contract() {
std::env::set_var("RUST_LOG", "info");
env_logger::init();
let handler_proto = DummyProtocolsHandler {
keep_alive: KeepAlive::Yes,
};

let mut swarm1 = new_test_swarm::<_, ()>(handler_proto.clone());
let mut swarm2 = new_test_swarm::<_, ()>(handler_proto);

let addr1: Multiaddr = multiaddr::Protocol::Memory(rand::random::<u64>()).into();
let addr2: Multiaddr = multiaddr::Protocol::Memory(rand::random::<u64>()).into();

swarm1.listen_on(addr1.clone().into()).unwrap();
swarm2.listen_on(addr2.clone().into()).unwrap();

let swarm1_id = *swarm1.local_peer_id();

async fn poll(
id: usize,
swarm: &mut Swarm<CallTraceBehaviour<MockBehaviour<DummyProtocolsHandler, ()>>>,
) {
let ev = swarm.select_next_some().await;
log::info!("[{}] {:?}", id, ev);
}

executor::block_on(async {
// Wait for the swarms to establish listeners
poll(1, &mut swarm1).await;
poll(2, &mut swarm2).await;

swarm1.dial(addr2.clone()).unwrap();
log::info!("Swarm 2 banning swarm 1\n\n");
swarm2.ban_peer_id(swarm1_id);

// Incoming connection
poll(2, &mut swarm2).await;

// Connection established
poll(2, &mut swarm2).await;
// Connection established
poll(1, &mut swarm1).await;

// Both see connections as closed
poll(1, &mut swarm1).await;
poll(2, &mut swarm2).await;

// Check what swarm2's behaviour got
assert_eq!(
swarm2.behaviour.inject_connection_established,
swarm2.behaviour.inject_connection_closed
);
})
}
}

0 comments on commit 6007c98

Please sign in to comment.