Merge pull request #20 from Michael-F-Bryan/testing
Added some trivial tests for the RequestBuilder
This commit is contained in:
		
							
								
								
									
										32
									
								
								src/body.rs
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								src/body.rs
									
									
									
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| use std::io::Read; | use std::io::{Cursor, Read}; | ||||||
|  | use std::io; | ||||||
| use std::fs::File; | use std::fs::File; | ||||||
| use std::fmt; | use std::fmt; | ||||||
|  |  | ||||||
| @@ -27,11 +28,39 @@ impl Body { | |||||||
|     */ |     */ | ||||||
| } | } | ||||||
|  |  | ||||||
|  | impl Read for Body { | ||||||
|  |     fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> { | ||||||
|  |         self.reader.read(buf) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| enum Kind { | enum Kind { | ||||||
|     Reader(Box<Read>, Option<u64>), |     Reader(Box<Read>, Option<u64>), | ||||||
|     Bytes(Vec<u8>), |     Bytes(Vec<u8>), | ||||||
| } | } | ||||||
|  |  | ||||||
|  | impl Read for Kind { | ||||||
|  |     fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> { | ||||||
|  |         match *self { | ||||||
|  |             Kind::Reader(ref mut reader, _) => { | ||||||
|  |                 reader.read(buf) | ||||||
|  |             } | ||||||
|  |             Kind::Bytes(ref mut bytes) => { | ||||||
|  |                 // To make sure the bytes are removed properly when you read | ||||||
|  |                 // them, you need to use `drain()` | ||||||
|  |                 // FIXME: this will probably have poor performance for larger | ||||||
|  |                 // bodies due to allocating more than necessary. | ||||||
|  |                 let drained_bytes: Vec<u8> = bytes.drain(..).collect(); | ||||||
|  |  | ||||||
|  |                 // then you need a Cursor because a standard Vec doesn't implement | ||||||
|  |                 // Read | ||||||
|  |                 let mut cursor = Cursor::new(drained_bytes); | ||||||
|  |                 cursor.read(buf) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| impl From<Vec<u8>> for Body { | impl From<Vec<u8>> for Body { | ||||||
|     #[inline] |     #[inline] | ||||||
|     fn from(v: Vec<u8>) -> Body { |     fn from(v: Vec<u8>) -> Body { | ||||||
| @@ -101,4 +130,3 @@ pub fn as_hyper_body<'a>(body: &'a mut Body) -> ::hyper::client::Body<'a> { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										138
									
								
								src/client.rs
									
									
									
									
									
								
							
							
						
						
									
										138
									
								
								src/client.rs
									
									
									
									
									
								
							| @@ -283,3 +283,141 @@ impl Read for Response { | |||||||
|         self.inner.read(buf) |         self.inner.read(buf) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | #[cfg(test)] | ||||||
|  | mod tests { | ||||||
|  |     use super::*; | ||||||
|  |     use hyper::method::Method; | ||||||
|  |     use hyper::Url; | ||||||
|  |     use hyper::header::{Host, Headers, ContentType}; | ||||||
|  |     use std::collections::HashMap; | ||||||
|  |     use std::io::Read; | ||||||
|  |     use serde_urlencoded; | ||||||
|  |     use serde_json; | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn basic_get_request() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let r = client.get(some_url); | ||||||
|  |  | ||||||
|  |         assert_eq!(r.method, Method::Get); | ||||||
|  |         assert_eq!(r.url, Url::parse(some_url)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn basic_head_request() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let r = client.head(some_url); | ||||||
|  |  | ||||||
|  |         assert_eq!(r.method, Method::Head); | ||||||
|  |         assert_eq!(r.url, Url::parse(some_url)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn basic_post_request() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let r = client.post(some_url); | ||||||
|  |  | ||||||
|  |         assert_eq!(r.method, Method::Post); | ||||||
|  |         assert_eq!(r.url, Url::parse(some_url)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn add_header() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let mut r = client.post(some_url); | ||||||
|  |  | ||||||
|  |         let header = Host { | ||||||
|  |             hostname: "google.com".to_string(), | ||||||
|  |             port: None, | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         // Add a copy of the header to the request builder | ||||||
|  |         r = r.header(header.clone()); | ||||||
|  |  | ||||||
|  |         // then check it was actually added | ||||||
|  |         assert_eq!(r.headers.get::<Host>(), Some(&header)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn add_headers() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let mut r = client.post(some_url); | ||||||
|  |  | ||||||
|  |         let header = Host { | ||||||
|  |             hostname: "google.com".to_string(), | ||||||
|  |             port: None, | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         let mut headers = Headers::new(); | ||||||
|  |         headers.set(header); | ||||||
|  |  | ||||||
|  |         // Add a copy of the headers to the request builder | ||||||
|  |         r = r.headers(headers.clone()); | ||||||
|  |  | ||||||
|  |         // then make sure they were added correctly | ||||||
|  |         assert_eq!(r.headers, headers); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn add_body() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let mut r = client.post(some_url); | ||||||
|  |  | ||||||
|  |         let body = "Some interesting content"; | ||||||
|  |  | ||||||
|  |         r = r.body(body); | ||||||
|  |  | ||||||
|  |         let mut buf = String::new(); | ||||||
|  |         r.body.unwrap().unwrap().read_to_string(&mut buf).unwrap(); | ||||||
|  |  | ||||||
|  |         assert_eq!(buf, body); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn add_form() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let mut r = client.post(some_url); | ||||||
|  |  | ||||||
|  |         let mut form_data = HashMap::new(); | ||||||
|  |         form_data.insert("foo", "bar"); | ||||||
|  |  | ||||||
|  |         r = r.form(&form_data); | ||||||
|  |  | ||||||
|  |         // Make sure the content type was set | ||||||
|  |         assert_eq!(r.headers.get::<ContentType>(), Some(&ContentType::form_url_encoded())); | ||||||
|  |  | ||||||
|  |         let mut buf = String::new(); | ||||||
|  |         r.body.unwrap().unwrap().read_to_string(&mut buf).unwrap(); | ||||||
|  |  | ||||||
|  |         let body_should_be = serde_urlencoded::to_string(&form_data).unwrap(); | ||||||
|  |         assert_eq!(buf, body_should_be); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     #[test] | ||||||
|  |     fn add_json() { | ||||||
|  |         let client = Client::new().unwrap(); | ||||||
|  |         let some_url = "https://google.com/"; | ||||||
|  |         let mut r = client.post(some_url); | ||||||
|  |  | ||||||
|  |         let mut json_data = HashMap::new(); | ||||||
|  |         json_data.insert("foo", "bar"); | ||||||
|  |  | ||||||
|  |         r = r.json(&json_data); | ||||||
|  |  | ||||||
|  |         // Make sure the content type was set | ||||||
|  |         assert_eq!(r.headers.get::<ContentType>(), Some(&ContentType::json())); | ||||||
|  |  | ||||||
|  |         let mut buf = String::new(); | ||||||
|  |         r.body.unwrap().unwrap().read_to_string(&mut buf).unwrap(); | ||||||
|  |  | ||||||
|  |         let body_should_be = serde_json::to_string(&json_data).unwrap(); | ||||||
|  |         assert_eq!(buf, body_should_be); | ||||||
|  |     } | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user