Assure: macros for Rust runtime checking

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

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

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

Introduction

The assure macros work like this:

For comparison assert macros work like this:

Return Ok or Err

The assure macros return Result with either:

Example of Ok:

rust let a = 1; let b = 1; assure_eq!(a, b); //-> Ok(a)

Example of Err:

rust let a = 1; let b = 2; assure_eq!(a, b); //-> Err("assure_eq left:1 right:2")

Usage

The assure macros can useful for checking with the ? operator.

This example function uses the assure_gt! macro, which means assure greater than:

rust fn sum_positive_numbers(a: i32, b: i32) -> Result<i32, String> { assure_gt!(a, 0)?; assure_gt!(b, 0)?; Ok(a + b) }

Example of Ok:

rust sum_positive_numbers(1, 2); //-> Ok(3)

Example of Err:

rust sum_positive_numbers(1, -2); //-> Err("assure_gt left:-2 right:0)

Custom error messages

The assure macros generate a defult diagnostic error message such as:

The macros have a second form, where a custom error message can be provided as the last argument:

Example error message:

rust fn sum_positive_numbers(a: i32, b: i32) -> Result<i32, String> { assure_gt!(a, 0, "param 1 must be postive but is {}", a)?; assure_gt!(b, 0, "param 2 must be postive but is {}", b)?; Ok(a + b) }

Macros for simple values

Macro for truth checking:

Macros for value comparison:

Macros for set checking

The assure_set…! macros help with comparison of set parameters, such as two arrays or two vectors. where the item order does not matter, and the item count does not matter.

Example of Ok:

rust let a = [1, 2]; let b = [2, 1]; assure_set_eq!(&a, &b); //-> Ok(&a)

Example of Err:

rust let a = [1, 2]; let b = [3, 4]; assure_set_eq!(&a, &b); //-> Err("assure_set_eq left:{1, 2} right:{3, 4}")

Macros for bag checking

The assure_bag…! macros help with comparison of bag parameters, such as comparison of two arrays or two vectors, where the item order does not matter, and the item count does matter.

Example of Ok:

rust let a = [1, 1]; let b = [1, 1]; assure_set_eq!(&a, &b); //-> Ok(&a)

Example of Err:

rust let a = [1, 1]; let b = [1, 1, 1]; assure_set_eq!(&a, &b); //-> Err("assure_bag_eq left:{1: 2} right:{1: 3}")

Macros for IO-related checking

The assure_io…! 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:

Example of Ok:

rust let a = 1; let b = 1; assure_io_eq!(a, b); //-> Ok(a)

Example of Err:

rust let a = 1; let b = 2; assure_io_eq!(a, b); //-> Err( // std::io::Error::new( // std::io::ErrorKind::InvalidInput, // "assure_io_eq left:1 right:2" // ) // )