TEST_F(EthernetIITest, CompleteConstructor) { EthernetII eth2; EthernetII eth = EthernetII(dst_addr, src_addr) / eth2; EXPECT_EQ(eth.dst_addr(), dst_addr); EXPECT_EQ(eth.src_addr(), src_addr); EXPECT_EQ(eth.payload_type(), 0); }
// Make sure that a big payload is not considered ICMP extensions TEST_F(IPv6Test, BigEncapsulatedPacketIsNotConsideredToHaveExtensions) { IPv6 encapsulated = IPv6(TINS_DEFAULT_TEST_IP) / UDP(99, 12) / RawPDU(std::string(250, 'A')); EthernetII pkt = EthernetII() / IPv6() / ICMPv6(ICMPv6::TIME_EXCEEDED) / encapsulated; PDU::serialization_type buffer = pkt.serialize(); EthernetII serialized(&buffer[0], buffer.size()); ASSERT_EQ(encapsulated.size(), serialized.rfind_pdu<RawPDU>().payload().size()); ASSERT_TRUE(serialized.rfind_pdu<ICMPv6>().extensions().extensions().empty()); }
TEST_F(EthernetIITest, SerializePreservesGivenPayloadType) { EthernetII eth; uint32_t payload_size = 100; uint8_t payload[100] = {0}; eth /= RawPDU(payload, payload_size); eth.payload_type(p_type); eth.serialize(); EXPECT_EQ(p_type, eth.payload_type()); }
TEST_F(Dot1QTest, SerializeCraftedPacket) { EthernetII pkt = EthernetII() / Dot1Q(10) / IP("192.168.1.2") / TCP(23, 45) / RawPDU("asdasdasd"); PDU::serialization_type buffer = pkt.serialize(); EXPECT_EQ(buffer[12], 0x81); EXPECT_EQ(buffer[13], 0x00); EthernetII pkt2(&buffer[0], buffer.size()); const Dot1Q &q1 = pkt2.rfind_pdu<Dot1Q>(); EXPECT_EQ(10, q1.id()); }
TEST_F(PPPoETest, StackedOnEthernetSerializationWithTags) { PPPoE pdu(expected_packet, sizeof(expected_packet)); EthernetII eth = EthernetII() / pdu; PDU::serialization_type buffer = eth.serialize(); EthernetII eth2(&buffer[0], (uint32_t)buffer.size()); PPPoE* unserialized = eth2.find_pdu<PPPoE>(); ASSERT_TRUE(unserialized != NULL); EXPECT_EQ( PPPoE::serialization_type(expected_packet, expected_packet + sizeof(expected_packet)), unserialized->serialize() ); }
// Use a large buffer. This wil set the length field TEST_F(IPv6Test, SerializePacketHavingICMPExtensionsWithLengthAndLotsOfPayload) { IPv6 encapsulated = IPv6(TINS_DEFAULT_TEST_IP) / UDP(99, 12) / RawPDU(std::string(250, 'A')); EthernetII pkt = EthernetII() / IPv6() / ICMPv6(ICMPv6::TIME_EXCEEDED) / encapsulated; const uint8_t payload[] = { 24, 150, 1, 1 }; ICMPExtension extension(1, 1); ICMPExtension::payload_type ext_payload(payload, payload + sizeof(payload)); extension.payload(ext_payload); pkt.rfind_pdu<ICMPv6>().extensions().add_extension(extension); PDU::serialization_type buffer = pkt.serialize(); EthernetII serialized(&buffer[0], buffer.size()); ASSERT_EQ(1, serialized.rfind_pdu<ICMPv6>().extensions().extensions().size()); EXPECT_EQ(ext_payload, serialized.rfind_pdu<ICMPv6>().extensions().extensions().begin()->payload()); }
bool callback(const PDU &pdu) { // The packet probably looks like this: // // EthernetII / IP / UDP / RawPDU // // So we retrieve each layer, and construct a // DNS PDU from the RawPDU layer contents. EthernetII eth = pdu.rfind_pdu<EthernetII>(); IP ip = eth.rfind_pdu<IP>(); UDP udp = ip.rfind_pdu<UDP>(); DNS dns = udp.rfind_pdu<RawPDU>().to<DNS>(); // Is it a DNS query? if(dns.type() == DNS::QUERY) { // Let's see if there's any query for an "A" record. for(const auto &query : dns.queries()) { if(query.type() == DNS::A) { // Here's one! Let's add an answer. dns.add_answer( DNS::Resource( query.dname(), "127.0.0.1", DNS::A, query.query_class(), // 777 is just a random TTL 777 ) ); } } // Have we added some answers? if(dns.answers_count() > 0) { // It's a response now dns.type(DNS::RESPONSE); // Recursion is available(just in case) dns.recursion_available(1); // Build our packet auto pkt = EthernetII(eth.src_addr(), eth.dst_addr()) / IP(ip.src_addr(), ip.dst_addr()) / UDP(udp.sport(), udp.dport()) / dns; // Send it! sender.send(pkt); } } return true; }
TEST_F(Dot1QTest, QinQ) { EthernetII pkt = EthernetII() / Dot1Q(10) / Dot1Q(42) / IP("192.168.1.2") / TCP(23, 45) / RawPDU("asdasdasd"); PDU::serialization_type buffer = pkt.serialize(); // First PID of the serialized packet should be Dot1AD = 0x88a8 EXPECT_EQ(buffer[12], 0x88); EXPECT_EQ(buffer[13], 0xa8); // Second PID of the serialized packet chouls be Dot1Q = 0x8100 EXPECT_EQ(buffer[16], 0x81); EXPECT_EQ(buffer[17], 0x00); EthernetII pkt2(&buffer[0], buffer.size()); const Dot1Q& q1 = pkt2.rfind_pdu<Dot1Q>(); ASSERT_TRUE(q1.inner_pdu() != NULL); const Dot1Q& q2 = q1.inner_pdu()->rfind_pdu<Dot1Q>(); EXPECT_EQ(10, q1.id()); EXPECT_EQ(42, q2.id()); }
TEST_F(EthernetIITest, DefaultConstructor) { EthernetII eth; EXPECT_EQ(eth.dst_addr(), empty_addr); EXPECT_EQ(eth.src_addr(), empty_addr); EXPECT_EQ(eth.payload_type(), 0); EXPECT_FALSE(eth.inner_pdu()); EXPECT_EQ(eth.pdu_type(), PDU::ETHERNET_II); }
TEST_F(PPPoETest, StackedOnEthernet) { EthernetII eth = EthernetII() / PPPoE(); PDU::serialization_type buffer = eth.serialize(); EthernetII eth2(&buffer[0], (uint32_t)buffer.size()); ASSERT_TRUE(eth2.find_pdu<PPPoE>() != NULL); }
TEST_F(EthernetIITest, DestinationAddress) { EthernetII eth; eth.dst_addr(dst_addr); ASSERT_EQ(eth.dst_addr(), dst_addr); }
TEST_F(EthernetIITest, SourceAddress) { EthernetII eth; eth.src_addr(src_addr); ASSERT_EQ(eth.src_addr(), src_addr); }
void EthernetIITest::test_equals(const EthernetII& eth1, const EthernetII& eth2) { EXPECT_EQ(eth1.dst_addr(), eth2.dst_addr()); EXPECT_EQ(eth1.src_addr(), eth2.src_addr()); EXPECT_EQ(eth1.payload_type(), eth2.payload_type()); EXPECT_EQ(eth1.inner_pdu() != NULL, eth2.inner_pdu() != NULL); }
TEST_F(EthernetIITest, PayloadType) { EthernetII eth; eth.payload_type(p_type); ASSERT_EQ(eth.payload_type(), p_type); }