use etherparse::*;
use super::*;
#[test]
fn eth_ipv4_udp() {
let in_payload = [24,25,26,27];
let mut serialized = Vec::new();
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv4([13,14,15,16], [17,18,19,20], 21)
.udp(22,23)
.write(&mut serialized, &in_payload)
.unwrap();
let expected_ip_size: usize = UdpHeader::SERIALIZED_SIZE +
in_payload.len();
assert_eq!(expected_ip_size
+ Ethernet2Header::SERIALIZED_SIZE
+ Ipv4Header::SERIALIZED_SIZE,
serialized.len());
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::Ipv4 as u16
});
let ip_actual = Ipv4Header::read(&mut cursor).unwrap();
let mut ip_expected = Ipv4Header::new(
expected_ip_size as u16,
21, IpTrafficClass::Udp,
[13,14,15,16],
[17,18,19,20]
);
ip_expected.header_checksum = ip_expected.calc_header_checksum().unwrap();
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv4_checksum(22, 23, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn ipv4_udp() {
let in_payload = [24,25,26,27];
let mut serialized = Vec::new();
PacketBuilder::ipv4([13,14,15,16], [17,18,19,20], 21)
.udp(22,23)
.write(&mut serialized, &in_payload)
.unwrap();
let expected_ip_size: usize = UdpHeader::SERIALIZED_SIZE +
in_payload.len();
assert_eq!(expected_ip_size
+ Ipv4Header::SERIALIZED_SIZE,
serialized.len());
use std::io::{Cursor, Read};
let mut cursor = Cursor::new(&serialized);
let ip_actual = Ipv4Header::read(&mut cursor).unwrap();
let mut ip_expected = Ipv4Header::new(
expected_ip_size as u16,
21, IpTrafficClass::Udp,
[13,14,15,16],
[17,18,19,20]
);
ip_expected.header_checksum = ip_expected.calc_header_checksum().unwrap();
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv4_checksum(22, 23, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn ipv6_udp() {
let in_payload = [24,25,26,27];
let mut serialized = Vec::new();
PacketBuilder::
ipv6(
[11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
[31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46],
47)
.udp(22,23)
.write(&mut serialized, &in_payload)
.unwrap();
let expected_ip_size: usize = UdpHeader::SERIALIZED_SIZE +
in_payload.len();
assert_eq!(expected_ip_size
+ Ipv6Header::SERIALIZED_SIZE,
serialized.len());
use std::io::{Cursor, Read};
let mut cursor = Cursor::new(&serialized);
let ip_actual = Ipv6Header::read(&mut cursor).unwrap();
let ip_expected = Ipv6Header{
traffic_class: 0,
flow_label: 0,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
};
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv6_checksum(22, 23, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn ipv_custom_udp() {
let in_payload = [24,25,26,27];
let mut serialized = Vec::new();
PacketBuilder::
ip(IpHeader::Version4(Ipv4Header::new(
0, 12, IpTrafficClass::Tcp, [13,14,15,16], [17,18,19,20] )))
.udp(22,23)
.write(&mut serialized, &in_payload)
.unwrap();
let expected_ip_size: usize = UdpHeader::SERIALIZED_SIZE +
in_payload.len();
assert_eq!(expected_ip_size
+ Ipv4Header::SERIALIZED_SIZE,
serialized.len());
use std::io::{Cursor, Read};
let mut cursor = Cursor::new(&serialized);
let ip_actual = Ipv4Header::read(&mut cursor).unwrap();
let mut ip_expected = Ipv4Header::new(
expected_ip_size as u16,
12, IpTrafficClass::Udp,
[13,14,15,16],
[17,18,19,20]
);
ip_expected.header_checksum = ip_expected.calc_header_checksum().unwrap();
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv4_checksum(22, 23, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn udp_builder_eth_ipv6_udp() {
let in_payload = [50,51,52,53];
let mut serialized = Vec::new();
PacketBuilder::ethernet2([1,2,3,4,5,6], [7,8,9,10,11,12])
.ipv6([11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
[31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46],
47)
.udp(48,49)
.write(&mut serialized, &in_payload)
.unwrap();
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
Ipv6Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
in_payload.len(),
serialized.len());
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::Ipv6 as u16
});
let ip_actual = Ipv6Header::read(&mut cursor).unwrap();
let ip_expected = Ipv6Header{
traffic_class: 0,
flow_label: 0,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
};
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv6_checksum(48, 49, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn udp_builder_eth_single_vlan_ipv4_udp() {
let in_payload = [50,51,52,53];
let mut serialized = Vec::new();
PacketBuilder::ethernet2([1,2,3,4,5,6], [7,8,9,10,11,12])
.single_vlan(0x123)
.ipv4([13,14,15,16], [17,18,19,20], 21)
.udp(48,49)
.write(&mut serialized, &in_payload)
.unwrap();
let expected_ip_size: usize = UdpHeader::SERIALIZED_SIZE +
in_payload.len();
assert_eq!(expected_ip_size + Ethernet2Header::SERIALIZED_SIZE
+ Ipv4Header::SERIALIZED_SIZE
+ SingleVlanHeader::SERIALIZED_SIZE,
serialized.len());
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::VlanTaggedFrame as u16
});
assert_eq!(SingleVlanHeader::read(&mut cursor).unwrap(),
SingleVlanHeader{
priority_code_point: 0,
drop_eligible_indicator: false,
vlan_identifier: 0x123,
ether_type: EtherType::Ipv4 as u16
});
let ip_actual = Ipv4Header::read(&mut cursor).unwrap();
let mut ip_expected = Ipv4Header::new(
expected_ip_size as u16, 21, IpTrafficClass::Udp,
[13,14,15,16],
[17,18,19,20]
);
ip_expected.header_checksum = ip_expected.calc_header_checksum().unwrap();
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv4_checksum(48, 49, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn udp_builder_eth_double_vlan_ipv6_udp() {
let in_payload = [50,51,52,53];
let mut serialized = Vec::new();
PacketBuilder::ethernet2([1,2,3,4,5,6], [7,8,9,10,11,12])
.double_vlan(0x123, 0x234)
.ipv6([11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
[31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46],
47)
.udp(48,49)
.write(&mut serialized, &in_payload)
.unwrap();
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
DoubleVlanHeader::SERIALIZED_SIZE +
Ipv6Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
in_payload.len(),
serialized.len());
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::ProviderBridging as u16
});
assert_eq!(SingleVlanHeader::read(&mut cursor).unwrap(),
SingleVlanHeader{
priority_code_point: 0,
drop_eligible_indicator: false,
vlan_identifier: 0x123,
ether_type: EtherType::VlanTaggedFrame as u16
});
assert_eq!(SingleVlanHeader::read(&mut cursor).unwrap(),
SingleVlanHeader{
priority_code_point: 0,
drop_eligible_indicator: false,
vlan_identifier: 0x234,
ether_type: EtherType::Ipv6 as u16
});
let ip_actual = Ipv6Header::read(&mut cursor).unwrap();
let ip_expected = Ipv6Header{
traffic_class: 0,
flow_label: 0,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
};
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv6_checksum(48, 49, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn udp_builder_eth_ip_udp() {
let in_payload = [50,51,52,53];
let mut serialized = Vec::new();
PacketBuilder::ethernet2([1,2,3,4,5,6], [7,8,9,10,11,12])
.ip(IpHeader::Version6(Ipv6Header{
traffic_class: 1,
flow_label: 2,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
}))
.udp(48,49)
.write(&mut serialized, &in_payload)
.unwrap();
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
Ipv6Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
in_payload.len(),
serialized.len());
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::Ipv6 as u16
});
let ip_actual = Ipv6Header::read(&mut cursor).unwrap();
let ip_expected = Ipv6Header{
traffic_class: 1,
flow_label: 2,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
};
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv6_checksum(48, 49, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
#[test]
fn udp_builder_eth_vlan_ip_udp() {
let in_payload = [50,51,52,53];
let mut serialized = Vec::new();
PacketBuilder::ethernet2([1,2,3,4,5,6], [7,8,9,10,11,12])
.vlan(VlanHeader::Single(SingleVlanHeader{
priority_code_point: 1,
drop_eligible_indicator: true,
vlan_identifier: 0x123,
ether_type: 0 }))
.ip(IpHeader::Version6(Ipv6Header{
traffic_class: 1,
flow_label: 2,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
}))
.udp(48,49)
.write(&mut serialized, &in_payload)
.unwrap();
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
SingleVlanHeader::SERIALIZED_SIZE +
Ipv6Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
in_payload.len(),
serialized.len());
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::VlanTaggedFrame as u16
});
assert_eq!(SingleVlanHeader::read(&mut cursor).unwrap(),
SingleVlanHeader{
priority_code_point: 1,
drop_eligible_indicator: true,
vlan_identifier: 0x123,
ether_type: EtherType::Ipv6 as u16
});
let ip_actual = Ipv6Header::read(&mut cursor).unwrap();
let ip_expected = Ipv6Header{
traffic_class: 1,
flow_label: 2,
payload_length: (UdpHeader::SERIALIZED_SIZE + in_payload.len()) as u16,
next_header: IpTrafficClass::Udp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
};
assert_eq!(ip_actual,
ip_expected);
let udp_actual = UdpHeader::read(&mut cursor).unwrap();
let udp_expected = UdpHeader::with_ipv6_checksum(48, 49, &ip_expected, &in_payload).unwrap();
assert_eq!(udp_actual,
udp_expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
proptest! {
#[test]
fn tcp_ipv4(ref input in tcp_any()) {
let in_payload = [24,25,26,27];
let mut ip_expected = Ipv4Header::new(
in_payload.len() as u16 + input.header_len(),
21, IpTrafficClass::Tcp,
[13,14,15,16],
[17,18,19,20]
);
ip_expected.header_checksum = ip_expected.calc_header_checksum().unwrap();
let expected = {
let mut expected = input.clone();
if !expected.ack {
expected.acknowledgment_number = 0;
}
if !expected.urg {
expected.urgent_pointer = 0;
}
expected.checksum = expected.calc_checksum_ipv4(&ip_expected, &in_payload[..]).unwrap();
expected
};
let serialized = {
let mut builder = PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv4([13,14,15,16], [17,18,19,20], 21)
.tcp(input.source_port,
input.destination_port,
input.sequence_number,
input.window_size)
.options_raw(input.options()).unwrap();
if input.ns {
builder = builder.ns();
}
if input.fin {
builder = builder.fin();
}
if input.syn {
builder = builder.syn();
}
if input.rst {
builder = builder.rst();
}
if input.psh {
builder = builder.psh();
}
if input.ack {
builder = builder.ack(input.acknowledgment_number);
}
if input.urg {
builder = builder.urg(input.urgent_pointer);
}
if input.ece {
builder = builder.ece();
}
if input.cwr {
builder = builder.cwr();
}
let mut serialized = Vec::new();
builder.write(&mut serialized, &in_payload).unwrap();
serialized
};
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::Ipv4 as u16
});
let ip_actual = Ipv4Header::read(&mut cursor).unwrap();
assert_eq!(ip_actual,
ip_expected);
assert_eq!(TcpHeader::read(&mut cursor).unwrap(),
expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
}
proptest! {
#[test]
fn tcp_ipv6(ref input in tcp_any()) {
let in_payload = [24,25,26,27];
let ip_expected = Ipv6Header{
traffic_class: 0,
flow_label: 0,
payload_length: (input.header_len() as usize + in_payload.len()) as u16,
next_header: IpTrafficClass::Tcp as u8,
hop_limit: 47,
source: [11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
destination: [31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46]
};
let expected = {
let mut expected = input.clone();
if !expected.ack {
expected.acknowledgment_number = 0;
}
if !expected.urg {
expected.urgent_pointer = 0;
}
expected.checksum = expected.calc_checksum_ipv6(&ip_expected, &in_payload[..]).unwrap();
expected
};
let serialized = {
let mut builder = PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv6([11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
[31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46],
47)
.tcp(input.source_port,
input.destination_port,
input.sequence_number,
input.window_size)
.options_raw(input.options()).unwrap();
if input.ns {
builder = builder.ns();
}
if input.fin {
builder = builder.fin();
}
if input.syn {
builder = builder.syn();
}
if input.rst {
builder = builder.rst();
}
if input.psh {
builder = builder.psh();
}
if input.ack {
builder = builder.ack(input.acknowledgment_number);
}
if input.urg {
builder = builder.urg(input.urgent_pointer);
}
if input.ece {
builder = builder.ece();
}
if input.cwr {
builder = builder.cwr();
}
let mut serialized = Vec::new();
builder.write(&mut serialized, &in_payload).unwrap();
serialized
};
use std::io::Cursor;
use std::io::Read;
let mut cursor = Cursor::new(&serialized);
assert_eq!(Ethernet2Header::read(&mut cursor).unwrap(),
Ethernet2Header{
source: [1,2,3,4,5,6],
destination: [7,8,9,10,11,12],
ether_type: EtherType::Ipv6 as u16
});
let ip_actual = Ipv6Header::read(&mut cursor).unwrap();
assert_eq!(ip_actual,
ip_expected);
assert_eq!(TcpHeader::read(&mut cursor).unwrap(),
expected);
let mut actual_payload: [u8;4] = [0;4];
cursor.read_exact(&mut actual_payload).unwrap();
assert_eq!(actual_payload, in_payload);
}
}
#[test]
fn tcp_options() {
let mut serialized = Vec::new();
use crate::TcpOptionElement::*;
let options = vec![MaximumSegmentSize(1234), Nop];
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv4([13,14,15,16], [17,18,19,20], 21)
.tcp(1,
2,
3,
4)
.options(&options).unwrap()
.write(&mut serialized, &[]).unwrap();
let decoded = PacketHeaders::from_ethernet_slice(&serialized[..]).unwrap();
let dec_options: Vec<Result<TcpOptionElement, TcpOptionReadError>> = decoded.transport.unwrap().tcp().unwrap().options_iterator().collect();
assert_eq!(
&[Ok(MaximumSegmentSize(1234)), Ok(Nop)],
&dec_options[..]
);
}
#[test]
fn size() {
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
Ipv4Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
123,
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv4([13,14,15,16], [17,18,19,20], 21)
.udp(22,23)
.size(123));
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
Ipv6Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
123,
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv6([11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
[31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46],
47)
.udp(22,23)
.size(123));
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
SingleVlanHeader::SERIALIZED_SIZE +
Ipv4Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
123,
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.single_vlan(0x123)
.ipv4([13,14,15,16], [17,18,19,20], 21)
.udp(22,23)
.size(123));
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
DoubleVlanHeader::SERIALIZED_SIZE +
Ipv6Header::SERIALIZED_SIZE +
UdpHeader::SERIALIZED_SIZE +
123,
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.double_vlan(0x123, 0x234)
.ipv6([11,12,13,14,15,16,17,18,19,10,21,22,23,24,25,26],
[31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46],
47)
.udp(22,23)
.size(123));
}
proptest! {
#[test]
fn size_tcp(ref input in tcp_any()) {
assert_eq!(Ethernet2Header::SERIALIZED_SIZE +
Ipv4Header::SERIALIZED_SIZE +
input.header_len() as usize +
123,
PacketBuilder::ethernet2([1,2,3,4,5,6],[7,8,9,10,11,12])
.ipv4([13,14,15,16], [17,18,19,20], 21)
.tcp(input.source_port,
input.destination_port,
input.sequence_number,
input.window_size)
.options_raw(input.options()).unwrap()
.size(123));
}
}