mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-10-01 12:20:39 +00:00

This patch is an intial implementation of the Tokio runtime. The Tokio runtime provides an out of the box configuration for running I/O heavy asynchronous applications. As of now, the Tokio runtime is a combination of a work-stealing thread pool as well as a background reactor to drive I/O resources. This patch also includes tokio-executor, a hopefully short lived crate that is based on the futures 0.2 executor RFC. * Implement `Park` for `Reactor` This enables the reactor to be used as the thread parker for executors. This also adds an `Error` component to `Park`. With this change, a `Reactor` and a `CurrentThread` can be combined to achieve the capabilities of tokio-core.
53 lines
1.5 KiB
Rust
53 lines
1.5 KiB
Rust
extern crate futures;
|
|
extern crate tokio;
|
|
extern crate tokio_io;
|
|
extern crate env_logger;
|
|
|
|
use futures::prelude::*;
|
|
use tokio::net::{TcpStream, TcpListener};
|
|
use tokio_io::io;
|
|
|
|
macro_rules! t {
|
|
($e:expr) => (match $e {
|
|
Ok(e) => e,
|
|
Err(e) => panic!("{} failed with {:?}", stringify!($e), e),
|
|
})
|
|
}
|
|
|
|
#[test]
|
|
fn basic_runtime_usage() {
|
|
let _ = env_logger::init();
|
|
|
|
// TODO: Don't require the lazy wrapper
|
|
tokio::run(::futures::future::lazy(|| {
|
|
let server = t!(TcpListener::bind(&"127.0.0.1:0".parse().unwrap()));
|
|
let addr = t!(server.local_addr());
|
|
let client = TcpStream::connect(&addr);
|
|
|
|
let server = server.incoming().take(1)
|
|
.map_err(|e| println!("accept err = {:?}", e))
|
|
.for_each(|socket| {
|
|
tokio::spawn({
|
|
io::write_all(socket, b"hello")
|
|
.map(|_| println!("write done"))
|
|
.map_err(|e| println!("write err = {:?}", e))
|
|
})
|
|
})
|
|
.map(|_| println!("accept done"));
|
|
|
|
let client = client
|
|
.map_err(|e| println!("connect err = {:?}", e))
|
|
.and_then(|client| {
|
|
// Read all
|
|
io::read_to_end(client, vec![])
|
|
.map(|_| println!("read done"))
|
|
.map_err(|e| println!("read err = {:?}", e))
|
|
});
|
|
|
|
tokio::spawn({
|
|
server.join(client)
|
|
.map(|_| println!("done"))
|
|
})
|
|
}));
|
|
}
|