5 unstable releases

0.3.1 Dec 10, 2023
0.3.0 May 15, 2022
0.2.1 Dec 11, 2021
0.2.0 Dec 22, 2020
0.1.0 Sep 7, 2020

#357 in Testing

Download history 57443/week @ 2024-09-18 63083/week @ 2024-09-25 62728/week @ 2024-10-02 56996/week @ 2024-10-09 72176/week @ 2024-10-16 59867/week @ 2024-10-23 60174/week @ 2024-10-30 49167/week @ 2024-11-06 78063/week @ 2024-11-13 61549/week @ 2024-11-20 52109/week @ 2024-11-27 61140/week @ 2024-12-04 69182/week @ 2024-12-11 32357/week @ 2024-12-18 8903/week @ 2024-12-25 17693/week @ 2025-01-01

137,563 downloads per month
Used in 38 crates (32 directly)

MIT/Apache

15KB
217 lines

mockall_double

A double test adapter that works well with Mockall.

Build Status Crates.io Documentation

Overview

Mockall can easily create a mock version of a struct. But how does one convince the code under test to use the mock struct instead of the real one? In Rust, it's necessary to replace the real struct at compile time. That's very easy to do with a few #[cfg(test)] statements. But mockall_double makes it even easier.

Usage

Typically mockall is only used by unit tests, so it can be a dev-dependency. But mockall_double must be a full dependency. To use it this way, add this to your Cargo.toml:

[dependencies]
mockall_double = "0.3.1"

[dev-dependencies]
mockall = "0.12.0"

Then use it like this:

use mockall_double::double;

mod mockable {
    #[cfg(test)]
    use mockall::automock;

    pub struct Foo {}
    #[cfg_attr(test, automock)]
    impl Foo {
        pub fn foo(&self, x: u32) -> u32 {
            // ...
            0
        }
    }
}

#[double]
use mockable::Foo;

fn bar(f: Foo) -> u32 {
    f.foo(42)
}

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn bar_test() {
        let mut mock = Foo::new();
        mock.expect_foo()
            .returning(|x| x + 1);
        assert_eq!(43, bar(mock));
    }
}

See the API docs for more information.

Minimum Supported Rust Version (MSRV)

mockall_double is tested with the same MSRV as Mockall itself. Currently, that's Rust 1.42.0. mockall_double's MSRV will not be changed in the future without bumping the major or minor version.

License

mockall_double is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE, and LICENSE-MIT for details

Acknowledgements

mockall_double is inspired by Jason Grlicky's double crate, but tweaked to work better with Mockall's naming conventions.

Dependencies

~220–660KB
~16K SLoC