assertables/
lib.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
//! # Assertables: Rust crate of assert macros for testing
//!
//! The `assertables` Rust crate provides many assert macros to improve your
//! compile-time tests and run-time reliability.
//!
//! * Crate: [https://crates.io/crates/assertables](https://crates.io/crates/assertables)
//! * Docs: [https://docs.rs/assertables/](https://docs.rs/assertables/)
//! * Repo: [https://github.com/sixarm/assertables-rust-crate/](https://github.com/sixarm/assertables-rust-crate/)
//! * Contact: [joel@joelparkerhenderson.com](mailto:joel@joelparkerhenderson.com)
//!
//! ## Introduction
//!
//! The Rust programming language provides a few built-in assert macros to test
//! code:
//!
//! The Rust programming language provides assert macros to test code:
//!
//! * [`assert!(a)`](https://doc.rust-lang.org/std/macro.assert.html) `// a is true`
//! * [`assert_eq!(a, b)`](https://doc.rust-lang.org/std/macro.assert_eq.html) `// a is equal to b`
//! * [`assert_ne!(a, b)`](https://doc.rust-lang.org/std/macro.assert_ne.html) `// a is not equal to b`
//!
//! The assertables crate provides many more, to help you work with numbers,
//! strings, results, options, polls, iterators, files, streams, commands, and more. 
//!
//! Examples:
//!
//! ```rust
//! use assertables::*;
//! # fn main() {
//! let s = "hello world";
//! assert_matches!(s, "hello world");
//! assert_starts_with!(s, "hello");
//! assert_ends_with!(s, "world");
//! assert_contains!(s, "o");
//! assert_len_eq!(s, "***********");
//! assert_all!(s.chars(), |c: char| c < 'x');
//! assert_any!(s.chars(), |c: char| c.is_whitespace());
//! # }
//!  ```
//! 
//! To use the macros, add this to your `Cargo.toml` file:
//!
//! ```toml
//! [dev-dependencies]
//! assertables = "*"
//! ```
//! 
//! Top benefits:
//!
//! 1. You can write better tests to improve reliability and maintainability.
//! 2. You can handle more corner cases without needing to write custom code.
//! 3. You can troubleshoot faster because error messages show specifics.
//!
//! Top features:
//!
//! 1. Easy to use: everything is well-documented with runnable examples.
//! 2. Zero overhead: if you don't use a macro, then it's never compiled.
//! 3. Runtime options: all the assertables macros have runtime versions.
//!
//! Top comparison crates:
//!    `[assert_matches](https://crates.io/crates/assert_matches)`,
//!    `[assert_approx_eq](https://crates.io/crates/assert_approx_eq)`,
//!    `[more_asserts](https://crates.io/crates/more_asserts)`,
//!    `[cool_asserts](https://crates.io/crates/cool_asserts)`.
//!    `[claims](https://crates.io/crates/claims)`.
//!
//! ## Highlights
//!
//! Values:
//! 
//! * [assert_eq!(a, b);](module@crate::assert_eq) `// equal to`
//! * [assert_ne!(a, b);](module@crate::assert_ne) `// not equal to`
//! * [assert_lt!(a, b);](module@crate::assert_lt) `// less than`
//! * [assert_le!(a, b);](module@crate::assert_le) `// less than or equal to`
//! * [assert_gt!(a, b);](module@crate::assert_gt) `// greater than`
//! * [assert_ge!(a, b);](module@crate::assert_ge) `// greater than or equal to`
//! 
//! Approximations:
//! 
//! * [assert_approx_eq!(number, number);](module@crate::assert_approx) `// |a-b| ≤ 1e-6`
//! * [assert_in_delta!(number, number, delta);](module@crate::assert_in_delta) `// |a-b| ≤ delta`
//! * [assert_in_epsilon!(number, number, epsilon);](module@crate::assert_in_epsilon) `// |a-b| ≤ epsilon * min(a,b)`
//! 
//! Groups for iterators, chars, etc.:
//! 
//! * [assert_all!(group, predicate);](module@crate::assert_all) `// group.all(predicate)`
//! * [assert_any!(group, predicate);](module@crate::assert_any) `// group.any(predicate)`
//! 
//! Infix for order operators, logic operators, etc.:
//! 
//! * [assert_infix!(a == b);](module@crate::assert_infix) `// order: == != < <= > >=`
//! * [assert_infix!(a && b);](module@crate::assert_infix) `// logic: && || ^ & |`
//! 
//! Parts for strings, vectors, etc.:
//! 
//! * [assert_starts_with!(whole, part);](module@crate::assert_starts_with) `// whole.starts_with(part)`
//! * [assert_ends_with!(whole, part);](module@crate::assert_ends_with) `// whole.ends_with(part)`
//! 
//! Lengths for strings, vectors, etc.:
//! 
//! * [assert_len!(item);](module@crate::assert_len) `// item.len()`
//! * [assert_is_empty!(item);](module@crate::assert_is_empty) `// item.is_empty()`
//! 
//! Matching for strings, regex, etc.:
//! 
//! * [assert_matches!(expression, pattern);](module@crate::assert_matches) `// matches!(expression, pattern)`
//! * [assert_is_match!(matcher, matchee);](module@crate::assert_is_match) `// matcher.is_match(matchee)`
//! * [assert_contains!(container, containee);](module@crate::assert_contains) `// container.contains(containee)`
//! 
//! Collections for arrays, vectors, iterators, sets, maps:
//! 
//! * [assert_iter_eq!(arr1, arr2);](module@crate::assert_iter) `// eq ne lt le gt ge`
//! * [assert_set_eq!(vec1, vec2);](module@crate::assert_set) `// eq ne lt le gt ge etc.`
//! * [assert_bag_eq!(map1, map2);](module@crate::assert_bag) `// eq ne lt le gt ge etc.`
//! 
//! Result Ok/Err:
//! 
//! * [assert_ok!(result);](module@crate::assert_ok) `// eq ne lt le gt ge`
//! * [assert_err!(result);](module@crate::assert_err) `// eq ne lt le gt ge`
//!   
//! Option Some/None:
//! 
//! * [assert_some!(option);](module@crate::assert_some) `// eq ne lt le gt ge`
//! * [assert_none!(option);](module@crate::assert_none)
//! 
//! Poll Ready/Pending:
//! 
//! * [assert_ready!(poll);](module@crate::assert_ready) `// eq ne lt le gt ge`
//! * [assert_pending!(poll);](module@crate::assert_pending)
//! 
//! Read file system paths and input/output streams:
//! 
//! * [assert_fs_read_to_string_eq!(path1, path2);](module@crate::assert_fs_read_to_string) `// eq ne lt le gt ge`
//! * [assert_io_read_to_string_eq!(stream1, stream2);](module@crate::assert_io_read_to_string) `// eq ne lt le gt ge`
//! 
//! Run commands and programs then assert on stdout or stderr:
//! 
//! * [assert_command_stdout_eq!(command1, command2);](module@crate::assert_command) `// eq ne lt le gt ge etc.`
//! * [assert_program_args_stdout_eq!(program1, args1, program2, args2);](module@crate::assert_program_args) `// eq ne lt le gt ge etc.`
//! 
//! Function comparisons, which are especially good for refactoring:
//! 
//! * [assert_fn_eq!(fn1, fn2);](module@crate::assert_fn) `// functions that return values`
//! * [assert_fn_ok_eq!(fn1, fn2);](module@crate::assert_fn_ok) `// functions that return Ok`
//! * [assert_fn_err_eq!(fn1, fn2);](module@crate::assert_fn_err) `// functions that return Err`
//! 
//! ## Forms
//! 
//! All assertables macros have forms for different outcomes:
//! 
//! * `[assert_gt!(a, b);](module@crate::macro.assert_gt.html) // panic during typical test`
//! * `[assert_gt_as_result!(a, b);](module@crate::macro.assert_gt_as_result.html) // return Ok or Err`
//! * `[debug_assert_gt!(a, b);](module@crate::macro.debug_assert_gt.html) // panic when in debug mode`
//! 
//! All assertables macros have forms for an optional message:
//! 
//! * `[assert_gt!(a, b);](module@crate::macro.assert_gt) // automatic error message`
//! * `[assert_gt!(a, b, "your text");](module@crate::macro.assert_gt) // custom error message`
//! 
//! Many assertables macros have forms for comparing left hand side (LHS) and right hand side (RHS) as the same type or as an arbitrary expression:
//! 
//! * `[assert_ok_eq!(a, b);](module@crate::macro.assert_ok_eq.html) // Ok(…) = Ok(…)`
//! * `[assert_ok_eq_expr!(a, b);](module@crate::macro.assert_ok_eq_expr.html) // Ok(…) = expression`
//! 
//! ## Forms
//!
//! All assertables macros have forms for an optional message:
//!
//! * [`assert_gt!(a, b)`](macro@crate::assert_gt) `// automatic message`
//! * [`assert_gt!(a, b, "Your text")`](macro@crate::assert_gt) `// custom message`
//!
//! All assertables macros have forms for different outcomes:
//!
//! * [`assert_gt!(a, b)`](macro@crate::assert_gt) `// panic during typical test`
//! * [`assert_gt_as_result!(a, b)`](macro@crate::assert_gt_as_result) `// return Ok or Err`
//! * [`debug_assert_gt!(a, b)`](macro@crate::debug_assert_gt) `// panic when in debug mode`
//!
//! Many assertables macros have forms for comparing left hand side (LHS) and
//! right hand side (RHS) as the same type or as an arbitrary expression:
//!
//! * [`assert_ok_eq!(a, b)`](macro@crate::assert_ok_eq) `// Ok(…) = Ok(…)`
//! * [`assert_ok_eq_expr!(a, b)`](macro@crate::assert_ok_eq_expr) `// Ok(…) = expression`
//!
//! ## Tracking
//!
//! * Package: assertables-rust-crate
//! * Version: 8.17.0
//! * Created: 2021-03-30T15:47:49Z
//! * Updated: 2024-10-09T18:40:20Z
//! * License: MIT or Apache-2.0 or GPL-2.0 or GPL-3.0 or contact us for more
//! * Contact: Joel Parker Henderson (joel@sixarm.com)

