From 185c5127c9d56ea282edc48ef18ae39216d05aad Mon Sep 17 00:00:00 2001 From: Joakim Akerblom Date: Sat, 2 Mar 2024 00:25:08 +0100 Subject: [PATCH] Docs: Improve doc of module shrink::vec --- src/shrink/vec.rs | 57 ++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 54 insertions(+), 3 deletions(-) diff --git a/src/shrink/vec.rs b/src/shrink/vec.rs index c5f9b36..0df941f 100644 --- a/src/shrink/vec.rs +++ b/src/shrink/vec.rs @@ -1,17 +1,68 @@ -//! Shrinkers for vectors +//! Shrinkers for vectors. +//! +//! One design choice of the vector shrinker implementation is to aggressively +//! try to shrink size before individual elements are shrunk. +//! +//! ```rust +//! use monkey_test::*; +//! +//! let failing_example_to_shrink = vec![-1, 2, 3, 4, 5, 6, 7, 8]; +//! +//! let int_vectors = gen::vec::any(gen::i16::any()); +//! +//! let smaller_candidates = int_vectors +//! .shrinker() +//! .candidates(failing_example_to_shrink) +//! .take(20) +//! .collect::>(); +//! +//! assert_eq!{ +//! smaller_candidates, +//! vec![ +//! // Vector shrinker tries to aggressively shrink size before +//! // individual elements are shrunk. +//! vec![ ], +//! vec![ 5, 6, 7, 8], +//! vec![-1, 2, 3, 4, ], +//! vec![ 3, 4, 5, 6, 7, 8], +//! vec![-1, 2, 5, 6, 7, 8], +//! vec![-1, 2, 3, 4, 7, 8], +//! vec![-1, 2, 3, 4, 5, 6, ], +//! vec![ 2, 3, 4, 5, 6, 7, 8], +//! vec![-1, 3, 4, 5, 6, 7, 8], +//! vec![-1, 2, 4, 5, 6, 7, 8], +//! vec![-1, 2, 3, 5, 6, 7, 8], +//! vec![-1, 2, 3, 4, 6, 7, 8], +//! vec![-1, 2, 3, 4, 5, 7, 8], +//! vec![-1, 2, 3, 4, 5, 6, 8], +//! vec![-1, 2, 3, 4, 5, 6, 7, ], +//! // Shrinking of individul elements starts here. +//! // ↓ First element +//! vec![ 0, 2, 3, 4, 5, 6, 7, 8], +//! vec![ 1, 2, 3, 4, 5, 6, 7, 8], +//! // ↓ Second element +//! vec![-1, 0, 3, 4, 5, 6, 7, 8], +//! vec![-1, 1, 3, 4, 5, 6, 7, 8], +//! // ↓ Third element +//! vec![-1, 2, 0, 4, 5, 6, 7, 8], +//! // And further ... +//! ] +//! }; +//! ``` use crate::BoxIter; use crate::BoxShrink; use crate::Shrink; -/// Default vector shrinker +/// Default vector shrinker. pub fn default( element_shrinker: BoxShrink, ) -> BoxShrink> { Box::new(VecShrink:: { element_shrinker }) } -/// Default vector shrinker +/// Shrinker that only tries to reduce the vector size, not trying to shrink +/// individual elements. pub fn no_element_shrinkning() -> BoxShrink> { Box::new(VecShrink:: { element_shrinker: crate::shrink::none(),