s2n_codec/encoder/
estimator.rsuse crate::encoder::Encoder;
#[cfg_attr(test, derive(Clone, Debug, bolero::TypeGenerator))]
pub struct EncoderLenEstimator {
capacity: usize,
len: usize,
}
impl EncoderLenEstimator {
#[inline]
pub const fn new(capacity: usize) -> Self {
Self { capacity, len: 0 }
}
#[inline]
pub const fn overflowed(&self) -> bool {
self.len > self.capacity
}
}
impl Encoder for EncoderLenEstimator {
#[inline]
fn write_sized<F: FnOnce(&mut [u8])>(&mut self, len: usize, _write: F) {
self.len += len;
}
#[inline]
fn write_slice(&mut self, slice: &[u8]) {
self.len += slice.len();
}
#[inline]
fn write_repeated(&mut self, count: usize, _value: u8) {
self.len += count;
}
#[inline]
fn write_zerocopy<T: zerocopy::FromBytes + zerocopy::Unaligned, F: FnOnce(&mut T)>(
&mut self,
_write: F,
) {
self.len += core::mem::size_of::<T>();
}
#[inline]
fn capacity(&self) -> usize {
self.capacity
}
#[inline]
fn len(&self) -> usize {
self.len
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
#[cfg_attr(kani, kani::proof)]
fn encoder_len_estimator_new() {
bolero::check!()
.with_type()
.cloned()
.for_each(|capacity: usize| Some(EncoderLenEstimator::new(capacity)));
}
#[test]
#[cfg_attr(kani, kani::proof)]
fn encoder_len_estimator_overflowed() {
bolero::check!()
.with_type()
.for_each(|callee: &EncoderLenEstimator| Some(callee.overflowed()));
}
#[test]
#[cfg_attr(kani, kani::proof)]
fn encoder_len_estimator_write_repeated() {
bolero::check!()
.with_type()
.cloned()
.filter(|(callee, count, _): &(EncoderLenEstimator, usize, u8)| {
count <= &(usize::MAX - callee.len)
})
.for_each(
|(mut callee, count, value): (EncoderLenEstimator, usize, u8)| {
callee.write_repeated(count, value);
Some(())
},
);
}
#[test]
#[cfg_attr(kani, kani::proof)]
fn encoder_len_estimator_capacity() {
bolero::check!()
.with_type()
.for_each(|callee: &EncoderLenEstimator| Some(callee.capacity()));
}
#[test]
#[cfg_attr(kani, kani::proof)]
fn encoder_len_estimator_len() {
bolero::check!()
.with_type()
.for_each(|callee: &EncoderLenEstimator| Some(callee.len()));
}
}