// Assert truth
pub mod assert; // (in addition to what's provided by Rust `std`)

// Assert value comparison
pub mod assert_eq; // (in addition to what's provided by Rust `std`)
pub mod assert_ne; // (in addition to what's provided by Rust `std`)
pub mod assert_lt;
pub mod assert_le;
pub mod assert_gt;
pub mod assert_ge;

// Assert value nearness
pub mod assert_approx;
pub mod assert_in_delta;
pub mod assert_in_epsilon;

// Assert all/any
pub mod assert_all;
pub mod assert_any;

// Infix
pub mod assert_infix;

// Matching
pub mod assert_is_empty;
pub mod assert_is_match;
pub mod assert_matches;
pub mod assert_contains;
pub mod assert_starts_with;
pub mod assert_ends_with;
pub mod assert_len;

// For Result Ok/Err
pub mod assert_ok;
pub mod assert_err;
pub mod assert_result; // Deprecated

// For Option Some/None
pub mod assert_some;
pub mod assert_none;
pub mod assert_option; // Deprecated

// For Poll Ready/Pending
pub mod assert_ready;
pub mod assert_pending;
pub mod assert_poll; // Deprecated

// For collections
pub mod assert_iter;
pub mod assert_set;
pub mod assert_bag;

// For functions
pub mod assert_fn;
pub mod assert_fn_ok;
pub mod assert_fn_err;

// For reading
pub mod assert_fs_read_to_string;
pub mod assert_io_read_to_string;

// For externals
pub mod assert_command;
pub mod assert_program_args;