use futures::{Future, Poll};
use error::{Error, Result};
use client::{AsyncSender, Client, Sender, SyncSender};
use client::requests::RequestBuilder;
use client::requests::endpoints::PingRequest;
use client::requests::raw::RawRequestInner;
use client::responses::PingResponse;
pub type PingRequestBuilder<TSender> = RequestBuilder<TSender, PingRequestInner>;
#[doc(hidden)]
pub struct PingRequestInner;
impl<TSender> Client<TSender>
where
TSender: Sender,
{
pub fn ping(&self) -> PingRequestBuilder<TSender> {
RequestBuilder::new(self.clone(), None, PingRequestInner)
}
}
impl PingRequestInner {
fn into_request(self) -> PingRequest<'static> {
PingRequest::new()
}
}
impl PingRequestBuilder<SyncSender> {
pub fn send(self) -> Result<PingResponse> {
let req = self.inner.into_request();
RequestBuilder::new(self.client, self.params, RawRequestInner::new(req))
.send()?
.into_response()
}
}
impl PingRequestBuilder<AsyncSender> {
pub fn send(self) -> Pending {
let req = self.inner.into_request();
let res_future = RequestBuilder::new(self.client, self.params, RawRequestInner::new(req))
.send()
.and_then(|res| res.into_response());
Pending::new(res_future)
}
}
pub struct Pending {
inner: Box<Future<Item = PingResponse, Error = Error>>,
}
impl Pending {
fn new<F>(fut: F) -> Self
where
F: Future<Item = PingResponse, Error = Error> + 'static,
{
Pending {
inner: Box::new(fut),
}
}
}
impl Future for Pending {
type Item = PingResponse;
type Error = Error;
fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
self.inner.poll()
}
}
#[cfg(test)]
mod tests {
use prelude::*;
#[test]
fn default_request() {
let client = SyncClientBuilder::new().build().unwrap();
let req = client.ping().inner.into_request();
assert_eq!("/", req.url.as_ref());
}
}