- Includes ergonomic traits like IntoUrl and IntoBody, allowing easy usage. - Client can have a RedirectPolicy. - Client can have a SslVerifier. Updated benchmarks for client. (Disabled rust-http client bench since it hangs.)
		
			
				
	
	
		
			107 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| #![feature(macro_rules)]
 | |
| extern crate curl;
 | |
| extern crate http;
 | |
| extern crate hyper;
 | |
| 
 | |
| extern crate test;
 | |
| 
 | |
| use std::fmt::{mod, Show};
 | |
| use std::io::net::ip::Ipv4Addr;
 | |
| use hyper::server::{Request, Response, Server};
 | |
| use hyper::method::Method::Get;
 | |
| use hyper::header::Headers;
 | |
| use hyper::Client;
 | |
| use hyper::client::RequestBuilder;
 | |
| 
 | |
| fn listen() -> hyper::server::Listening {
 | |
|     let server = Server::http(Ipv4Addr(127, 0, 0, 1), 0);
 | |
|     server.listen(handle).unwrap()
 | |
| }
 | |
| 
 | |
| macro_rules! try_return(
 | |
|     ($e:expr) => {{
 | |
|         match $e {
 | |
|             Ok(v) => v,
 | |
|             Err(..) => return
 | |
|         }
 | |
|     }})
 | |
| 
 | |
| fn handle(_r: Request, res: Response) {
 | |
|     static BODY: &'static [u8] = b"Benchmarking hyper vs others!";
 | |
|     let mut res = try_return!(res.start());
 | |
|     try_return!(res.write(BODY))
 | |
|     try_return!(res.end());
 | |
| }
 | |
| 
 | |
| 
 | |
| #[bench]
 | |
| fn bench_curl(b: &mut test::Bencher) {
 | |
|     let mut listening = listen();
 | |
|     let s = format!("http://{}/", listening.socket);
 | |
|     let url = s.as_slice();
 | |
|     b.iter(|| {
 | |
|         curl::http::handle()
 | |
|             .get(url)
 | |
|             .header("X-Foo", "Bar")
 | |
|             .exec()
 | |
|             .unwrap()
 | |
|     });
 | |
|     listening.close().unwrap();
 | |
| }
 | |
| 
 | |
| #[deriving(Clone)]
 | |
| struct Foo;
 | |
| 
 | |
| impl hyper::header::Header for Foo {
 | |
|     fn header_name(_: Option<Foo>) -> &'static str {
 | |
|         "x-foo"
 | |
|     }
 | |
|     fn parse_header(_: &[Vec<u8>]) -> Option<Foo> {
 | |
|         None
 | |
|     }
 | |
| }
 | |
| 
 | |
| impl hyper::header::HeaderFormat for Foo {
 | |
|     fn fmt_header(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
 | |
|         "Bar".fmt(fmt)
 | |
|     }
 | |
| }
 | |
| 
 | |
| #[bench]
 | |
| fn bench_hyper(b: &mut test::Bencher) {
 | |
|     let mut listening = listen();
 | |
|     let s = format!("http://{}/", listening.socket);
 | |
|     let url = s.as_slice();
 | |
|     let mut client = Client::new();
 | |
|     let mut headers = Headers::new();
 | |
|     headers.set(Foo);
 | |
|     b.iter(|| {
 | |
|         client.get(url).header(Foo).send().unwrap().read_to_string().unwrap();
 | |
|     });
 | |
|     listening.close().unwrap()
 | |
| }
 | |
| 
 | |
| /*
 | |
| doesn't handle keep-alive properly...
 | |
| #[bench]
 | |
| fn bench_http(b: &mut test::Bencher) {
 | |
|     let mut listening = listen();
 | |
|     let s = format!("http://{}/", listening.socket);
 | |
|     let url = s.as_slice();
 | |
|     b.iter(|| {
 | |
|         let mut req: http::client::RequestWriter = http::client::RequestWriter::new(
 | |
|             http::method::Get,
 | |
|             hyper::Url::parse(url).unwrap()
 | |
|         ).unwrap();
 | |
|         req.headers.extensions.insert("x-foo".to_string(), "Bar".to_string());
 | |
|         // cant unwrap because Err contains RequestWriter, which does not implement Show
 | |
|         let mut res = match req.read_response() {
 | |
|             Ok(res) => res,
 | |
|             Err((_, ioe)) => panic!("http response failed = {}", ioe)
 | |
|         };
 | |
|         res.read_to_string().unwrap();
 | |
|     });
 | |
|     listening.close().unwrap()
 | |
| }
 | |
| */
 |