#stdio #testing #stderr #stdout #stdin #env #io-operations

io-providers

Enables dependency injection for many I/O operations

6 releases

Uses old Rust 2015

0.2.0-beta.3 Sep 23, 2018
0.2.0-beta.2 Sep 20, 2018
0.1.2 Sep 25, 2015

#714 in Filesystem

MIT license

61KB
998 lines

io-providers Build Status Latest Version Documentation License

Defines "provider" traits and implementations for different types of I/O operations, enabling dependency injection that's very helpful for testing.

A number of different I/O types are supported:

  • Process environment (variables, working directy etc), via Env
  • Standard streams (stdin, stdout and stderr), via StdStreams
  • Filesystem access, via Fs

In addition to "native" implementations for each trait, "simulated" implementations are also built-in:

  • SimulatedEnv for faking process environment state
  • SimulatedStdStreams for faking standard stream input and inspecting output
  • TempFs for performing filesystem access in a chroot-like sandbox isolated from the rest of the filesystem

Each provider trait can be used independently, however there is also the all-encompassing Io which provides access to all of them. If you have a variety of I/O dependencies, it might be easiest to create and pass around a single &mut Io.

Documentation

https://docs.rs/io-providers/

Examples

Cargo.toml:

[dependencies]
io-providers = "0.2.0-beta.2"

src/main.rs:

extern crate io_providers;

use std::io::Write;
use std::path::Path;
use io_providers::{Env, Io, NativeIo, SimulatedIo, StdStreams};

/// Gets the current working directory and prints it to stdout.
fn do_work<I: Io>(io: &mut I) {
    let cur_dir = io.env().current_dir().unwrap();
    let stdout = io.std_streams().output();
    writeln!(stdout, "The current directory is: {}", cur_dir.to_str().unwrap()).unwrap();
}

fn main() {
    // Test `do_work()` using a simulated I/O environment
    let mut simulated_io = SimulatedIo::new().unwrap();
    simulated_io.env_mut().set_current_dir(Path::new("/foo/bar")).unwrap();
    do_work(&mut simulated_io);
    assert_eq!(
        "The current directory is: /foo/bar\n",
        ::std::str::from_utf8(simulated_io.std_streams().read_output()).unwrap());

    // Now use a native I/O provided to access the real system
    let mut real_io = NativeIo::new();
    do_work(&mut real_io);
}

License

io-providers is distributed under the MIT license.

Dependencies

~2–11MB
~115K SLoC