35 releases

0.6.2 Jun 29, 2023
0.6.0-rc.1 Feb 21, 2023
0.5.0 Dec 2, 2022
0.5.0-rc.2 Oct 19, 2022
0.3.4 Mar 23, 2021

#585 in Testing

Download history 129/week @ 2025-08-26 211/week @ 2025-09-02 164/week @ 2025-09-09 317/week @ 2025-09-16 136/week @ 2025-09-23 147/week @ 2025-09-30 121/week @ 2025-10-07 162/week @ 2025-10-14 272/week @ 2025-10-21 118/week @ 2025-10-28 158/week @ 2025-11-04 170/week @ 2025-11-11 140/week @ 2025-11-18 196/week @ 2025-11-25 120/week @ 2025-12-02 136/week @ 2025-12-09

618 downloads per month
Used in 3 crates

Apache-2.0

595KB
13K SLoC

stubr

Wiremock rewritten in Rust


Read the full documentation here


lib.rs:

This crate proposes a reimplementation of Wiremock. Its aims at converting Wiremock stubs into wiremock-rs mocks.

You can also use stubr-build to share stubs between a producer project and a consumer one.

Also available as a cli.

use it

use isahc;
use stubr::*;
use asserhttp::*;

#[async_std::test]
async fn simple_async() {
    // supply a directory containing json stubs. Invalid files are just ignored
    let stubr = Stubr::start("tests/stubs").await;
    // or just mount a single file
    let stubr = Stubr::start("tests/stubs/hello.json").await;
    // or configure it (more configurations to come)
    let stubr = Stubr::start_with("tests/stubs", Config { port: Some(8080), ..Default::default() }).await;
    isahc::get_async(stubr.uri()).await.expect_status_ok();
}

#[test]
fn simple_blocking() {
    // can also be used in a blocking way
    let stubr = Stubr::start_blocking("tests/stubs");
    let stubr = Stubr::start_blocking_with("tests/stubs", Config { port: Some(8080), ..Default::default() });
    isahc::get(stubr.uri()).expect_status_ok();
}

macro

use isahc;
use stubr::*;
use asserhttp::*;

#[async_std::test]
#[stubr::mock] // <- takes all stubs under "tests/stubs"
async fn with_macro() {
    surf::get(stubr.uri()).await.expect_status_ok();
}

#[async_std::test]
#[stubr::mock("pets", port = 4321)] // <- takes all stubs under "tests/stubs/pets"
async fn with_path_and_port() {
    surf::get(stubr.uri()).await.expect_status_ok();
}

configuration

A Stubr server can be configured globally thanks to Config struct.

use stubr::Config;
let config = Config {
    // server port, defaults to random
    port: Some(8080),
    // enable verbose logs
    verbose: true,
    // global delay in milliseconds. Supersedes any locally defined one.
    global_delay: Some(2000),
    // delay in milliseconds added to any locally defined one. Simulates network latencies.
    latency: Some(2000),
    // Enables verification via https://docs.rs/wiremock/latest/wiremock/struct.Mock.html#method.expect
    verify: true,
};

Dependencies

~41–66MB
~1M SLoC