2022-07-14 10:03:08 +00:00
|
|
|
// mac-os `getrandom_1` does some pointer shenanigans
|
|
|
|
//@compile-flags: -Zmiri-permissive-provenance
|
2022-07-22 20:53:20 -04:00
|
|
|
use rand::{rngs::SmallRng, Rng, SeedableRng};
|
2022-07-14 10:03:08 +00:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
// Test `getrandom` directly (in multiple different versions).
|
|
|
|
let mut data = vec![0; 16];
|
|
|
|
getrandom_1::getrandom(&mut data).unwrap();
|
|
|
|
getrandom_2::getrandom(&mut data).unwrap();
|
|
|
|
|
|
|
|
// Try seeding with "real" entropy.
|
|
|
|
let mut rng = SmallRng::from_entropy();
|
|
|
|
let _val = rng.gen::<i32>();
|
|
|
|
let _val = rng.gen::<isize>();
|
|
|
|
let _val = rng.gen::<i128>();
|
|
|
|
|
|
|
|
// Also try per-thread RNG.
|
|
|
|
let mut rng = rand::thread_rng();
|
|
|
|
let _val = rng.gen::<i32>();
|
|
|
|
let _val = rng.gen::<isize>();
|
|
|
|
let _val = rng.gen::<i128>();
|
|
|
|
}
|