@@ -32,4 +32,4 @@ cache:
|
|||||||
|
|
||||||
script:
|
script:
|
||||||
- cargo build $FEATURES
|
- cargo build $FEATURES
|
||||||
- cargo test $FEATURES
|
- cargo test -v $FEATURES
|
||||||
|
|||||||
@@ -165,6 +165,32 @@ impl Response {
|
|||||||
serde_json::from_reader(self).map_err(::error::from)
|
serde_json::from_reader(self).map_err(::error::from)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Copy the response body into a writer.
|
||||||
|
///
|
||||||
|
/// This function internally uses [`std::io::copy`] and hence will continuously read data from
|
||||||
|
/// the body and then write it into writer in a streaming fashion until EOF is met.
|
||||||
|
///
|
||||||
|
/// On success, the total number of bytes that were copied to `writer` is returned.
|
||||||
|
/// [`std::io::copy`]: https://doc.rust-lang.org/std/io/fn.copy.html
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
/// # fn run() -> Result<(), Box<::std::error::Error>> {
|
||||||
|
/// let mut resp = reqwest::get("http://httpbin.org/range/5")?;
|
||||||
|
/// let mut buf: Vec<u8> = vec![];
|
||||||
|
/// resp.copy_to(&mut buf)?;
|
||||||
|
/// assert_eq!(b"abcde", buf.as_slice());
|
||||||
|
/// # Ok(())
|
||||||
|
/// # }
|
||||||
|
/// ```
|
||||||
|
#[inline]
|
||||||
|
pub fn copy_to<W: ?Sized>(&mut self, w: &mut W) -> io::Result<u64>
|
||||||
|
where W: io::Write
|
||||||
|
{
|
||||||
|
io::copy(self, w)
|
||||||
|
}
|
||||||
|
|
||||||
/// Turn a response into an error if the server returned an error.
|
/// Turn a response into an error if the server returned an error.
|
||||||
///
|
///
|
||||||
/// # Example
|
/// # Example
|
||||||
|
|||||||
@@ -5,6 +5,40 @@ mod support;
|
|||||||
|
|
||||||
use std::io::Read;
|
use std::io::Read;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_response_copy_to() {
|
||||||
|
let server = server! {
|
||||||
|
request: b"\
|
||||||
|
GET /1 HTTP/1.1\r\n\
|
||||||
|
Host: $HOST\r\n\
|
||||||
|
User-Agent: $USERAGENT\r\n\
|
||||||
|
Accept: */*\r\n\
|
||||||
|
Accept-Encoding: gzip\r\n\
|
||||||
|
\r\n\
|
||||||
|
",
|
||||||
|
response: b"\
|
||||||
|
HTTP/1.1 200 OK\r\n\
|
||||||
|
Server: test\r\n\
|
||||||
|
Content-Length: 5\r\n\
|
||||||
|
\r\n\
|
||||||
|
Hello\
|
||||||
|
"
|
||||||
|
};
|
||||||
|
|
||||||
|
let url = format!("http://{}/1", server.addr());
|
||||||
|
let mut res = reqwest::get(&url).unwrap();
|
||||||
|
assert_eq!(res.url().as_str(), &url);
|
||||||
|
assert_eq!(res.status(), reqwest::StatusCode::Ok);
|
||||||
|
assert_eq!(res.headers().get(),
|
||||||
|
Some(&reqwest::header::Server::new("test".to_string())));
|
||||||
|
assert_eq!(res.headers().get(),
|
||||||
|
Some(&reqwest::header::ContentLength(5)));
|
||||||
|
|
||||||
|
let mut buf: Vec<u8> = vec![];
|
||||||
|
res.copy_to(&mut buf).unwrap();
|
||||||
|
assert_eq!(b"Hello", buf.as_slice());
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_get() {
|
fn test_get() {
|
||||||
let server = server! {
|
let server = server! {
|
||||||
|
|||||||
Reference in New Issue
Block a user