use crate::err::{ip, LenError};
#[derive(Clone, Debug, Eq, PartialEq, Hash)]
pub enum SliceError {
Len(LenError),
IpHeaders(ip::HeadersError),
}
impl core::fmt::Display for SliceError {
fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
use SliceError::*;
match self {
Len(err) => err.fmt(f),
IpHeaders(err) => err.fmt(f),
}
}
}
impl core::error::Error for SliceError {
fn source(&self) -> Option<&(dyn core::error::Error + 'static)> {
use SliceError::*;
match self {
Len(err) => Some(err),
IpHeaders(err) => Some(err),
}
}
}
#[cfg(test)]
mod tests {
use super::{
super::{HeaderError::*, HeadersError::*},
SliceError::*,
};
use crate::{
err::{Layer, LenError},
LenSource,
};
use alloc::format;
use std::{
collections::hash_map::DefaultHasher,
error::Error,
hash::{Hash, Hasher},
};
#[test]
fn debug() {
let err = Ip(UnsupportedIpVersion { version_number: 6 });
assert_eq!(
format!("IpHeaders({:?})", err.clone()),
format!("{:?}", IpHeaders(err))
);
}
#[test]
fn clone_eq_hash() {
let err = IpHeaders(Ip(UnsupportedIpVersion { version_number: 6 }));
assert_eq!(err, err.clone());
let hash_a = {
let mut hasher = DefaultHasher::new();
err.hash(&mut hasher);
hasher.finish()
};
let hash_b = {
let mut hasher = DefaultHasher::new();
err.clone().hash(&mut hasher);
hasher.finish()
};
assert_eq!(hash_a, hash_b);
}
#[test]
fn fmt() {
{
let err = LenError {
required_len: 1,
layer: Layer::Ipv4Packet,
len: 2,
len_source: LenSource::Slice,
layer_start_offset: 3,
};
assert_eq!(format!("{}", &err), format!("{}", Len(err)));
}
{
let err = Ip(UnsupportedIpVersion { version_number: 6 });
assert_eq!(format!("{}", &err), format!("{}", IpHeaders(err.clone())));
}
}
#[cfg(feature = "std")]
#[test]
fn source() {
assert!(Len(LenError {
required_len: 1,
layer: Layer::Ipv4Packet,
len: 2,
len_source: LenSource::Slice,
layer_start_offset: 3
})
.source()
.is_some());
assert!(IpHeaders(Ip(UnsupportedIpVersion { version_number: 6 }))
.source()
.is_some());
}
}