Assure: macros for Rust runtime checking

This Rust crate provides the macro assure! and related macros.

These macros are similar to the macro assert! and related macros.

Available via https://crates.io/crates/assure

Introduction

The assure! macros work like this:

Whereas assert! macros work like this:

Macros for simple values

Macro for truth checking:

Macros for value comparison:

Examples:

```rust assure_eq!(1, 1) -> Ok(true)

assureeq!(1, 2) -> Err("assureeq left:1 right:2")

assure_eq!(1, 2, "message") -> Err("message") ```

Macros for bag checking

These macros help with order-independent comparison of iterator bag parameters, such as comparison of two arrays, or two vectors.

Examples:

```rust assureseteq!([1, 1], [1, 1]) -> Ok(true)

assureseteq!([1, 1], [1, 1, 1]) -> Err("assurebageq left:{1: 2} right:{1: 3}")

assure_eq!([1, 1], [1, 1, 1], "message") -> Err("message") ```

Macros for set checking

These macros help with order-independent comparison of iterator set parameters, such as comparison of two arrays, or two vectors.

Examples:

```rust assureseteq!([1, 2], [2, 1]) -> Ok(true)

assureseteq!([1, 2], [3, 4]) -> Err("assureseteq left:{1, 2} right:{3, 4}")

assure_eq!([1, 2], [3, 4], "message") -> Err("message") ```

Macros for IO-related checking

These macros help with IO-related checking, such as comparison of files, streams, etc. These macros return a Result with Ok(true) or Err(std::io::Error::new(std::io::ErrorKind::InvalidInput, message)).

Macro for truth checking:

Macros for value comparison:

```rust assureioeq!(1, 1) -> Ok(true)

assureioeq!(1, 2) -> Err(std::io::Error::new(std::io::ErrorKind::InvalidInput, "assureioeq left:1 right:2"))

assureioeq!(1, 2, "message") -> Err(std::io::Error:new(std::io::ErrorKind::InvalidInput, "message")) ```