run_make_support::command

Struct Command

Source
pub struct Command {
    cmd: Command,
    stdin_buf: Option<Box<[u8]>>,
    stdin: Option<Stdio>,
    stdout: Option<Stdio>,
    stderr: Option<Stdio>,
    drop_bomb: DropBomb,
    already_executed: bool,
}
Expand description

This is a custom command wrapper that simplifies working with commands and makes it easier to ensure that we check the exit status of executed processes.

§A Command must be executed exactly once

A Command is armed by a [DropBomb] on construction to enforce that it will be executed. If a Command is constructed but never executed, the drop bomb will explode and cause the test to panic. Execution methods run and run_fail will defuse the drop bomb. A test containing constructed but never executed commands is dangerous because it can give a false sense of confidence.

Each Command invocation can also only be executed once, because we want to enforce std{in,out,err} config via std::process::Stdio but std::process::Stdio is not cloneable.

In this sense, Command exhibits linear type semantics but enforced at run-time.

Fields§

§cmd: Command§stdin_buf: Option<Box<[u8]>>§stdin: Option<Stdio>§stdout: Option<Stdio>§stderr: Option<Stdio>§drop_bomb: DropBomb§already_executed: bool

Implementations§

Source§

impl Command

Source

pub fn new<P: AsRef<OsStr>>(program: P) -> Self

Source

pub fn stdin_buf<I: AsRef<[u8]>>(&mut self, input: I) -> &mut Self

Specify a stdin input buffer. This is a convenience helper,

Source

pub fn stdin<T: Into<Stdio>>(&mut self, cfg: T) -> &mut Self

Configuration for the child process’s standard input (stdin) handle.

See std::process::Command::stdin.

Source

pub fn stdout<T: Into<Stdio>>(&mut self, cfg: T) -> &mut Self

Configuration for the child process’s standard output (stdout) handle.

See std::process::Command::stdout.

Source

pub fn stderr<T: Into<Stdio>>(&mut self, cfg: T) -> &mut Self

Configuration for the child process’s standard error (stderr) handle.

See std::process::Command::stderr.

Source

pub fn env<K, V>(&mut self, key: K, value: V) -> &mut Self
where K: AsRef<OsStr>, V: AsRef<OsStr>,

Specify an environment variable.

Source

pub fn env_remove<K>(&mut self, key: K) -> &mut Self
where K: AsRef<OsStr>,

Remove an environmental variable.

Source

pub fn arg<S>(&mut self, arg: S) -> &mut Self
where S: AsRef<OsStr>,

Generic command argument provider. Prefer specific helper methods if possible. Note that for some executables, arguments might be platform specific. For C/C++ compilers, arguments might be platform and compiler specific.

Source

pub fn args<S, V>(&mut self, args: V) -> &mut Self
where S: AsRef<OsStr>, V: AsRef<[S]>,

Generic command arguments provider. Prefer specific helper methods if possible. Note that for some executables, arguments might be platform specific. For C/C++ compilers, arguments might be platform and compiler specific.

Source

pub fn inspect<I>(&mut self, inspector: I) -> &mut Self
where I: FnOnce(&StdCommand),

Inspect what the underlying std::process::Command is up to the current construction.

Source

pub fn current_dir<P: AsRef<Path>>(&mut self, path: P) -> &mut Self

Set the path where the command will be run.

Source

pub fn run(&mut self) -> CompletedProcess

Run the constructed command and assert that it is successfully run.

By default, std{in,out,err} are Stdio::piped().

Source

pub fn run_fail(&mut self) -> CompletedProcess

Run the constructed command and assert that it does not successfully run.

By default, std{in,out,err} are Stdio::piped().

Source

pub fn run_unchecked(&mut self) -> CompletedProcess

Run the command but do not check its exit status. Only use if you explicitly don’t care about the exit status.

Prefer to use Self::run and Self::run_fail whenever possible.

Source

fn command_output(&mut self) -> CompletedProcess

Trait Implementations§

Source§

impl Debug for Command

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 312 bytes