mirror of
https://github.com/ntex-rs/ntex.git
synced 2025-04-03 21:07:39 +03:00
Add ServerBuilder::configure_async() helper, async version of configure method
This commit is contained in:
parent
bd5d40e439
commit
8b7c3111c0
4 changed files with 93 additions and 2 deletions
|
@ -1,5 +1,9 @@
|
|||
# Changes
|
||||
|
||||
## [0.5.26] - 2022-09-20
|
||||
|
||||
* server: Add ServerBuilder::configure_async() helper, async version of configure method
|
||||
|
||||
## [0.5.25] - 2022-08-22
|
||||
|
||||
* http: Fix http2 content-length handling
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
[package]
|
||||
name = "ntex"
|
||||
version = "0.5.25"
|
||||
version = "0.5.26"
|
||||
authors = ["ntex contributors <team@ntex.rs>"]
|
||||
description = "Framework for composable network services"
|
||||
readme = "README.md"
|
||||
|
@ -57,7 +57,7 @@ ntex-macros = "0.1.3"
|
|||
ntex-util = "0.1.17"
|
||||
ntex-bytes = "0.1.16"
|
||||
ntex-h2 = "0.1.4"
|
||||
ntex-rt = "0.4.4"
|
||||
ntex-rt = "0.4.6"
|
||||
ntex-io = "0.1.8"
|
||||
ntex-tls = "0.1.5"
|
||||
ntex-tokio = { version = "0.1.3", optional = true }
|
||||
|
|
|
@ -168,6 +168,33 @@ impl ServerBuilder {
|
|||
Ok(self)
|
||||
}
|
||||
|
||||
/// Execute external async configuration as part of the server building
|
||||
/// process.
|
||||
///
|
||||
/// This function is useful for moving parts of configuration to a
|
||||
/// different module or even library.
|
||||
pub async fn configure_async<F, R>(mut self, f: F) -> io::Result<ServerBuilder>
|
||||
where
|
||||
F: Fn(&mut ServiceConfig) -> R,
|
||||
R: Future<Output = io::Result<()>>,
|
||||
{
|
||||
let mut cfg = ServiceConfig::new(self.threads, self.backlog);
|
||||
|
||||
f(&mut cfg).await?;
|
||||
|
||||
let apply = cfg.apply;
|
||||
let mut srv = ConfiguredService::new(apply);
|
||||
for (name, lst) in cfg.services {
|
||||
let token = self.token.next();
|
||||
srv.stream(token, name.clone(), lst.local_addr()?);
|
||||
self.sockets.push((token, name, Listener::from_tcp(lst)));
|
||||
}
|
||||
self.services.push(Box::new(srv));
|
||||
self.threads = cfg.threads;
|
||||
|
||||
Ok(self)
|
||||
}
|
||||
|
||||
/// Register async service configuration function.
|
||||
///
|
||||
/// This function get called during worker runtime configuration stage.
|
||||
|
|
|
@ -185,6 +185,66 @@ fn test_on_worker_start() {
|
|||
let _ = h.join();
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[cfg(feature = "tokio")]
|
||||
fn test_configure_async() {
|
||||
let addr1 = TestServer::unused_addr();
|
||||
let addr2 = TestServer::unused_addr();
|
||||
let addr3 = TestServer::unused_addr();
|
||||
let (tx, rx) = mpsc::channel();
|
||||
let num = Arc::new(AtomicUsize::new(0));
|
||||
let num2 = num.clone();
|
||||
|
||||
let h = thread::spawn(move || {
|
||||
let num = num2.clone();
|
||||
let num2 = num2.clone();
|
||||
let sys = ntex::rt::System::new("test");
|
||||
sys.block_on(async move {
|
||||
let srv = Server::build()
|
||||
.disable_signals()
|
||||
.configure_async(move |cfg| {
|
||||
let num = num.clone();
|
||||
let lst = net::TcpListener::bind(addr3).unwrap();
|
||||
cfg.bind("addr1", addr1)
|
||||
.unwrap()
|
||||
.bind("addr2", addr2)
|
||||
.unwrap()
|
||||
.listen("addr3", lst)
|
||||
.on_worker_start(move |rt| {
|
||||
let num = num.clone();
|
||||
async move {
|
||||
rt.service("addr1", fn_service(|_| Ready::Ok::<_, ()>(())));
|
||||
rt.service("addr3", fn_service(|_| Ready::Ok::<_, ()>(())));
|
||||
let _ = num.fetch_add(1, Relaxed);
|
||||
Ok::<_, io::Error>(())
|
||||
}
|
||||
})
|
||||
.unwrap();
|
||||
Ready::Ok::<_, io::Error>(())
|
||||
})
|
||||
.await
|
||||
.unwrap()
|
||||
.on_worker_start(move |_| {
|
||||
let _ = num2.fetch_add(1, Relaxed);
|
||||
Ready::Ok::<_, io::Error>(())
|
||||
})
|
||||
.workers(1)
|
||||
.run();
|
||||
let _ = tx.send((srv, ntex::rt::System::current()));
|
||||
Ok::<_, io::Error>(())
|
||||
})
|
||||
});
|
||||
let (_, sys) = rx.recv().unwrap();
|
||||
thread::sleep(time::Duration::from_millis(500));
|
||||
|
||||
assert!(net::TcpStream::connect(addr1).is_ok());
|
||||
assert!(net::TcpStream::connect(addr2).is_ok());
|
||||
assert!(net::TcpStream::connect(addr3).is_ok());
|
||||
assert_eq!(num.load(Relaxed), 2);
|
||||
sys.stop();
|
||||
let _ = h.join();
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[cfg(feature = "tokio")]
|
||||
#[cfg(not(target_os = "macos"))]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue