#testing #injection #fault #reliability #crash #io-error

fault-injection

Simple fault injection, concurrency delay injection, and error source annotation

9 stable releases

1.0.10 Aug 5, 2023
1.0.9 Jun 19, 2023
1.0.7 Aug 13, 2022
1.0.4 Jul 3, 2022
0.1.0 May 16, 2022

#133 in Concurrency

Download history 202/week @ 2024-09-16 175/week @ 2024-09-23 97/week @ 2024-09-30 96/week @ 2024-10-07 115/week @ 2024-10-14 122/week @ 2024-10-21 120/week @ 2024-10-28 171/week @ 2024-11-04 262/week @ 2024-11-11 85/week @ 2024-11-18 85/week @ 2024-11-25 118/week @ 2024-12-02 322/week @ 2024-12-09 2717/week @ 2024-12-16 1171/week @ 2024-12-23 813/week @ 2024-12-30

5,033 downloads per month
Used in 11 crates (4 directly)

MIT/Apache

10KB
83 lines

fault-injection

docs

Similar to the try! macro or ? operator, but externally controllable to inject faults during testing. Unlike the try! macro or ? operator, this additionally annotates the description of the error to include the crate, file name, and line number where the error originated from to facilitate quick debugging. It is specialized to work with io::Result types, and will return an io::Error for faults, with into() called similar to the try! macro or ? operator. Decrements the FAULT_INJECT_COUNTER by 1 (it is set to u64::MAX by default), and if it hits 0, returns an io::Error with a kind of Other. If SLEEPINESS is set to something other than 0, this macro will also inject weakly pseudorandom delays for facilitating a basic form of concurrency testing.

Examples

use std::io;

use fault_injection::{fallible, set_trigger_function, FAULT_INJECT_COUNTER};

fn trigger_fn(crate_name: &str, file_name: &str, line_number: u32) {
    println!(
        "fault injected at {} {} {}",
        crate_name, file_name, line_number
    );
}

fn do_io() -> io::Result<()> {
    Ok(())
}

// this will return an injected error
fn use_it() -> std::io::Result<()> {
    set_trigger_function(trigger_fn);
    FAULT_INJECT_COUNTER.store(1, std::sync::atomic::Ordering::Release);

    fallible!(do_io());

    Ok(())
}

No runtime deps