use core::num::NonZeroU16;
use static_alloc::{Slab, slab};
#[test]
fn homogeneous() {
let slab = Slab::<[u64; 3]>::uninit();
let new_zero = slab.leak(0_u64).unwrap();
assert_eq!(*new_zero, 0);
let next = slab.leak(255_u64).unwrap();
assert_eq!(*next, 255);
assert_eq!(*new_zero, 0);
let last = slab.leak(u64::max_value()).unwrap();
assert_eq!(*next, 255);
assert_eq!(*new_zero, 0);
assert_eq!(*last, u64::max_value());
assert!(slab.leak(0_u8).is_err());
}
#[test]
fn heterogeneous() {
let slab = Slab::<[u16; 3]>::uninit();
let intu16: &mut u16 = slab.leak(0).unwrap();
assert_eq!(*intu16, 0);
let option: &mut Option<u8> = slab.leak(Some(0_u8)).unwrap();
assert_eq!(*option, Some(0));
let nonzero: &mut Option<NonZeroU16> = slab.leak(None).unwrap();
assert_eq!(*nonzero, None);
assert!(slab.leak(0_u8).is_err());
}
#[test]
fn zst() {
let slab = Slab::<()>::uninit();
slab.leak::<()>(())
.expect("Could 'allocate' zst in no space");
}
#[test]
fn level() {
let slab = Slab::<[u16; 2]>::uninit();
let init = slab.level();
let (intu16, level) = slab.leak_at(0u16, init).unwrap();
assert_eq!(*intu16, 0);
assert!(init < level);
assert_eq!(slab.level(), level);
assert_eq!(slab.leak_at(0u16, init).unwrap_err().kind(),
slab::Failure::Mismatch { observed: level });
let (othu16, next) = slab.leak_at(10u16, level).unwrap();
assert_eq!(*othu16, 10);
assert!(init < next);
assert!(level < next);
assert_eq!(slab.level(), next);
}