xref: /freebsd/tests/sys/netinet6/frag6/frag6_14.py (revision e32221a15f089282e5dfe18891c5312b26cbe3ba)
1f74e6e49SBjoern A. Zeeb#!/usr/bin/env python
2f74e6e49SBjoern A. Zeeb#-
3f74e6e49SBjoern A. Zeeb# SPDX-License-Identifier: BSD-2-Clause
4f74e6e49SBjoern A. Zeeb#
5f74e6e49SBjoern A. Zeeb# Copyright (c) 2019 Netflix, Inc.
6f74e6e49SBjoern A. Zeeb#
7f74e6e49SBjoern A. Zeeb# Redistribution and use in source and binary forms, with or without
8f74e6e49SBjoern A. Zeeb# modification, are permitted provided that the following conditions
9f74e6e49SBjoern A. Zeeb# are met:
10f74e6e49SBjoern A. Zeeb# 1. Redistributions of source code must retain the above copyright
11f74e6e49SBjoern A. Zeeb#    notice, this list of conditions and the following disclaimer.
12f74e6e49SBjoern A. Zeeb# 2. Redistributions in binary form must reproduce the above copyright
13f74e6e49SBjoern A. Zeeb#    notice, this list of conditions and the following disclaimer in the
14f74e6e49SBjoern A. Zeeb#    documentation and/or other materials provided with the distribution.
15f74e6e49SBjoern A. Zeeb#
16f74e6e49SBjoern A. Zeeb# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17f74e6e49SBjoern A. Zeeb# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18f74e6e49SBjoern A. Zeeb# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19f74e6e49SBjoern A. Zeeb# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20f74e6e49SBjoern A. Zeeb# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21f74e6e49SBjoern A. Zeeb# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22f74e6e49SBjoern A. Zeeb# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23f74e6e49SBjoern A. Zeeb# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24f74e6e49SBjoern A. Zeeb# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25f74e6e49SBjoern A. Zeeb# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26f74e6e49SBjoern A. Zeeb# SUCH DAMAGE.
27f74e6e49SBjoern A. Zeeb#
28f74e6e49SBjoern A. Zeeb# $FreeBSD$
29f74e6e49SBjoern A. Zeeb#
30f74e6e49SBjoern A. Zeeb
31f74e6e49SBjoern A. Zeebimport argparse
32a26e895fSKristof Provostimport logging
33a26e895fSKristof Provostlogging.getLogger("scapy").setLevel(logging.CRITICAL)
34f74e6e49SBjoern A. Zeebimport scapy.all as sp
35f74e6e49SBjoern A. Zeebimport socket
36f74e6e49SBjoern A. Zeebimport sys
37f74e6e49SBjoern A. Zeebfrom time import sleep
38f74e6e49SBjoern A. Zeeb
39f74e6e49SBjoern A. Zeebdef main():
40f74e6e49SBjoern A. Zeeb	parser = argparse.ArgumentParser("frag6.py",
41f74e6e49SBjoern A. Zeeb		description="IPv6 fragementation test tool")
42f74e6e49SBjoern A. Zeeb	parser.add_argument('--sendif', nargs=1,
43f74e6e49SBjoern A. Zeeb		required=True,
44f74e6e49SBjoern A. Zeeb		help='The interface through which the packet will be sent')
45f74e6e49SBjoern A. Zeeb	parser.add_argument('--recvif', nargs=1,
46f74e6e49SBjoern A. Zeeb		required=True,
47f74e6e49SBjoern A. Zeeb		help='The interface on which to check for the packet')
48f74e6e49SBjoern A. Zeeb	parser.add_argument('--src', nargs=1,
49f74e6e49SBjoern A. Zeeb		required=True,
50f74e6e49SBjoern A. Zeeb		help='The source IP address')
51f74e6e49SBjoern A. Zeeb	parser.add_argument('--to', nargs=1,
52f74e6e49SBjoern A. Zeeb		required=True,
53f74e6e49SBjoern A. Zeeb		help='The destination IP address')
54f74e6e49SBjoern A. Zeeb	parser.add_argument('--debug',
55f74e6e49SBjoern A. Zeeb		required=False, action='store_true',
56f74e6e49SBjoern A. Zeeb		help='Enable test debugging')
57f74e6e49SBjoern A. Zeeb
58f74e6e49SBjoern A. Zeeb	args = parser.parse_args()
59f74e6e49SBjoern A. Zeeb
60f74e6e49SBjoern A. Zeeb
61f74e6e49SBjoern A. Zeeb	########################################################################
62f74e6e49SBjoern A. Zeeb	#
63f74e6e49SBjoern A. Zeeb	# Send multiple fragments, with an exact overlap in a middle one,
64f74e6e49SBjoern A. Zeeb	# not finishing the full packet (and ignoring the content anyway).
65f74e6e49SBjoern A. Zeeb	#
66f74e6e49SBjoern A. Zeeb	# A:  Reassembly failure.
67f74e6e49SBjoern A. Zeeb	# R:  dup dropped silently / Timeout (not waiting for).
68f74e6e49SBjoern A. Zeeb	#
69f74e6e49SBjoern A. Zeeb	data = "6" * 8
70f74e6e49SBjoern A. Zeeb	ip6f01 = \
71f74e6e49SBjoern A. Zeeb		sp.Ether() / \
72f74e6e49SBjoern A. Zeeb		sp.IPv6(src=args.src[0], dst=args.to[0]) / \
73f74e6e49SBjoern A. Zeeb		sp.IPv6ExtHdrFragment(offset=0, m=1, id=14) / \
74f74e6e49SBjoern A. Zeeb		sp.UDP(dport=3456, sport=6543) / \
75f74e6e49SBjoern A. Zeeb		data
76f74e6e49SBjoern A. Zeeb	ip6f02 = \
77f74e6e49SBjoern A. Zeeb		sp.Ether() / \
78f74e6e49SBjoern A. Zeeb		sp.IPv6(src=args.src[0], dst=args.to[0]) / \
79f74e6e49SBjoern A. Zeeb		sp.IPv6ExtHdrFragment(offset=0x1000, m=0, id=14) / \
80f74e6e49SBjoern A. Zeeb		sp.UDP(dport=3456, sport=6543) / \
81f74e6e49SBjoern A. Zeeb		data
82f74e6e49SBjoern A. Zeeb	ip6f03 = \
83f74e6e49SBjoern A. Zeeb		sp.Ether() / \
84f74e6e49SBjoern A. Zeeb		sp.IPv6(src=args.src[0], dst=args.to[0]) / \
85f74e6e49SBjoern A. Zeeb		sp.IPv6ExtHdrFragment(offset=16, m=1, id=14) / \
86f74e6e49SBjoern A. Zeeb		sp.UDP(dport=3456, sport=6543) / \
87f74e6e49SBjoern A. Zeeb		data
88f74e6e49SBjoern A. Zeeb	ip6f04 = \
89f74e6e49SBjoern A. Zeeb		sp.Ether() / \
90f74e6e49SBjoern A. Zeeb		sp.IPv6(src=args.src[0], dst=args.to[0]) / \
91f74e6e49SBjoern A. Zeeb		sp.IPv6ExtHdrFragment(offset=16, m=1, id=14) / \
92f74e6e49SBjoern A. Zeeb		sp.UDP(dport=3456, sport=6543) / \
93f74e6e49SBjoern A. Zeeb		data
94f74e6e49SBjoern A. Zeeb	if args.debug :
95f74e6e49SBjoern A. Zeeb		ip6f01.display()
96f74e6e49SBjoern A. Zeeb		ip6f02.display()
97f74e6e49SBjoern A. Zeeb		ip6f03.display()
98f74e6e49SBjoern A. Zeeb		ip6f04.display()
99f74e6e49SBjoern A. Zeeb	sp.sendp(ip6f01, iface=args.sendif[0], verbose=False)
100f74e6e49SBjoern A. Zeeb	sp.sendp(ip6f02, iface=args.sendif[0], verbose=False)
101f74e6e49SBjoern A. Zeeb	sp.sendp(ip6f03, iface=args.sendif[0], verbose=False)
102f74e6e49SBjoern A. Zeeb	sp.sendp(ip6f04, iface=args.sendif[0], verbose=False)
103f74e6e49SBjoern A. Zeeb
104f74e6e49SBjoern A. Zeeb
105f74e6e49SBjoern A. Zeeb	# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # ##
106f74e6e49SBjoern A. Zeeb	#
107f74e6e49SBjoern A. Zeeb	# Send multiple fragments, with a partial overlap on the first one
108f74e6e49SBjoern A. Zeeb	# not finishing the full packet (and ignoring the content anyway).
109f74e6e49SBjoern A. Zeeb	# The second packet needs to be the first one in the fragment chain
110f74e6e49SBjoern A. Zeeb	# in order to trigger the 2nd case to test.
111f74e6e49SBjoern A. Zeeb	#
112f74e6e49SBjoern A. Zeeb	# A:  Reassembly failure.
113f74e6e49SBjoern A. Zeeb	# R:  dup dropped silently / Timeout (not waiting for).
114f74e6e49SBjoern A. Zeeb	#
115f74e6e49SBjoern A. Zeeb	data = "6" * 8
116f74e6e49SBjoern A. Zeeb	ip6f01 = \
117f74e6e49SBjoern A. Zeeb		sp.Ether() / \
118f74e6e49SBjoern A. Zeeb		sp.IPv6(src=args.src[0], dst=args.to[0]) / \
119f74e6e49SBjoern A. Zeeb		sp.IPv6ExtHdrFragment(offset=10, m=1, id=0x1401) / \
120f74e6e49SBjoern A. Zeeb		sp.UDP(dport=3456, sport=6543) / \
121f74e6e49SBjoern A. Zeeb		data
122f74e6e49SBjoern A. Zeeb	ip6f02 = \
123f74e6e49SBjoern A. Zeeb		sp.Ether() / \
124f74e6e49SBjoern A. Zeeb		sp.IPv6(src=args.src[0], dst=args.to[0]) / \
125f74e6e49SBjoern A. Zeeb		sp.IPv6ExtHdrFragment(offset=9, m=0, id=0x1401) / \
126f74e6e49SBjoern A. Zeeb		sp.UDP(dport=3456, sport=6543) / \
127f74e6e49SBjoern A. Zeeb		data
128f74e6e49SBjoern A. Zeeb	if args.debug :
129f74e6e49SBjoern A. Zeeb		ip6f01.display()
130f74e6e49SBjoern A. Zeeb		ip6f02.display()
131f74e6e49SBjoern A. Zeeb	sp.sendp(ip6f01, iface=args.sendif[0], verbose=False)
132f74e6e49SBjoern A. Zeeb	sp.sendp(ip6f02, iface=args.sendif[0], verbose=False)
133f74e6e49SBjoern A. Zeeb
1344527b28bSBjoern A. Zeeb	# Wait for expiry.
135*e32221a1SAlexander V. Chernikov	sleep(3)
136f74e6e49SBjoern A. Zeeb	sys.exit(0)
137f74e6e49SBjoern A. Zeeb
138f74e6e49SBjoern A. Zeebif __name__ == '__main__':
139f74e6e49SBjoern A. Zeeb	main()
140