2022-06-22 03:27:58 +00:00
|
|
|
use nu_test_support::{nu, pipeline};
|
|
|
|
use std::net::TcpListener;
|
|
|
|
use std::sync::mpsc;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn port_with_invalid_range() {
|
2023-07-17 16:43:51 +00:00
|
|
|
let actual = nu!("port 4000 3999");
|
2022-06-22 03:27:58 +00:00
|
|
|
|
|
|
|
assert!(actual.err.contains("Invalid range"))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn port_with_already_usage() {
|
2022-07-25 11:42:06 +00:00
|
|
|
let retry_times = 10;
|
|
|
|
for _ in 0..retry_times {
|
|
|
|
let (tx, rx) = mpsc::sync_channel(0);
|
2022-06-22 03:27:58 +00:00
|
|
|
|
2022-07-25 11:42:06 +00:00
|
|
|
// let system pick a free port for us.
|
|
|
|
let free_port = {
|
|
|
|
let listener = TcpListener::bind("127.0.0.1:0").expect("failed to pick a port");
|
|
|
|
listener.local_addr().unwrap().port()
|
|
|
|
};
|
|
|
|
let handler = std::thread::spawn(move || {
|
|
|
|
let _listener = TcpListener::bind(format!("127.0.0.1:{free_port}"));
|
|
|
|
let _ = rx.recv();
|
|
|
|
});
|
2023-07-17 16:43:51 +00:00
|
|
|
let actual = nu!(pipeline(&format!("port {free_port} {free_port}")));
|
2022-07-25 11:42:06 +00:00
|
|
|
let _ = tx.send(true);
|
|
|
|
// make sure that the thread is closed and we release the port.
|
|
|
|
handler.join().unwrap();
|
2022-06-22 03:27:58 +00:00
|
|
|
|
2022-07-25 11:42:06 +00:00
|
|
|
// check for error kind str.
|
|
|
|
if actual.err.contains("AddrInUse") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2023-01-15 02:03:32 +00:00
|
|
|
panic!("already check port report AddrInUse for several times, but still failed.");
|
2022-06-22 03:27:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn port_from_system_given() {
|
2023-07-17 16:43:51 +00:00
|
|
|
let actual = nu!("port");
|
2022-06-22 03:27:58 +00:00
|
|
|
|
|
|
|
// check that we can get an integer port from system.
|
|
|
|
assert!(actual.out.parse::<u16>().unwrap() > 0)
|
|
|
|
}
|