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

#122 in HTTP client

Download history 973/week @ 2024-04-03 789/week @ 2024-04-10 989/week @ 2024-04-17 886/week @ 2024-04-24 779/week @ 2024-05-01 867/week @ 2024-05-08 771/week @ 2024-05-15 873/week @ 2024-05-22 915/week @ 2024-05-29 737/week @ 2024-06-05 701/week @ 2024-06-12 713/week @ 2024-06-19 961/week @ 2024-06-26 458/week @ 2024-07-03 670/week @ 2024-07-10 660/week @ 2024-07-17

2,876 downloads per month
Used in greenhouse_core

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–19MB
~287K SLoC