39 releases

0.8.0-alpha.1 Sep 1, 2024
0.7.0 Jan 5, 2024
0.7.0-rc.1 Oct 15, 2023
0.6.8 Jul 5, 2023
0.3.3 Oct 3, 2019

#10 in Testing

Download history 79715/week @ 2024-09-26 90229/week @ 2024-10-03 91908/week @ 2024-10-10 88115/week @ 2024-10-17 85207/week @ 2024-10-24 79889/week @ 2024-10-31 88063/week @ 2024-11-07 93080/week @ 2024-11-14 82792/week @ 2024-11-21 80306/week @ 2024-11-28 95544/week @ 2024-12-05 93963/week @ 2024-12-12 60478/week @ 2024-12-19 30057/week @ 2024-12-26 64426/week @ 2025-01-02 75113/week @ 2025-01-09

248,267 downloads per month
Used in 169 crates (167 directly)

MIT license

1.5MB
12K SLoC

httpmock

Simple yet powerful HTTP mocking library for Rust

Build codecov crates.io Mentioned in Awesome Rust Discord

Website · API Reference · Chat · Crate · Report Bug · Request Feature · Changelog · Support this Project

Features

  • Simple, expressive, fluent API.
  • Many built-in helpers for easy request matching (Regex, JSON, serde, cookies, and more).
  • Record and Playback
  • Forward and Proxy Mode
  • HTTPS support
  • Fault and network delay simulation.
  • Custom request matchers.
  • Standalone mode with an accompanying Docker image.
  • Helpful error messages
  • Advanced verification and debugging support (including diff generation between actual and expected HTTP request values)
  • Parallel test execution.
  • Fully asynchronous core with synchronous and asynchronous APIs.
  • Support for mock configuration using YAML files.

Getting Started

Add httpmock to Cargo.toml:

[dev-dependencies]
httpmock = "0.8.0-alpha.1"

You can then use httpmock as follows:

use httpmock::prelude::*;

// Start a lightweight mock server.
let server = MockServer::start();

// Create a mock on the server.
let mock = server.mock(|when, then| {
    when.method(GET)
        .path("/translate")
        .query_param("word", "hello");
    then.status(200)
        .header("content-type", "text/html; charset=UTF-8")
        .body("Привет");
});

// Send an HTTP request to the mock server. This simulates your code.
let response = isahc::get(server.url("/translate?word=hello")).unwrap();

// Ensure the specified mock was called exactly one time (or fail with a
// detailed error description).
mock.assert();

// Ensure the mock server did respond as specified.
assert_eq!(response.status(), 200);

The above example will spin up a lightweight HTTP mock server and configure it to respond to all GET requests to path /translate with query parameter word=hello. The corresponding HTTP response will contain the text body Привет.

When the specified expectations do not match the received request, httpmock provides a detailed error description, including a diff that shows the differences between the expected and actual HTTP requests. Example:

0 of 1 expected requests matched the mock specification.
Here is a comparison with the most similar unmatched request (request number 1):

------------------------------------------------------------
1 : Query Parameter Mismatch
------------------------------------------------------------
Expected:
    key    [equals]  word
    value  [equals]  hello-rustaceans

Received (most similar query parameter):
    word=hello

All received query parameter values:
    1. word=hello

Matcher:  query_param
Docs:     https://docs.rs/httpmock/0.8.0-alpha.1/httpmock/struct.When.html#method.query_param

Usage

See the official website for detailed API documentation.

Examples

You can find examples in the httpmock test directory. The official website and reference docs also contain a lot of examples.

License

httpmock is free software: you can redistribute it and/or modify it under the terms of the MIT Public License.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the MIT Public License for more details.

Dependencies

~15–32MB
~522K SLoC