From ff2908ea5fc351b1a83e2fb428aea56b9896b5a4 Mon Sep 17 00:00:00 2001 From: valesteban Date: Tue, 17 Oct 2023 15:46:02 -0300 Subject: [PATCH] saves query by reference in future --- src/resolver/async_resolver.rs | 14 +------------- src/resolver/lookup.rs | 24 ++++++++++++++---------- 2 files changed, 15 insertions(+), 23 deletions(-) diff --git a/src/resolver/async_resolver.rs b/src/resolver/async_resolver.rs index f8d5dbaa..291f81d6 100644 --- a/src/resolver/async_resolver.rs +++ b/src/resolver/async_resolver.rs @@ -1,7 +1,6 @@ use std::io; use std::net::{IpAddr, Ipv4Addr}; -use crate::client::client_connection::ClientConnection; use crate::dns_cache::DnsCache; use crate::domain_name::DomainName; use crate::message::class_qclass::Qclass; @@ -95,17 +94,6 @@ mod async_resolver_test { let response = resolver.lookup_ip("example.com", "UDP").await.unwrap(); println!("[TEST FINISH=> {}]",response); - - - + } - - // #[test] - // fn test_spawn() { - - // let resolver = AsyncResolver::new(ResolverConfig::default()); - - // let handle = tokio::spawn(resolver.lookup_ip("example.com", "UDP")); - // unimplemented!(); - // } } \ No newline at end of file diff --git a/src/resolver/lookup.rs b/src/resolver/lookup.rs index a0b77d5f..a77fe21d 100644 --- a/src/resolver/lookup.rs +++ b/src/resolver/lookup.rs @@ -44,9 +44,9 @@ impl Future for LookupIpFutureStub{ println!(" [ready empty]"); self.waker = Some(cx.waker().clone()); - + let referenced_query = Arc::clone(&self.query); //same as self.query.clone() tokio::spawn( - lookup_stub(self.name.clone(),self.cache.clone(),self.conn.clone(),self.waker.clone(),self.query.clone())); + lookup_stub(self.name.clone(),self.cache.clone(),self.conn.clone(),self.waker.clone(),referenced_query)); println!(" [return pending]"); return Poll::Pending; }, @@ -83,8 +83,8 @@ pub async fn lookup_stub( //FIXME: podemos ponerle de nombre lookup_strategy y mut cache: DnsCache, conn: ClientConnectionType, waker: Option, - query:Arc> + Send>>>>, -) -> Result { + referenced_query:Arc> + Send>>>>, +) { println!("[LOOKUP STUB]"); @@ -113,7 +113,7 @@ pub async fn lookup_stub( //FIXME: podemos ponerle de nombre lookup_strategy y .map(|rr_cache_value| rr_cache_value.get_resource_record()) .collect::>(); new_query.set_answer(answer); - return Ok(new_query); + // return Ok(new_query); } //FIXME: @@ -133,15 +133,19 @@ pub async fn lookup_stub( //FIXME: podemos ponerle de nombre lookup_strategy y Ok(val)}, } } - }; - //para que en siguient eciclo de tokio despierte esta task + }; + + let mut future_query = referenced_query.lock().unwrap(); + *future_query = future::ready(response_result).boxed(); // TODO: check if it workingas expected + + //wake up task if let Some(waker) = waker { println!("[LOOKUP STUB] wake"); waker.wake(); } println!("[LOOKUP STUB] return"); - response_result + } @@ -169,8 +173,8 @@ mod async_resolver_test { let conn = ClientConnectionType::UDP(client_udp); let query = Arc::new(Mutex::new(future::err(ResolverError::Message("Empty")).boxed())); - let result = lookup_stub(name, cache, conn, waker,query).await; - println!("[Test Result ] {:?}", result); + lookup_stub(name, cache, conn, waker,query).await; + // println!("[Test Result ] {:?}", result); }