13 releases

0.1.9 Jan 24, 2024
0.1.8 Nov 20, 2023
0.1.7 Oct 18, 2023
0.1.5 Jul 14, 2023
0.1.1 Mar 19, 2023

#103 in HTTP client

Download history 418/week @ 2023-12-23 258/week @ 2023-12-30 431/week @ 2024-01-06 662/week @ 2024-01-13 612/week @ 2024-01-20 913/week @ 2024-01-27 818/week @ 2024-02-03 719/week @ 2024-02-10 801/week @ 2024-02-17 730/week @ 2024-02-24 615/week @ 2024-03-02 835/week @ 2024-03-09 871/week @ 2024-03-16 774/week @ 2024-03-23 1054/week @ 2024-03-30 631/week @ 2024-04-06

3,399 downloads per month

MIT/Apache

26KB
578 lines

Minimalistic HTTP Client Test Utilities.

  • Built on top of reqwest.
  • Optimized for testing convenience, not for performance.
  • Do not use for production/application code, just for testing.
  • For production code (apps, services, ...) use the underlying reqwest library and its utilities.

Thanks

Example

use anyhow::Result;
use serde_json::{json, Value};

#[tokio::test]
async fn test_simple_base() -> httpc_test::Result<()> {
	// Create a new httpc test client with a base URL (will be prefixed for all calls)
	// The client will have a cookie_store.
	let hc = httpc_test::new_client("http://localhost:8080")?;


	//// do_get, do_post, do_put, do_patch, do_delete return a httpc_test::Response

	// Simple do_get
	let res = hc.do_get("/hello").await?; // httpc_test::Response 
	let status = res.status();
	// Pretty print the result (status, headers, response cookies, client cookies, body)
	res.print().await?;

	let auth_token = res.res_cookie_value("auth-token"); // Option<String>
	let content_type = res.header("content_type"); // Option<&String>

	// Another do_get
	let res = hc.do_get("/context.rs").await?;
	// Pretty print but do not print the body 
	res.print_no_body().await?;


	//// get, post, put, patch, delete return a DeserializeOwned

	// a get (return a Deserialized)
	let json_value = hc.get::<Value>("/api/tickets").await?;

	// Another post (with the cookie store updated from the login request above )
	let res = hc
		.do_post(
			"/api/tickets",
			json!({
				"subject": "ticket 01"
			}),
		)
		.await?;
	res.print().await?;


	// Post with text content and specific content type
	let res = hc
		.do_post(
			"/api/tickets",
			(r#"{
				"subject": "ticket bb"
			}
			"#, 
			"application/json"),
		)
		.await?;
	res.print().await?;

	// Same woth do_patch, do_put.


	Ok(())
}



This GitHub repo

Dependencies

~7–21MB
~313K SLoC