fn main() {
tracing_subscriber::fmt::init();
run();
}
fn run() {
use tokio::runtime::Runtime;
let runtime = Runtime::new().expect("Failed to create runtime");
let resolver = {
#[cfg(any(unix, windows))]
{
use hickory_resolver::{TokioResolver, net::runtime::TokioRuntimeProvider};
TokioResolver::builder(TokioRuntimeProvider::default())
.expect("failed to create resolver")
.build()
.unwrap()
}
#[cfg(not(any(unix, windows)))]
{
use hickory_resolver::{
Resolver,
config::{GOOGLE, ResolverConfig, ResolverOpts},
};
Resolver::tokio(ResolverConfig::udp_and_tcp(), ResolverOpts::default())
}
};
let names = &["www.google.com", "www.reddit.com", "www.wikipedia.org"];
let mut futures = names
.iter()
.map(|name| (name, resolver.lookup_ip(*name)))
.collect::<Vec<_>>();
for (name, lookup) in futures.drain(..) {
let ips = runtime
.block_on(lookup)
.expect("Failed completing lookup future")
.iter()
.collect::<Vec<_>>();
println!("{name} resolved to {ips:?}");
}
drop(futures);
drop(resolver);
}
#[test]
fn test_multithreaded_runtime() {
test_support::subscribe();
run()
}