6 releases
new 0.2.5-alpha | Apr 17, 2025 |
---|---|
0.2.4-alpha | Mar 18, 2025 |
#240 in Testing
353 downloads per month
87KB
2K
SLoC
mocktail is a minimal crate for mocking HTTP and gRPC servers in Rust, with native support for streaming.
Table of contents
Features
- Mocks HTTP and gRPC servers
- Mocks defined in Rust using a simple, ergonomic API
- Provides first-class support for streaming
- Supports gRPC unary, client-streaming, server-streaming, and bidirectional-streaming methods
- Match requests to mock responses using built-in matchers or custom matchers
- Fully asynchronous
Getting Started
-
Add
mocktail
toCargo.toml
as a development dependency:[dev-dependencies] mocktail = "0.2.5-alpha"
-
Basic usage example:
use mocktail::prelude::*; #[tokio::test] async fn test_example() -> Result<(), Box<dyn std::error::Error>> { // Create a mock set let mut mocks = MockSet::new(); // Build a mock that returns a "hello world!" response // to POST requests to the /hello endpoint with the text "world" // in the body. mocks.mock(|when, then| { when.post().path("/hello").text("world"); then.text("hello world!"); }); // Create and start a mock server let mut server = MockServer::new("example").with_mocks(mocks); server.start().await?; // Create a client let client = reqwest::Client::builder().http2_prior_knowledge().build()?; // Send a request that matches the mock created above let response = client .post(server.url("/hello")) .body("world") .send() .await?; assert_eq!(response.status(), http::StatusCode::OK); let body = response.text().await?; assert_eq!(body, "hello world!"); // Send a request that doesn't match a mock let response = client.get(server.url("/nope")).send().await?; assert_eq!(response.status(), http::StatusCode::NOT_FOUND); // Mocks can also be registered to the server directly // Register a mock that will match the request above that returned 404 server.mock(|when, then| { when.get().path("/nope"); then.text("yep!"); }); // Send the request again, it should now match let response = client.get(server.url("/nope")).send().await?; assert_eq!(response.status(), http::StatusCode::OK); let body = response.text().await?; assert_eq!(body, "yep!"); // Mocks can be cleared from the server, enabling server reuse server.mocks.clear(); Ok(()) }
Examples
See examples in the mocktail-tests
crate.
Related projects
This crate takes inspiration from other great mocking libraries including:
Dependencies
~10–20MB
~269K SLoC