2019-10-16 20:33:55 +02:00
|
|
|
use std::mem::MaybeUninit;
|
2019-11-30 04:30:49 +01:00
|
|
|
use std::ptr::NonNull;
|
2019-10-16 20:33:55 +02:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn unitialized_zero_size_box() {
|
|
|
|
assert_eq!(
|
|
|
|
&*Box::<()>::new_uninit() as *const _,
|
|
|
|
NonNull::<MaybeUninit<()>>::dangling().as_ptr(),
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
Box::<[()]>::new_uninit_slice(4).as_ptr(),
|
|
|
|
NonNull::<MaybeUninit<()>>::dangling().as_ptr(),
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
Box::<[String]>::new_uninit_slice(0).as_ptr(),
|
|
|
|
NonNull::<MaybeUninit<String>>::dangling().as_ptr(),
|
|
|
|
);
|
|
|
|
}
|
2020-05-23 17:51:02 +02:00
|
|
|
|
|
|
|
#[derive(Clone, PartialEq, Eq, Debug)]
|
|
|
|
struct Dummy {
|
|
|
|
_data: u8,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn box_clone_and_clone_from_equivalence() {
|
|
|
|
for size in (0..8).map(|i| 2usize.pow(i)) {
|
|
|
|
let control = vec![Dummy { _data: 42 }; size].into_boxed_slice();
|
|
|
|
let clone = control.clone();
|
|
|
|
let mut copy = vec![Dummy { _data: 84 }; size].into_boxed_slice();
|
|
|
|
copy.clone_from(&control);
|
|
|
|
assert_eq!(control, clone);
|
|
|
|
assert_eq!(control, copy);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-29 12:18:15 +02:00
|
|
|
/// This test might give a false positive in case the box realocates, but the alocator keeps the
|
|
|
|
/// original pointer.
|
|
|
|
///
|
2020-08-02 17:20:00 +02:00
|
|
|
/// On the other hand it won't give a false negative, if it fails than the memory was definitely not
|
2020-05-29 12:18:15 +02:00
|
|
|
/// reused
|
2020-05-23 17:51:02 +02:00
|
|
|
#[test]
|
|
|
|
fn box_clone_from_ptr_stability() {
|
|
|
|
for size in (0..8).map(|i| 2usize.pow(i)) {
|
|
|
|
let control = vec![Dummy { _data: 42 }; size].into_boxed_slice();
|
|
|
|
let mut copy = vec![Dummy { _data: 84 }; size].into_boxed_slice();
|
|
|
|
let copy_raw = copy.as_ptr() as usize;
|
|
|
|
copy.clone_from(&control);
|
|
|
|
assert_eq!(copy.as_ptr() as usize, copy_raw);
|
|
|
|
}
|
|
|
|
}
|