[][src]Struct proptest::test_runner::TestRng

pub struct TestRng { /* fields omitted */ }

Proptest's random number generator.

Methods

impl TestRng[src]

pub fn from_seed(algorithm: RngAlgorithm, seed: &[u8]) -> Self[src]

Create a new RNG with the given algorithm and seed.

Any RNG created with the same algorithm-seed pair will produce the same sequence of values on all systems and all supporting versions of proptest.

Panics

Panics if seed is not an appropriate length for algorithm.

pub fn deterministic_rng(algorithm: RngAlgorithm) -> Self[src]

Returns a TestRng with a particular hard-coded seed.

The seed value will always be the same for a particular version of Proptest and algorithm, but may change across releases.

This is useful for testing things like strategy implementations without risking getting "unlucky" RNGs which deviate from average behaviour enough to cause spurious failures. For example, a strategy for bool which is supposed to produce true 50% of the time might have a test which checks that the distribution is "close enough" to 50%. If every test run starts with a different RNG, occasionally there will be spurious test failures when the RNG happens to produce a very skewed distribution. Using this or TestRunner::deterministic() avoids such issues.

Trait Implementations

impl Clone for TestRng[src]

fn clone_from(&mut self, source: &Self)
1.0.0
[src]

Performs copy-assignment from source. Read more

impl Debug for TestRng[src]

impl RngCore for TestRng[src]

Auto Trait Implementations

impl Send for TestRng

impl Sync for TestRng

Blanket Implementations

impl<T> From for T[src]

impl<T, U> TryFrom for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T, U> Into for T where
    U: From<T>, 
[src]

impl<T> Borrow for T where
    T: ?Sized
[src]

impl<T> BorrowMut for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

impl<R> Rng for R where
    R: RngCore + ?Sized
[src]

fn gen<T>(&mut self) -> T where
    Standard: Distribution<T>, 
[src]

Return a random value supporting the [Standard] distribution. Read more

fn gen_range<T, B1, B2>(&mut self, low: B1, high: B2) -> T where
    B1: SampleBorrow<T>,
    B2: SampleBorrow<T>,
    T: SampleUniform
[src]

Generate a random value in the range [low, high), i.e. inclusive of low and exclusive of high. Read more

fn sample<T, D>(&mut self, distr: D) -> T where
    D: Distribution<T>, 
[src]

Sample a new value, using the given distribution. Read more

fn sample_iter<T, D>(&'a mut self, distr: &'a D) -> DistIter<'a, D, Self, T> where
    D: Distribution<T>, 
[src]

Create an iterator that generates values using the given distribution. Read more

fn fill<T>(&mut self, dest: &mut T) where
    T: AsByteSliceMut + ?Sized
[src]

Fill dest entirely with random bytes (uniform value distribution), where dest is any type supporting [AsByteSliceMut], namely slices and arrays over primitive integer types (i8, i16, u32, etc.). Read more

fn try_fill<T>(&mut self, dest: &mut T) -> Result<(), Error> where
    T: AsByteSliceMut + ?Sized
[src]

Fill dest entirely with random bytes (uniform value distribution), where dest is any type supporting [AsByteSliceMut], namely slices and arrays over primitive integer types (i8, i16, u32, etc.). Read more

fn gen_bool(&mut self, p: f64) -> bool[src]

Return a bool with a probability p of being true. Read more

fn gen_ratio(&mut self, numerator: u32, denominator: u32) -> bool[src]

Return a bool with a probability of numerator/denominator of being true. I.e. gen_ratio(2, 3) has chance of 2 in 3, or about 67%, of returning true. If numerator == denominator, then the returned value is guaranteed to be true. If numerator == 0, then the returned value is guaranteed to be false. Read more

fn choose<T>(&mut self, values: &'a [T]) -> Option<&'a T>[src]

Deprecated since 0.6.0:

use SliceRandom::choose instead

Return a random element from values. Read more

fn choose_mut<T>(&mut self, values: &'a mut [T]) -> Option<&'a mut T>[src]

Deprecated since 0.6.0:

use SliceRandom::choose_mut instead

Return a mutable pointer to a random element from values. Read more

fn shuffle<T>(&mut self, values: &mut [T])[src]

Deprecated since 0.6.0:

use SliceRandom::shuffle instead

Shuffle a mutable slice in place. Read more