Skip to content

Commit

Permalink
Shifts tests to use random ports
Browse files Browse the repository at this point in the history
  • Loading branch information
AgeManning committed Apr 14, 2020
1 parent 065ea15 commit e7a1aee
Show file tree
Hide file tree
Showing 4 changed files with 84 additions and 9 deletions.
33 changes: 33 additions & 0 deletions beacon_node/eth2-libp2p/tests/common/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ use eth2_libp2p::Multiaddr;
use eth2_libp2p::NetworkConfig;
use eth2_libp2p::Service as LibP2PService;
use slog::{debug, error, o, Drain};
use std::net::{TcpListener, UdpSocket};
use std::time::Duration;
use tempdir::TempDir;

Expand All @@ -19,6 +20,38 @@ pub fn build_log(level: slog::Level, enabled: bool) -> slog::Logger {
}
}

// A bit of hack to find an unused port.
///
/// Does not guarantee that the given port is unused after the function exists, just that it was
/// unused before the function started (i.e., it does not reserve a port).
pub fn unused_port(transport: &str) -> Result<u16, String> {
let local_addr = match transport {
"tcp" => {
let listener = TcpListener::bind("127.0.0.1:0").map_err(|e| {
format!("Failed to create TCP listener to find unused port: {:?}", e)
})?;
listener.local_addr().map_err(|e| {
format!(
"Failed to read TCP listener local_addr to find unused port: {:?}",
e
)
})?
}
"udp" => {
let socket = UdpSocket::bind("127.0.0.1:0")
.map_err(|e| format!("Failed to create UDP socket to find unused port: {:?}", e))?;
socket.local_addr().map_err(|e| {
format!(
"Failed to read UDP socket local_addr to find unused port: {:?}",
e
)
})?
}
_ => return Err("Invalid transport to find unused port".into()),
};
Ok(local_addr.port())
}

