Improve the random port function docs (#1536)

Also:
* rename the function
* create an alternative function for the common case.
This commit is contained in:
teor 2020-12-18 11:32:33 +10:00 committed by GitHub
parent 3266265f7f
commit 3355be4c41
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 28 additions and 4 deletions

View File

@ -745,17 +745,41 @@ fn sync_past_sapling_testnet() {
sync_past_sapling(network).unwrap();
}
/// Returns a random port
/// Returns a random port number from the ephemeral port range.
///
/// Does not check if the port is already in use. It's impossible to do this
/// check in a reliable, cross-platform way.
fn random_port() -> u16 {
///
/// ## Usage
///
/// If you want a once-off random unallocated port, use
/// `random_unallocated_port`. Don't use this function if you don't need
/// to - it has a small risk of port conflcits.
///
/// Use this function when you need to use the same random port multiple
/// times. For example: setting up both ends of a connection, or re-using
/// the same port multiple times.
fn random_known_port() -> u16 {
// Use the intersection of the IANA ephemeral port range, and the Linux
// ephemeral port range:
// https://en.wikipedia.org/wiki/Ephemeral_port#Range
rand::thread_rng().gen_range(49152, 60999)
}
/// Returns the "magic" port number that tells the operating system to
/// choose a random unallocated port.
///
/// The OS chooses a different port each time it opens a connection or
/// listener with this magic port number.
///
/// ## Usage
///
/// See the usage note for `random_known_port`.
#[allow(dead_code)]
fn random_unallocated_port() -> u16 {
0
}
#[tokio::test]
async fn metrics_endpoint() -> Result<()> {
use hyper::Client;
@ -763,7 +787,7 @@ async fn metrics_endpoint() -> Result<()> {
zebra_test::init();
// [Note on port conflict](#Note on port conflict)
let port = random_port();
let port = random_known_port();
let endpoint = format!("127.0.0.1:{}", port);
let url = format!("http://{}", endpoint);
@ -818,7 +842,7 @@ async fn tracing_endpoint() -> Result<()> {
zebra_test::init();
// [Note on port conflict](#Note on port conflict)
let port = random_port();
let port = random_known_port();
let endpoint = format!("127.0.0.1:{}", port);
let url_default = format!("http://{}", endpoint);
let url_filter = format!("{}/filter", url_default);