fix async request builder tests
This commit is contained in:
@@ -301,10 +301,10 @@ mod tests {
|
||||
fn add_query_append() {
|
||||
let client = Client::new();
|
||||
let some_url = "https://google.com/";
|
||||
let mut r = client.get(some_url);
|
||||
let r = client.get(some_url);
|
||||
|
||||
r.query(&[("foo", "bar")]);
|
||||
r.query(&[("qux", 3)]);
|
||||
let r = r.query(&[("foo", "bar")]);
|
||||
let r = r.query(&[("qux", 3)]);
|
||||
|
||||
let req = r.build().expect("request is valid");
|
||||
assert_eq!(req.url().query(), Some("foo=bar&qux=3"));
|
||||
@@ -314,9 +314,9 @@ mod tests {
|
||||
fn add_query_append_same() {
|
||||
let client = Client::new();
|
||||
let some_url = "https://google.com/";
|
||||
let mut r = client.get(some_url);
|
||||
let r = client.get(some_url);
|
||||
|
||||
r.query(&[("foo", "a"), ("foo", "b")]);
|
||||
let r = r.query(&[("foo", "a"), ("foo", "b")]);
|
||||
|
||||
let req = r.build().expect("request is valid");
|
||||
assert_eq!(req.url().query(), Some("foo=a&foo=b"));
|
||||
@@ -332,11 +332,11 @@ mod tests {
|
||||
|
||||
let client = Client::new();
|
||||
let some_url = "https://google.com/";
|
||||
let mut r = client.get(some_url);
|
||||
let r = client.get(some_url);
|
||||
|
||||
let params = Params { foo: "bar".into(), qux: 3 };
|
||||
|
||||
r.query(¶ms);
|
||||
let r = r.query(¶ms);
|
||||
|
||||
let req = r.build().expect("request is valid");
|
||||
assert_eq!(req.url().query(), Some("foo=bar&qux=3"));
|
||||
@@ -350,9 +350,9 @@ mod tests {
|
||||
|
||||
let client = Client::new();
|
||||
let some_url = "https://google.com/";
|
||||
let mut r = client.get(some_url);
|
||||
let r = client.get(some_url);
|
||||
|
||||
r.query(¶ms);
|
||||
let r = r.query(¶ms);
|
||||
|
||||
let req = r.build().expect("request is valid");
|
||||
assert_eq!(req.url().query(), Some("foo=bar&qux=three"));
|
||||
|
||||
@@ -6,7 +6,7 @@ use std::thread;
|
||||
use futures::{Future, Stream};
|
||||
use futures::sync::{mpsc, oneshot};
|
||||
|
||||
use request::{self, Request, RequestBuilder};
|
||||
use request::{Request, RequestBuilder};
|
||||
use response::{self, Response};
|
||||
use {async_impl, header, Certificate, Identity, Method, IntoUrl, Proxy, RedirectPolicy, wait};
|
||||
|
||||
@@ -359,7 +359,7 @@ impl Client {
|
||||
Ok(url) => Ok(Request::new(method, url)),
|
||||
Err(err) => Err(::error::from(err)),
|
||||
};
|
||||
request::builder(self.clone(), req)
|
||||
RequestBuilder::new(self.clone(), req)
|
||||
}
|
||||
|
||||
/// Executes a `Request`.
|
||||
@@ -476,7 +476,7 @@ impl ClientHandle {
|
||||
|
||||
fn execute_request(&self, req: Request) -> ::Result<Response> {
|
||||
let (tx, rx) = oneshot::channel();
|
||||
let (req, body) = request::async(req);
|
||||
let (req, body) = req.into_async();
|
||||
let url = req.url().clone();
|
||||
self.inner.tx
|
||||
.as_ref()
|
||||
|
||||
@@ -80,9 +80,31 @@ impl Request {
|
||||
pub fn body_mut(&mut self) -> &mut Option<Body> {
|
||||
&mut self.body
|
||||
}
|
||||
|
||||
pub(crate) fn into_async(self) -> (async_impl::Request, Option<body::Sender>) {
|
||||
use header::CONTENT_LENGTH;
|
||||
|
||||
let mut req_async = self.inner;
|
||||
let body = self.body.and_then(|body| {
|
||||
let (tx, body, len) = body::async(body);
|
||||
if let Some(len) = len {
|
||||
req_async.headers_mut().insert(CONTENT_LENGTH, HeaderValue::from_str(len.to_string().as_str()).expect(""));
|
||||
}
|
||||
*req_async.body_mut() = Some(body);
|
||||
tx
|
||||
});
|
||||
(req_async, body)
|
||||
}
|
||||
}
|
||||
|
||||
impl RequestBuilder {
|
||||
pub(crate) fn new(client: Client, request: ::Result<Request>) -> RequestBuilder {
|
||||
RequestBuilder {
|
||||
client,
|
||||
request,
|
||||
}
|
||||
}
|
||||
|
||||
/// Add a `Header` to this Request.
|
||||
///
|
||||
/// ```rust
|
||||
@@ -433,29 +455,6 @@ fn fmt_request_fields<'a, 'b>(f: &'a mut fmt::DebugStruct<'a, 'b>, req: &Request
|
||||
.field("headers", req.headers())
|
||||
}
|
||||
|
||||
// pub(crate)
|
||||
|
||||
#[inline]
|
||||
pub fn builder(client: Client, request: ::Result<Request>) -> RequestBuilder {
|
||||
RequestBuilder { client, request }
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub fn async(req: Request) -> (async_impl::Request, Option<body::Sender>) {
|
||||
use header::CONTENT_LENGTH;
|
||||
|
||||
let mut req_async = req.inner;
|
||||
let body = req.body.and_then(|body| {
|
||||
let (tx, body, len) = body::async(body);
|
||||
if let Some(len) = len {
|
||||
req_async.headers_mut().insert(CONTENT_LENGTH, HeaderValue::from_str(len.to_string().as_str()).expect(""));
|
||||
}
|
||||
*req_async.body_mut() = Some(body);
|
||||
tx
|
||||
});
|
||||
(req_async, body)
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use {body, Client, Method};
|
||||
|
||||
Reference in New Issue
Block a user