pub fn build_config(
port: u16,
mut boot_nodes: Vec<Enr>,
Expand Down
6 changes: 4 additions & 2 deletions beacon_node/eth2-libp2p/tests/gossipsub_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ fn test_gossipsub_forward() {
let log = common::build_log(Level::Info, false);

let num_nodes = 20;
let mut nodes = common::build_linear(log.clone(), num_nodes, Some(19000));
let base_port = common::unused_port("tcp").unwrap();
let mut nodes = common::build_linear(log.clone(), num_nodes, Some(base_port));
let mut received_count = 0;
let pubsub_message = PubsubMessage::Block(vec![0; 4]);
let publishing_topic: String = "/eth2/beacon_block/ssz".into();
Expand Down Expand Up @@ -88,7 +89,8 @@ fn test_gossipsub_full_mesh_publish() {
// as nodes may get pruned out of the mesh before the gossipsub message
// is published to them.
let num_nodes = 12;
let mut nodes = common::build_full_mesh(log, num_nodes, Some(11320));
let base_port = common::unused_port("tcp").unwrap();
let mut nodes = common::build_full_mesh(log, num_nodes, Some(base_port));
let mut publishing_node = nodes.pop().unwrap();
let pubsub_message = PubsubMessage::Block(vec![0; 4]);
let publishing_topic: String = "/eth2/beacon_block/ssz".into();
Expand Down
39 changes: 37 additions & 2 deletions beacon_node/eth2-libp2p/tests/noise.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ use libp2p::{
};
use slog::{crit, debug, info, Level};
use std::io::{Error, ErrorKind};
use std::net::{TcpListener, UdpSocket};
use std::sync::atomic::{AtomicBool, Ordering::Relaxed};
use std::sync::Arc;
use std::time::Duration;
Expand Down Expand Up @@ -105,6 +106,38 @@ fn build_secio_transport(local_private_key: Keypair) -> Boxed<(PeerId, StreamMux
.boxed()
}

// A bit of hack to find an unused port.
///
/// Does not guarantee that the given port is unused after the function exists, just that it was
/// unused before the function started (i.e., it does not reserve a port).
pub fn unused_port(transport: &str) -> Result<u16, String> {
let local_addr = match transport {
"tcp" => {
let listener = TcpListener::bind("127.0.0.1:0").map_err(|e| {
format!("Failed to create TCP listener to find unused port: {:?}", e)
})?;
listener.local_addr().map_err(|e| {
format!(
"Failed to read TCP listener local_addr to find unused port: {:?}",
e
)
})?
}
"udp" => {
let socket = UdpSocket::bind("127.0.0.1:0")
.map_err(|e| format!("Failed to create UDP socket to find unused port: {:?}", e))?;
socket.local_addr().map_err(|e| {
format!(
"Failed to read UDP socket local_addr to find unused port: {:?}",
e
)
})?
}
_ => return Err("Invalid transport to find unused port".into()),
};
Ok(local_addr.port())
}

/// Test if the encryption falls back to secio if noise isn't available
#[test]
fn test_secio_noise_fallback() {
Expand All @@ -114,12 +147,14 @@ fn test_secio_noise_fallback() {

let log = common::build_log(log_level, enable_logging);

let noisy_config = common::build_config(56010, vec![], None);
let port = unused_port("tcp").unwrap();
let noisy_config = common::build_config(port, vec![], None);
let mut noisy_node = Service::new(&noisy_config, log.clone())
.expect("should build a libp2p instance")
.1;

let secio_config = common::build_config(56011, vec![common::get_enr(&noisy_node)], None);
let port = unused_port("tcp").unwrap();
let secio_config = common::build_config(port, vec![common::get_enr(&noisy_node)], None);

// Building a custom Libp2pService from outside the crate isn't possible because of
// private fields in the Libp2pService struct. A swarm is good enough for testing
Expand Down
15 changes: 10 additions & 5 deletions beacon_node/eth2-libp2p/tests/rpc_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ fn test_status_rpc() {
let log = common::build_log(log_level, enable_logging);

// get sender/receiver
let (mut sender, mut receiver) = common::build_node_pair(&log, 10500);
let port = common::unused_port("tcp").unwrap();
let (mut sender, mut receiver) = common::build_node_pair(&log, port);

// Dummy STATUS RPC message
let rpc_request = RPCRequest::Status(StatusMessage {
Expand Down Expand Up @@ -134,7 +135,8 @@ fn test_blocks_by_range_chunked_rpc() {
let log = common::build_log(log_level, enable_logging);

// get sender/receiver
let (mut sender, mut receiver) = common::build_node_pair(&log, 10505);
let port = common::unused_port("tcp").unwrap();
let (mut sender, mut receiver) = common::build_node_pair(&log, port);

// BlocksByRange Request
let rpc_request = RPCRequest::BlocksByRange(BlocksByRangeRequest {
Expand Down Expand Up @@ -261,7 +263,8 @@ fn test_blocks_by_range_single_empty_rpc() {
let log = common::build_log(log_level, enable_logging);

// get sender/receiver
let (mut sender, mut receiver) = common::build_node_pair(&log, 10510);
let port = common::unused_port("tcp").unwrap();
let (mut sender, mut receiver) = common::build_node_pair(&log, port);

// BlocksByRange Request
let rpc_request = RPCRequest::BlocksByRange(BlocksByRangeRequest {
Expand Down Expand Up @@ -385,7 +388,8 @@ fn test_blocks_by_root_chunked_rpc() {
let log = common::build_log(log_level, enable_logging);

// get sender/receiver
let (mut sender, mut receiver) = common::build_node_pair(&log, 10515);
let port = common::unused_port("tcp").unwrap();
let (mut sender, mut receiver) = common::build_node_pair(&log, port);

// BlocksByRoot Request
let rpc_request = RPCRequest::BlocksByRoot(BlocksByRootRequest {
Expand Down Expand Up @@ -509,7 +513,8 @@ fn test_goodbye_rpc() {
let log = common::build_log(log_level, enable_logging);

// get sender/receiver
let (mut sender, mut receiver) = common::build_node_pair(&log, 10520);
let port = common::unused_port("tcp").unwrap();
let (mut sender, mut receiver) = common::build_node_pair(&log, port);

// Goodbye Request
let rpc_request = RPCRequest::Goodbye(GoodbyeReason::ClientShutdown);
Expand Down

0 comments on commit e7a1aee

Please sign in to comment.