pub struct Index(/* private fields */);
Expand description
A stand-in for an index into a slice or similar collection or conceptually similar things.
At the lowest level, Index
is a mechanism for generating usize
values
in the range [0..N), for some N whose value is not known until it is
needed. (Contrast with using 0..N
itself as a strategy, where you need to
know N when you define the strategy.)
For any upper bound, the actual index produced by an Index
is the same no
matter how many times it is used. Different upper bounds will produce
different but not independent values.
Shrinking will cause the index to binary search through the underlying collection(s) it is used to sample.
Note that Index
cannot currently be used as a slice index (e.g.,
slice[index]
) due to the trait coherence rules.
§Example
If the collection itself being indexed is itself generated by a strategy,
you can make separately define that strategy and a strategy generating one
or more Index
es and then join the two after input generation, avoiding a
call to prop_flat_map()
.
use proptest::prelude::*;
proptest! {
#[test]
fn my_test(
names in prop::collection::vec("[a-z]+", 10..20),
indices in prop::collection::vec(any::<prop::sample::Index>(), 5..10)
) {
// We now have Vec<String> of ten to twenty names, and a Vec<Index>
// of five to ten indices and can combine them however we like.
for index in &indices {
println!("Accessing item by index: {}", names[index.index(names.len())]);
println!("Accessing item by convenience method: {}", index.get(&names));
}
// Test stuff...
}
}
Implementations§
Source§impl Index
impl Index
Sourcepub fn index(&self, size: usize) -> usize
pub fn index(&self, size: usize) -> usize
Return the real index that would be used to index a collection of size size
.
§Panics
Panics if size == 0
.
Trait Implementations§
Source§impl Arbitrary for Index
impl Arbitrary for Index
Source§type Parameters = ()
type Parameters = ()
arbitrary_with
accepts for configuration
of the generated Strategy
. Parameters must implement Default
.Source§type Strategy = IndexStrategy
type Strategy = IndexStrategy
Strategy
used to generate values of type Self
.Source§fn arbitrary_with(_: ()) -> IndexStrategy
fn arbitrary_with(_: ()) -> IndexStrategy
impl Copy for Index
Auto Trait Implementations§
impl Freeze for Index
impl RefUnwindSafe for Index
impl Send for Index
impl Sync for Index
impl Unpin for Index
impl UnwindSafe for Index
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)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: 8 bytes