blob: 235016e45b14bc783fd77458e74d37946b710547 [file] [log] [blame]
Renato Botelho do Coutoead1e532019-10-31 13:31:07 -05001#!/usr/bin/env python3
Pavel Kotucek59dda062017-03-02 15:22:47 +01002"""ACL plugin Test Case HLD:
3"""
4
5import unittest
6import random
7
Andrew Yourtchenkobc378782023-09-26 16:01:21 +02008from config import config
Pavel Kotucek59dda062017-03-02 15:22:47 +01009from scapy.packet import Raw
10from scapy.layers.l2 import Ether
11from scapy.layers.inet import IP, TCP, UDP, ICMP
12from scapy.layers.inet6 import IPv6, ICMPv6EchoRequest
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +000013from scapy.layers.inet6 import IPv6ExtHdrFragment
Pavel Kotucek59dda062017-03-02 15:22:47 +010014from framework import VppTestCase, VppTestRunner
Andrew Yourtchenkoc8eae8d2021-01-20 20:30:36 +000015from framework import tag_fixme_vpp_workers
Pavel Kotucek59dda062017-03-02 15:22:47 +010016from util import Host, ppp
Jakub Grajciar2f8cd912020-03-27 06:55:06 +010017from ipaddress import IPv4Network, IPv6Network
Pavel Kotucek59dda062017-03-02 15:22:47 +010018
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +010019from vpp_lo_interface import VppLoInterface
Jakub Grajciar2f8cd912020-03-27 06:55:06 +010020from vpp_acl import AclRule, VppAcl, VppAclInterface, VppEtypeWhitelist
21from vpp_ip import INVALID_INDEX
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +010022
Pavel Kotucek59dda062017-03-02 15:22:47 +010023
Andrew Yourtchenkobc378782023-09-26 16:01:21 +020024@unittest.skipIf("acl" in config.excluded_plugins, "Exclude ACL plugin tests")
Andrew Yourtchenkoc8eae8d2021-01-20 20:30:36 +000025@tag_fixme_vpp_workers
Pavel Kotucek59dda062017-03-02 15:22:47 +010026class TestACLplugin(VppTestCase):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020027 """ACL plugin Test Case"""
Pavel Kotucek59dda062017-03-02 15:22:47 +010028
29 # traffic types
30 IP = 0
31 ICMP = 1
32
33 # IP version
34 IPRANDOM = -1
35 IPV4 = 0
36 IPV6 = 1
37
38 # rule types
39 DENY = 0
40 PERMIT = 1
41
42 # supported protocols
43 proto = [[6, 17], [1, 58]]
Klement Sekerad9b0c6f2022-04-26 19:02:15 +020044 proto_map = {1: "ICMP", 58: "ICMPv6EchoRequest", 6: "TCP", 17: "UDP"}
Pavel Kotucek59dda062017-03-02 15:22:47 +010045 ICMPv4 = 0
46 ICMPv6 = 1
47 TCP = 0
48 UDP = 1
49 PROTO_ALL = 0
50
51 # port ranges
52 PORTS_ALL = -1
53 PORTS_RANGE = 0
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +020054 PORTS_RANGE_2 = 1
Pavel Kotucek59dda062017-03-02 15:22:47 +010055 udp_sport_from = 10
56 udp_sport_to = udp_sport_from + 5
57 udp_dport_from = 20000
58 udp_dport_to = udp_dport_from + 5000
59 tcp_sport_from = 30
60 tcp_sport_to = tcp_sport_from + 5
61 tcp_dport_from = 40000
62 tcp_dport_to = tcp_dport_from + 5000
63
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +020064 udp_sport_from_2 = 90
65 udp_sport_to_2 = udp_sport_from_2 + 5
66 udp_dport_from_2 = 30000
67 udp_dport_to_2 = udp_dport_from_2 + 5000
68 tcp_sport_from_2 = 130
69 tcp_sport_to_2 = tcp_sport_from_2 + 5
70 tcp_dport_from_2 = 20000
71 tcp_dport_to_2 = tcp_dport_from_2 + 5000
72
Pavel Kotucek59dda062017-03-02 15:22:47 +010073 icmp4_type = 8 # echo request
74 icmp4_code = 3
75 icmp6_type = 128 # echo request
76 icmp6_code = 3
77
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +020078 icmp4_type_2 = 8
79 icmp4_code_from_2 = 5
80 icmp4_code_to_2 = 20
81 icmp6_type_2 = 128
82 icmp6_code_from_2 = 8
83 icmp6_code_to_2 = 42
84
Pavel Kotucek59dda062017-03-02 15:22:47 +010085 # Test variables
86 bd_id = 1
87
88 @classmethod
89 def setUpClass(cls):
90 """
91 Perform standard class setup (defined by class method setUpClass in
92 class VppTestCase) before running the test case, set test case related
93 variables and configure VPP.
94 """
95 super(TestACLplugin, cls).setUpClass()
96
Pavel Kotucek59dda062017-03-02 15:22:47 +010097 try:
98 # Create 2 pg interfaces
99 cls.create_pg_interfaces(range(2))
100
101 # Packet flows mapping pg0 -> pg1, pg2 etc.
102 cls.flows = dict()
103 cls.flows[cls.pg0] = [cls.pg1]
104
105 # Packet sizes
106 cls.pg_if_packet_sizes = [64, 512, 1518, 9018]
107
108 # Create BD with MAC learning and unknown unicast flooding disabled
109 # and put interfaces to this BD
Laszlo Kiraly0f8f4352022-09-16 13:20:07 +0200110 cls.vapi.bridge_domain_add_del_v2(
111 bd_id=cls.bd_id, uu_flood=1, learn=1, flood=1, forward=1, is_add=1
112 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100113 for pg_if in cls.pg_interfaces:
Ole Troana5b2eec2019-03-11 19:23:25 +0100114 cls.vapi.sw_interface_set_l2_bridge(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200115 rx_sw_if_index=pg_if.sw_if_index, bd_id=cls.bd_id
116 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100117
118 # Set up all interfaces
119 for i in cls.pg_interfaces:
120 i.admin_up()
121
122 # Mapping between packet-generator index and lists of test hosts
123 cls.hosts_by_pg_idx = dict()
124 for pg_if in cls.pg_interfaces:
125 cls.hosts_by_pg_idx[pg_if.sw_if_index] = []
126
127 # Create list of deleted hosts
128 cls.deleted_hosts_by_pg_idx = dict()
129 for pg_if in cls.pg_interfaces:
130 cls.deleted_hosts_by_pg_idx[pg_if.sw_if_index] = []
131
132 # warm-up the mac address tables
133 # self.warmup_test()
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200134 count = 16
135 start = 0
136 n_int = len(cls.pg_interfaces)
snaramre2bb71512019-10-16 22:15:43 +0000137 macs_per_if = count // n_int
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200138 i = -1
139 for pg_if in cls.pg_interfaces:
140 i += 1
141 start_nr = macs_per_if * i + start
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200142 end_nr = (
143 count + start if i == (n_int - 1) else macs_per_if * (i + 1) + start
144 )
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200145 hosts = cls.hosts_by_pg_idx[pg_if.sw_if_index]
snaramre2bb71512019-10-16 22:15:43 +0000146 for j in range(int(start_nr), int(end_nr)):
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200147 host = Host(
148 "00:00:00:ff:%02x:%02x" % (pg_if.sw_if_index, j),
149 "172.17.1%02x.%u" % (pg_if.sw_if_index, j),
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200150 "2017:dead:%02x::%u" % (pg_if.sw_if_index, j),
151 )
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200152 hosts.append(host)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100153
154 except Exception:
155 super(TestACLplugin, cls).tearDownClass()
156 raise
157
Paul Vinciguerra7f9b7f92019-03-12 19:23:27 -0700158 @classmethod
159 def tearDownClass(cls):
160 super(TestACLplugin, cls).tearDownClass()
161
Pavel Kotucek59dda062017-03-02 15:22:47 +0100162 def setUp(self):
163 super(TestACLplugin, self).setUp()
164 self.reset_packet_infos()
165
166 def tearDown(self):
167 """
168 Show various debug prints after each test.
169 """
170 super(TestACLplugin, self).tearDown()
Paul Vinciguerra90cf21b2019-03-13 09:23:05 -0700171
172 def show_commands_at_teardown(self):
173 cli = "show vlib graph l2-input-feat-arc"
174 self.logger.info(self.vapi.ppcli(cli))
175 cli = "show vlib graph l2-input-feat-arc-end"
176 self.logger.info(self.vapi.ppcli(cli))
177 cli = "show vlib graph l2-output-feat-arc"
178 self.logger.info(self.vapi.ppcli(cli))
179 cli = "show vlib graph l2-output-feat-arc-end"
180 self.logger.info(self.vapi.ppcli(cli))
181 self.logger.info(self.vapi.ppcli("show l2fib verbose"))
182 self.logger.info(self.vapi.ppcli("show acl-plugin acl"))
183 self.logger.info(self.vapi.ppcli("show acl-plugin interface"))
184 self.logger.info(self.vapi.ppcli("show acl-plugin tables"))
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200185 self.logger.info(self.vapi.ppcli("show bridge-domain %s detail" % self.bd_id))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100186
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200187 def create_rule(
188 self,
189 ip=0,
190 permit_deny=0,
191 ports=PORTS_ALL,
192 proto=-1,
193 s_prefix=0,
194 s_ip=0,
195 d_prefix=0,
196 d_ip=0,
197 ):
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100198 if ip:
199 src_prefix = IPv6Network((s_ip, s_prefix))
200 dst_prefix = IPv6Network((d_ip, d_prefix))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100201 else:
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100202 src_prefix = IPv4Network((s_ip, s_prefix))
203 dst_prefix = IPv4Network((d_ip, d_prefix))
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200204 return AclRule(
205 is_permit=permit_deny,
206 ports=ports,
207 proto=proto,
208 src_prefix=src_prefix,
209 dst_prefix=dst_prefix,
210 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100211
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100212 def apply_rules(self, rules, tag=None):
213 acl = VppAcl(self, rules, tag=tag)
214 acl.add_vpp_config()
215 self.logger.info("Dumped ACL: " + str(acl.dump()))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100216 # Apply a ACL on the interface as inbound
217 for i in self.pg_interfaces:
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100218 acl_if = VppAclInterface(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200219 self, sw_if_index=i.sw_if_index, n_input=1, acls=[acl]
220 )
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100221 acl_if.add_vpp_config()
222 return acl.acl_index
Pavel Kotucek59dda062017-03-02 15:22:47 +0100223
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100224 def apply_rules_to(self, rules, tag=None, sw_if_index=INVALID_INDEX):
225 acl = VppAcl(self, rules, tag=tag)
226 acl.add_vpp_config()
227 self.logger.info("Dumped ACL: " + str(acl.dump()))
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +0100228 # Apply a ACL on the interface as inbound
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200229 acl_if = VppAclInterface(self, sw_if_index=sw_if_index, n_input=1, acls=[acl])
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100230 return acl.acl_index
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +0100231
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100232 def etype_whitelist(self, whitelist, n_input, add=True):
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +0100233 # Apply whitelists on all the interfaces
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100234 if add:
235 self._wl = []
236 for i in self.pg_interfaces:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200237 self._wl.append(
238 VppEtypeWhitelist(
239 self,
240 sw_if_index=i.sw_if_index,
241 whitelist=whitelist,
242 n_input=n_input,
243 ).add_vpp_config()
244 )
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100245 else:
246 if hasattr(self, "_wl"):
247 for wl in self._wl:
248 wl.remove_vpp_config()
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +0100249
Pavel Kotucek59dda062017-03-02 15:22:47 +0100250 def create_upper_layer(self, packet_index, proto, ports=0):
251 p = self.proto_map[proto]
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200252 if p == "UDP":
Pavel Kotucek59dda062017-03-02 15:22:47 +0100253 if ports == 0:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200254 return UDP(
255 sport=random.randint(self.udp_sport_from, self.udp_sport_to),
256 dport=random.randint(self.udp_dport_from, self.udp_dport_to),
257 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100258 else:
259 return UDP(sport=ports, dport=ports)
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200260 elif p == "TCP":
Pavel Kotucek59dda062017-03-02 15:22:47 +0100261 if ports == 0:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200262 return TCP(
263 sport=random.randint(self.tcp_sport_from, self.tcp_sport_to),
264 dport=random.randint(self.tcp_dport_from, self.tcp_dport_to),
265 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100266 else:
267 return TCP(sport=ports, dport=ports)
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200268 return ""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100269
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200270 def create_stream(
271 self,
272 src_if,
273 packet_sizes,
274 traffic_type=0,
275 ipv6=0,
276 proto=-1,
277 ports=0,
278 fragments=False,
279 pkt_raw=True,
280 etype=-1,
281 ):
Pavel Kotucek59dda062017-03-02 15:22:47 +0100282 """
283 Create input packet stream for defined interface using hosts or
284 deleted_hosts list.
285
286 :param object src_if: Interface to create packet stream for.
287 :param list packet_sizes: List of required packet sizes.
288 :param traffic_type: 1: ICMP packet, 2: IPv6 with EH, 0: otherwise.
289 :return: Stream of packets.
290 """
291 pkts = []
292 if self.flows.__contains__(src_if):
293 src_hosts = self.hosts_by_pg_idx[src_if.sw_if_index]
294 for dst_if in self.flows[src_if]:
295 dst_hosts = self.hosts_by_pg_idx[dst_if.sw_if_index]
296 n_int = len(dst_hosts) * len(src_hosts)
297 for i in range(0, n_int):
snaramre2bb71512019-10-16 22:15:43 +0000298 dst_host = dst_hosts[int(i / len(src_hosts))]
Pavel Kotucek59dda062017-03-02 15:22:47 +0100299 src_host = src_hosts[i % len(src_hosts)]
300 pkt_info = self.create_packet_info(src_if, dst_if)
301 if ipv6 == 1:
302 pkt_info.ip = 1
303 elif ipv6 == 0:
304 pkt_info.ip = 0
305 else:
306 pkt_info.ip = random.choice([0, 1])
307 if proto == -1:
308 pkt_info.proto = random.choice(self.proto[self.IP])
309 else:
310 pkt_info.proto = proto
311 payload = self.info_to_payload(pkt_info)
312 p = Ether(dst=dst_host.mac, src=src_host.mac)
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +0100313 if etype > 0:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200314 p = Ether(dst=dst_host.mac, src=src_host.mac, type=etype)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100315 if pkt_info.ip:
316 p /= IPv6(dst=dst_host.ip6, src=src_host.ip6)
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +0000317 if fragments:
318 p /= IPv6ExtHdrFragment(offset=64, m=1)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100319 else:
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +0000320 if fragments:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200321 p /= IP(
322 src=src_host.ip4, dst=dst_host.ip4, flags=1, frag=64
323 )
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +0000324 else:
325 p /= IP(src=src_host.ip4, dst=dst_host.ip4)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100326 if traffic_type == self.ICMP:
327 if pkt_info.ip:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200328 p /= ICMPv6EchoRequest(
329 type=self.icmp6_type, code=self.icmp6_code
330 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100331 else:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200332 p /= ICMP(type=self.icmp4_type, code=self.icmp4_code)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100333 else:
334 p /= self.create_upper_layer(i, pkt_info.proto, ports)
Pavel Kotuceke7b67342017-04-18 13:12:20 +0200335 if pkt_raw:
336 p /= Raw(payload)
337 pkt_info.data = p.copy()
338 if pkt_raw:
339 size = random.choice(packet_sizes)
340 self.extend_packet(p, size)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100341 pkts.append(p)
342 return pkts
343
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200344 def verify_capture(self, pg_if, capture, traffic_type=0, ip_type=0, etype=-1):
Pavel Kotucek59dda062017-03-02 15:22:47 +0100345 """
346 Verify captured input packet stream for defined interface.
347
348 :param object pg_if: Interface to verify captured packet stream for.
349 :param list capture: Captured packet stream.
350 :param traffic_type: 1: ICMP packet, 2: IPv6 with EH, 0: otherwise.
351 """
352 last_info = dict()
353 for i in self.pg_interfaces:
354 last_info[i.sw_if_index] = None
355 dst_sw_if_index = pg_if.sw_if_index
356 for packet in capture:
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +0100357 if etype > 0:
358 if packet[Ether].type != etype:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200359 self.logger.error(ppp("Unexpected ethertype in packet:", packet))
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +0100360 else:
361 continue
Pavel Kotucek59dda062017-03-02 15:22:47 +0100362 try:
363 # Raw data for ICMPv6 are stored in ICMPv6EchoRequest.data
364 if traffic_type == self.ICMP and ip_type == self.IPV6:
365 payload_info = self.payload_to_info(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200366 packet[ICMPv6EchoRequest], "data"
367 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100368 payload = packet[ICMPv6EchoRequest]
369 else:
Paul Vinciguerraeaea4212019-03-06 11:58:06 -0800370 payload_info = self.payload_to_info(packet[Raw])
Pavel Kotucek59dda062017-03-02 15:22:47 +0100371 payload = packet[self.proto_map[payload_info.proto]]
372 except:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200373 self.logger.error(
374 ppp("Unexpected or invalid packet (outside network):", packet)
375 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100376 raise
377
378 if ip_type != 0:
379 self.assertEqual(payload_info.ip, ip_type)
380 if traffic_type == self.ICMP:
381 try:
382 if payload_info.ip == 0:
383 self.assertEqual(payload.type, self.icmp4_type)
384 self.assertEqual(payload.code, self.icmp4_code)
385 else:
386 self.assertEqual(payload.type, self.icmp6_type)
387 self.assertEqual(payload.code, self.icmp6_code)
388 except:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200389 self.logger.error(
390 ppp("Unexpected or invalid packet (outside network):", packet)
391 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100392 raise
393 else:
394 try:
395 ip_version = IPv6 if payload_info.ip == 1 else IP
396
397 ip = packet[ip_version]
398 packet_index = payload_info.index
399
400 self.assertEqual(payload_info.dst, dst_sw_if_index)
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200401 self.logger.debug(
402 "Got packet on port %s: src=%u (id=%u)"
403 % (pg_if.name, payload_info.src, packet_index)
404 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100405 next_info = self.get_next_packet_info_for_interface2(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200406 payload_info.src, dst_sw_if_index, last_info[payload_info.src]
407 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100408 last_info[payload_info.src] = next_info
409 self.assertTrue(next_info is not None)
410 self.assertEqual(packet_index, next_info.index)
411 saved_packet = next_info.data
412 # Check standard fields
413 self.assertEqual(ip.src, saved_packet[ip_version].src)
414 self.assertEqual(ip.dst, saved_packet[ip_version].dst)
415 p = self.proto_map[payload_info.proto]
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200416 if p == "TCP":
Pavel Kotucek59dda062017-03-02 15:22:47 +0100417 tcp = packet[TCP]
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200418 self.assertEqual(tcp.sport, saved_packet[TCP].sport)
419 self.assertEqual(tcp.dport, saved_packet[TCP].dport)
420 elif p == "UDP":
Pavel Kotucek59dda062017-03-02 15:22:47 +0100421 udp = packet[UDP]
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200422 self.assertEqual(udp.sport, saved_packet[UDP].sport)
423 self.assertEqual(udp.dport, saved_packet[UDP].dport)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100424 except:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200425 self.logger.error(ppp("Unexpected or invalid packet:", packet))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100426 raise
427 for i in self.pg_interfaces:
428 remaining_packet = self.get_next_packet_info_for_interface2(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200429 i, dst_sw_if_index, last_info[i.sw_if_index]
430 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100431 self.assertTrue(
432 remaining_packet is None,
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200433 "Port %u: Packet expected from source %u didn't arrive"
434 % (dst_sw_if_index, i.sw_if_index),
435 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100436
437 def run_traffic_no_check(self):
438 # Test
439 # Create incoming packet streams for packet-generator interfaces
440 for i in self.pg_interfaces:
441 if self.flows.__contains__(i):
442 pkts = self.create_stream(i, self.pg_if_packet_sizes)
443 if len(pkts) > 0:
444 i.add_stream(pkts)
445
446 # Enable packet capture and start packet sending
447 self.pg_enable_capture(self.pg_interfaces)
448 self.pg_start()
449
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200450 def run_verify_test(
451 self,
452 traffic_type=0,
453 ip_type=0,
454 proto=-1,
455 ports=0,
456 frags=False,
457 pkt_raw=True,
458 etype=-1,
459 ):
Pavel Kotucek59dda062017-03-02 15:22:47 +0100460 # Test
461 # Create incoming packet streams for packet-generator interfaces
462 pkts_cnt = 0
463 for i in self.pg_interfaces:
464 if self.flows.__contains__(i):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200465 pkts = self.create_stream(
466 i,
467 self.pg_if_packet_sizes,
468 traffic_type,
469 ip_type,
470 proto,
471 ports,
472 frags,
473 pkt_raw,
474 etype,
475 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100476 if len(pkts) > 0:
477 i.add_stream(pkts)
478 pkts_cnt += len(pkts)
479
480 # Enable packet capture and start packet sendingself.IPV
481 self.pg_enable_capture(self.pg_interfaces)
482 self.pg_start()
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200483 self.logger.info("sent packets count: %d" % pkts_cnt)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100484
485 # Verify
486 # Verify outgoing packet streams per packet-generator interface
487 for src_if in self.pg_interfaces:
488 if self.flows.__contains__(src_if):
489 for dst_if in self.flows[src_if]:
490 capture = dst_if.get_capture(pkts_cnt)
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200491 self.logger.info("Verifying capture on interface %s" % dst_if.name)
492 self.verify_capture(dst_if, capture, traffic_type, ip_type, etype)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100493
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200494 def run_verify_negat_test(
495 self, traffic_type=0, ip_type=0, proto=-1, ports=0, frags=False, etype=-1
496 ):
Pavel Kotucek59dda062017-03-02 15:22:47 +0100497 # Test
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200498 pkts_cnt = 0
Pavel Kotucek59dda062017-03-02 15:22:47 +0100499 self.reset_packet_infos()
500 for i in self.pg_interfaces:
501 if self.flows.__contains__(i):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200502 pkts = self.create_stream(
503 i,
504 self.pg_if_packet_sizes,
505 traffic_type,
506 ip_type,
507 proto,
508 ports,
509 frags,
510 True,
511 etype,
512 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100513 if len(pkts) > 0:
514 i.add_stream(pkts)
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200515 pkts_cnt += len(pkts)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100516
517 # Enable packet capture and start packet sending
518 self.pg_enable_capture(self.pg_interfaces)
519 self.pg_start()
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +0200520 self.logger.info("sent packets count: %d" % pkts_cnt)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100521
522 # Verify
523 # Verify outgoing packet streams per packet-generator interface
524 for src_if in self.pg_interfaces:
525 if self.flows.__contains__(src_if):
526 for dst_if in self.flows[src_if]:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200527 self.logger.info("Verifying capture on interface %s" % dst_if.name)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100528 capture = dst_if.get_capture(0)
529 self.assertEqual(len(capture), 0)
530
Pavel Kotucek59dda062017-03-02 15:22:47 +0100531 def test_0000_warmup_test(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200532 """ACL plugin version check; learn MACs"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100533 reply = self.vapi.papi.acl_plugin_get_version()
534 self.assertEqual(reply.major, 1)
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200535 self.logger.info(
536 "Working with ACL plugin version: %d.%d" % (reply.major, reply.minor)
537 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100538 # minor version changes are non breaking
539 # self.assertEqual(reply.minor, 0)
540
541 def test_0001_acl_create(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200542 """ACL create/delete test"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100543
544 self.logger.info("ACLP_TEST_START_0001")
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100545 # Create a permit-1234 ACL
546 r = [AclRule(is_permit=1, proto=17, ports=1234, sport_to=1235)]
Pavel Kotucek59dda062017-03-02 15:22:47 +0100547 # Test 1: add a new ACL
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100548 first_acl = VppAcl(self, rules=r, tag="permit 1234")
549 first_acl.add_vpp_config()
550 self.assertTrue(first_acl.query_vpp_config())
Pavel Kotucek59dda062017-03-02 15:22:47 +0100551 # The very first ACL gets #0
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100552 self.assertEqual(first_acl.acl_index, 0)
553 rr = first_acl.dump()
Pavel Kotucek59dda062017-03-02 15:22:47 +0100554 self.logger.info("Dumped ACL: " + str(rr))
555 self.assertEqual(len(rr), 1)
556 # We should have the same number of ACL entries as we had asked
557 self.assertEqual(len(rr[0].r), len(r))
558 # The rules should be the same. But because the submitted and returned
559 # are different types, we need to iterate over rules and keys to get
560 # to basic values.
561 for i_rule in range(0, len(r) - 1):
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100562 encoded_rule = r[i_rule].encode()
563 for rule_key in encoded_rule:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200564 self.assertEqual(rr[0].r[i_rule][rule_key], encoded_rule[rule_key])
Pavel Kotucek59dda062017-03-02 15:22:47 +0100565
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100566 # Create a deny-1234 ACL
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200567 r_deny = [
568 AclRule(is_permit=0, proto=17, ports=1234, sport_to=1235),
569 AclRule(is_permit=1, proto=17, ports=0),
570 ]
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100571 second_acl = VppAcl(self, rules=r_deny, tag="deny 1234;permit all")
572 second_acl.add_vpp_config()
573 self.assertTrue(second_acl.query_vpp_config())
Pavel Kotucek59dda062017-03-02 15:22:47 +0100574 # The second ACL gets #1
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100575 self.assertEqual(second_acl.acl_index, 1)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100576
577 # Test 2: try to modify a nonexistent ACL
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100578 invalid_acl = VppAcl(self, acl_index=432, rules=r, tag="FFFF:FFFF")
579 reply = invalid_acl.add_vpp_config(expect_error=True)
Jakub Grajciaraad1ee12020-03-11 12:47:32 +0100580
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100581 # apply an ACL on an interface inbound, try to delete ACL, must fail
582 acl_if_list = VppAclInterface(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200583 self, sw_if_index=self.pg0.sw_if_index, n_input=1, acls=[first_acl]
584 )
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100585 acl_if_list.add_vpp_config()
586 first_acl.remove_vpp_config(expect_error=True)
587 # Unapply an ACL and then try to delete it - must be ok
588 acl_if_list.remove_vpp_config()
589 first_acl.remove_vpp_config()
590
591 # apply an ACL on an interface inbound, try to delete ACL, must fail
592 acl_if_list = VppAclInterface(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200593 self, sw_if_index=self.pg0.sw_if_index, n_input=0, acls=[second_acl]
594 )
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100595 acl_if_list.add_vpp_config()
596 second_acl.remove_vpp_config(expect_error=True)
597 # Unapply an ACL and then try to delete it - must be ok
598 acl_if_list.remove_vpp_config()
599 second_acl.remove_vpp_config()
Andrew Yourtchenko987abe92017-09-27 13:50:31 +0200600
601 # try to apply a nonexistent ACL - must fail
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100602 acl_if_list = VppAclInterface(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200603 self, sw_if_index=self.pg0.sw_if_index, n_input=0, acls=[invalid_acl]
604 )
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100605 acl_if_list.add_vpp_config(expect_error=True)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100606
607 self.logger.info("ACLP_TEST_FINISH_0001")
608
609 def test_0002_acl_permit_apply(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200610 """permit ACL apply test"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100611 self.logger.info("ACLP_TEST_START_0002")
612
613 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200614 rules.append(
615 self.create_rule(self.IPV4, self.PERMIT, 0, self.proto[self.IP][self.UDP])
616 )
617 rules.append(
618 self.create_rule(self.IPV4, self.PERMIT, 0, self.proto[self.IP][self.TCP])
619 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100620
621 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100622 acl_idx = self.apply_rules(rules, "permit per-flow")
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000623
624 # enable counters
625 reply = self.vapi.papi.acl_stats_intf_counters_enable(enable=1)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100626
627 # Traffic should still pass
628 self.run_verify_test(self.IP, self.IPV4, -1)
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000629
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200630 matches = self.statistics.get_counter("/acl/%d/matches" % acl_idx)
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000631 self.logger.info("stat segment counters: %s" % repr(matches))
632 cli = "show acl-plugin acl"
633 self.logger.info(self.vapi.ppcli(cli))
634 cli = "show acl-plugin tables"
635 self.logger.info(self.vapi.ppcli(cli))
636
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200637 total_hits = matches[0][0]["packets"] + matches[0][1]["packets"]
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000638 self.assertEqual(total_hits, 64)
639
640 # disable counters
641 reply = self.vapi.papi.acl_stats_intf_counters_enable(enable=0)
642
Pavel Kotucek59dda062017-03-02 15:22:47 +0100643 self.logger.info("ACLP_TEST_FINISH_0002")
644
645 def test_0003_acl_deny_apply(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200646 """deny ACL apply test"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100647 self.logger.info("ACLP_TEST_START_0003")
648 # Add a deny-flows ACL
649 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200650 rules.append(
651 self.create_rule(
652 self.IPV4, self.DENY, self.PORTS_ALL, self.proto[self.IP][self.UDP]
653 )
654 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100655 # Permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200656 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100657
658 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100659 acl_idx = self.apply_rules(rules, "deny per-flow;permit all")
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000660
661 # enable counters
662 reply = self.vapi.papi.acl_stats_intf_counters_enable(enable=1)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100663
664 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200665 self.run_verify_negat_test(self.IP, self.IPV4, self.proto[self.IP][self.UDP])
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000666
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200667 matches = self.statistics.get_counter("/acl/%d/matches" % acl_idx)
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000668 self.logger.info("stat segment counters: %s" % repr(matches))
669 cli = "show acl-plugin acl"
670 self.logger.info(self.vapi.ppcli(cli))
671 cli = "show acl-plugin tables"
672 self.logger.info(self.vapi.ppcli(cli))
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200673 self.assertEqual(matches[0][0]["packets"], 64)
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000674 # disable counters
675 reply = self.vapi.papi.acl_stats_intf_counters_enable(enable=0)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100676 self.logger.info("ACLP_TEST_FINISH_0003")
Andrew Yourtchenkof995c712019-06-13 15:23:21 +0000677 # self.assertEqual(, 0)
Pavel Kotucek59dda062017-03-02 15:22:47 +0100678
679 def test_0004_vpp624_permit_icmpv4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200680 """VPP_624 permit ICMPv4"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100681 self.logger.info("ACLP_TEST_START_0004")
682
683 # Add an ACL
684 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200685 rules.append(
686 self.create_rule(
687 self.IPV4,
688 self.PERMIT,
689 self.PORTS_RANGE,
690 self.proto[self.ICMP][self.ICMPv4],
691 )
692 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100693 # deny ip any any in the end
694 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
695
696 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100697 self.apply_rules(rules, "permit icmpv4")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100698
699 # Traffic should still pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200700 self.run_verify_test(self.ICMP, self.IPV4, self.proto[self.ICMP][self.ICMPv4])
Pavel Kotucek59dda062017-03-02 15:22:47 +0100701
702 self.logger.info("ACLP_TEST_FINISH_0004")
703
704 def test_0005_vpp624_permit_icmpv6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200705 """VPP_624 permit ICMPv6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100706 self.logger.info("ACLP_TEST_START_0005")
707
708 # Add an ACL
709 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200710 rules.append(
711 self.create_rule(
712 self.IPV6,
713 self.PERMIT,
714 self.PORTS_RANGE,
715 self.proto[self.ICMP][self.ICMPv6],
716 )
717 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100718 # deny ip any any in the end
719 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
720
721 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100722 self.apply_rules(rules, "permit icmpv6")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100723
724 # Traffic should still pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200725 self.run_verify_test(self.ICMP, self.IPV6, self.proto[self.ICMP][self.ICMPv6])
Pavel Kotucek59dda062017-03-02 15:22:47 +0100726
727 self.logger.info("ACLP_TEST_FINISH_0005")
728
729 def test_0006_vpp624_deny_icmpv4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200730 """VPP_624 deny ICMPv4"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100731 self.logger.info("ACLP_TEST_START_0006")
732 # Add an ACL
733 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200734 rules.append(
735 self.create_rule(
736 self.IPV4,
737 self.DENY,
738 self.PORTS_RANGE,
739 self.proto[self.ICMP][self.ICMPv4],
740 )
741 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100742 # permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200743 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100744
745 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100746 self.apply_rules(rules, "deny icmpv4")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100747
748 # Traffic should not pass
749 self.run_verify_negat_test(self.ICMP, self.IPV4, 0)
750
751 self.logger.info("ACLP_TEST_FINISH_0006")
752
753 def test_0007_vpp624_deny_icmpv6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200754 """VPP_624 deny ICMPv6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100755 self.logger.info("ACLP_TEST_START_0007")
756 # Add an ACL
757 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200758 rules.append(
759 self.create_rule(
760 self.IPV6,
761 self.DENY,
762 self.PORTS_RANGE,
763 self.proto[self.ICMP][self.ICMPv6],
764 )
765 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100766 # deny ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200767 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100768
769 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100770 self.apply_rules(rules, "deny icmpv6")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100771
772 # Traffic should not pass
773 self.run_verify_negat_test(self.ICMP, self.IPV6, 0)
774
775 self.logger.info("ACLP_TEST_FINISH_0007")
776
777 def test_0008_tcp_permit_v4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200778 """permit TCPv4"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100779 self.logger.info("ACLP_TEST_START_0008")
780
781 # Add an ACL
782 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200783 rules.append(
784 self.create_rule(
785 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
786 )
787 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100788 # deny ip any any in the end
789 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
790
791 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100792 self.apply_rules(rules, "permit ipv4 tcp")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100793
794 # Traffic should still pass
795 self.run_verify_test(self.IP, self.IPV4, self.proto[self.IP][self.TCP])
796
797 self.logger.info("ACLP_TEST_FINISH_0008")
798
799 def test_0009_tcp_permit_v6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200800 """permit TCPv6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100801 self.logger.info("ACLP_TEST_START_0009")
802
803 # Add an ACL
804 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200805 rules.append(
806 self.create_rule(
807 self.IPV6, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
808 )
809 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100810 # deny ip any any in the end
811 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
812
813 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100814 self.apply_rules(rules, "permit ip6 tcp")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100815
816 # Traffic should still pass
817 self.run_verify_test(self.IP, self.IPV6, self.proto[self.IP][self.TCP])
818
819 self.logger.info("ACLP_TEST_FINISH_0008")
820
821 def test_0010_udp_permit_v4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200822 """permit UDPv4"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100823 self.logger.info("ACLP_TEST_START_0010")
824
825 # Add an ACL
826 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200827 rules.append(
828 self.create_rule(
829 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
830 )
831 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100832 # deny ip any any in the end
833 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
834
835 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100836 self.apply_rules(rules, "permit ipv udp")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100837
838 # Traffic should still pass
839 self.run_verify_test(self.IP, self.IPV4, self.proto[self.IP][self.UDP])
840
841 self.logger.info("ACLP_TEST_FINISH_0010")
842
843 def test_0011_udp_permit_v6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200844 """permit UDPv6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100845 self.logger.info("ACLP_TEST_START_0011")
846
847 # Add an ACL
848 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200849 rules.append(
850 self.create_rule(
851 self.IPV6, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
852 )
853 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100854 # deny ip any any in the end
855 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
856
857 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100858 self.apply_rules(rules, "permit ip6 udp")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100859
860 # Traffic should still pass
861 self.run_verify_test(self.IP, self.IPV6, self.proto[self.IP][self.UDP])
862
863 self.logger.info("ACLP_TEST_FINISH_0011")
864
865 def test_0012_tcp_deny(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200866 """deny TCPv4/v6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100867 self.logger.info("ACLP_TEST_START_0012")
868
869 # Add an ACL
870 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200871 rules.append(
872 self.create_rule(
873 self.IPV4, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
874 )
875 )
876 rules.append(
877 self.create_rule(
878 self.IPV6, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
879 )
880 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100881 # permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200882 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
883 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100884
885 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100886 self.apply_rules(rules, "deny ip4/ip6 tcp")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100887
888 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200889 self.run_verify_negat_test(
890 self.IP, self.IPRANDOM, self.proto[self.IP][self.TCP]
891 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100892
893 self.logger.info("ACLP_TEST_FINISH_0012")
894
895 def test_0013_udp_deny(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200896 """deny UDPv4/v6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100897 self.logger.info("ACLP_TEST_START_0013")
898
899 # Add an ACL
900 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200901 rules.append(
902 self.create_rule(
903 self.IPV4, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
904 )
905 )
906 rules.append(
907 self.create_rule(
908 self.IPV6, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
909 )
910 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100911 # permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200912 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
913 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +0100914
915 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100916 self.apply_rules(rules, "deny ip4/ip6 udp")
Pavel Kotucek59dda062017-03-02 15:22:47 +0100917
918 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200919 self.run_verify_negat_test(
920 self.IP, self.IPRANDOM, self.proto[self.IP][self.UDP]
921 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100922
923 self.logger.info("ACLP_TEST_FINISH_0013")
924
925 def test_0014_acl_dump(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200926 """verify add/dump acls"""
Pavel Kotucek59dda062017-03-02 15:22:47 +0100927 self.logger.info("ACLP_TEST_START_0014")
928
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200929 r = [
930 [self.IPV4, self.PERMIT, 1234, self.proto[self.IP][self.TCP]],
931 [self.IPV4, self.PERMIT, 2345, self.proto[self.IP][self.UDP]],
932 [self.IPV4, self.PERMIT, 0, self.proto[self.IP][self.TCP]],
933 [self.IPV4, self.PERMIT, 0, self.proto[self.IP][self.UDP]],
934 [self.IPV4, self.PERMIT, 5, self.proto[self.ICMP][self.ICMPv4]],
935 [self.IPV6, self.PERMIT, 4321, self.proto[self.IP][self.TCP]],
936 [self.IPV6, self.PERMIT, 5432, self.proto[self.IP][self.UDP]],
937 [self.IPV6, self.PERMIT, 0, self.proto[self.IP][self.TCP]],
938 [self.IPV6, self.PERMIT, 0, self.proto[self.IP][self.UDP]],
939 [self.IPV6, self.PERMIT, 6, self.proto[self.ICMP][self.ICMPv6]],
940 [self.IPV4, self.DENY, self.PORTS_ALL, 0],
941 [self.IPV4, self.DENY, 1234, self.proto[self.IP][self.TCP]],
942 [self.IPV4, self.DENY, 2345, self.proto[self.IP][self.UDP]],
943 [self.IPV4, self.DENY, 5, self.proto[self.ICMP][self.ICMPv4]],
944 [self.IPV6, self.DENY, 4321, self.proto[self.IP][self.TCP]],
945 [self.IPV6, self.DENY, 5432, self.proto[self.IP][self.UDP]],
946 [self.IPV6, self.DENY, 6, self.proto[self.ICMP][self.ICMPv6]],
947 [self.IPV6, self.DENY, self.PORTS_ALL, 0],
948 ]
Pavel Kotucek59dda062017-03-02 15:22:47 +0100949
950 # Add and verify new ACLs
951 rules = []
952 for i in range(len(r)):
953 rules.append(self.create_rule(r[i][0], r[i][1], r[i][2], r[i][3]))
954
Jakub Grajciar2f8cd912020-03-27 06:55:06 +0100955 acl = VppAcl(self, rules=rules)
956 acl.add_vpp_config()
957 result = acl.dump()
Pavel Kotucek59dda062017-03-02 15:22:47 +0100958
959 i = 0
960 for drules in result:
961 for dr in drules.r:
Pavel Kotucek59dda062017-03-02 15:22:47 +0100962 self.assertEqual(dr.is_permit, r[i][1])
963 self.assertEqual(dr.proto, r[i][3])
964
965 if r[i][2] > 0:
966 self.assertEqual(dr.srcport_or_icmptype_first, r[i][2])
967 else:
968 if r[i][2] < 0:
969 self.assertEqual(dr.srcport_or_icmptype_first, 0)
970 self.assertEqual(dr.srcport_or_icmptype_last, 65535)
971 else:
972 if dr.proto == self.proto[self.IP][self.TCP]:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200973 self.assertGreater(
974 dr.srcport_or_icmptype_first, self.tcp_sport_from - 1
975 )
976 self.assertLess(
977 dr.srcport_or_icmptype_first, self.tcp_sport_to + 1
978 )
979 self.assertGreater(
980 dr.dstport_or_icmpcode_last, self.tcp_dport_from - 1
981 )
982 self.assertLess(
983 dr.dstport_or_icmpcode_last, self.tcp_dport_to + 1
984 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100985 elif dr.proto == self.proto[self.IP][self.UDP]:
Klement Sekerad9b0c6f2022-04-26 19:02:15 +0200986 self.assertGreater(
987 dr.srcport_or_icmptype_first, self.udp_sport_from - 1
988 )
989 self.assertLess(
990 dr.srcport_or_icmptype_first, self.udp_sport_to + 1
991 )
992 self.assertGreater(
993 dr.dstport_or_icmpcode_last, self.udp_dport_from - 1
994 )
995 self.assertLess(
996 dr.dstport_or_icmpcode_last, self.udp_dport_to + 1
997 )
Pavel Kotucek59dda062017-03-02 15:22:47 +0100998 i += 1
999
1000 self.logger.info("ACLP_TEST_FINISH_0014")
1001
1002 def test_0015_tcp_permit_port_v4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001003 """permit single TCPv4"""
Pavel Kotucek59dda062017-03-02 15:22:47 +01001004 self.logger.info("ACLP_TEST_START_0015")
1005
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001006 port = random.randint(16384, 65535)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001007 # Add an ACL
1008 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001009 rules.append(
1010 self.create_rule(
1011 self.IPV4, self.PERMIT, port, self.proto[self.IP][self.TCP]
1012 )
1013 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001014 # deny ip any any in the end
1015 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1016
1017 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001018 self.apply_rules(rules, "permit ip4 tcp %d" % port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001019
1020 # Traffic should still pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001021 self.run_verify_test(self.IP, self.IPV4, self.proto[self.IP][self.TCP], port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001022
1023 self.logger.info("ACLP_TEST_FINISH_0015")
1024
1025 def test_0016_udp_permit_port_v4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001026 """permit single UDPv4"""
Pavel Kotucek59dda062017-03-02 15:22:47 +01001027 self.logger.info("ACLP_TEST_START_0016")
1028
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001029 port = random.randint(16384, 65535)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001030 # Add an ACL
1031 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001032 rules.append(
1033 self.create_rule(
1034 self.IPV4, self.PERMIT, port, self.proto[self.IP][self.UDP]
1035 )
1036 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001037 # deny ip any any in the end
1038 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1039
1040 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001041 self.apply_rules(rules, "permit ip4 tcp %d" % port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001042
1043 # Traffic should still pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001044 self.run_verify_test(self.IP, self.IPV4, self.proto[self.IP][self.UDP], port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001045
1046 self.logger.info("ACLP_TEST_FINISH_0016")
1047
1048 def test_0017_tcp_permit_port_v6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001049 """permit single TCPv6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +01001050 self.logger.info("ACLP_TEST_START_0017")
1051
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001052 port = random.randint(16384, 65535)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001053 # Add an ACL
1054 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001055 rules.append(
1056 self.create_rule(
1057 self.IPV6, self.PERMIT, port, self.proto[self.IP][self.TCP]
1058 )
1059 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001060 # deny ip any any in the end
1061 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
1062
1063 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001064 self.apply_rules(rules, "permit ip4 tcp %d" % port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001065
1066 # Traffic should still pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001067 self.run_verify_test(self.IP, self.IPV6, self.proto[self.IP][self.TCP], port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001068
1069 self.logger.info("ACLP_TEST_FINISH_0017")
1070
1071 def test_0018_udp_permit_port_v6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001072 """permit single UDPv6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +01001073 self.logger.info("ACLP_TEST_START_0018")
1074
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001075 port = random.randint(16384, 65535)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001076 # Add an ACL
1077 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001078 rules.append(
1079 self.create_rule(
1080 self.IPV6, self.PERMIT, port, self.proto[self.IP][self.UDP]
1081 )
1082 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001083 # deny ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001084 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +01001085
1086 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001087 self.apply_rules(rules, "permit ip4 tcp %d" % port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001088
1089 # Traffic should still pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001090 self.run_verify_test(self.IP, self.IPV6, self.proto[self.IP][self.UDP], port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001091
1092 self.logger.info("ACLP_TEST_FINISH_0018")
1093
1094 def test_0019_udp_deny_port(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001095 """deny single TCPv4/v6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +01001096 self.logger.info("ACLP_TEST_START_0019")
1097
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001098 port = random.randint(16384, 65535)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001099 # Add an ACL
1100 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001101 rules.append(
1102 self.create_rule(self.IPV4, self.DENY, port, self.proto[self.IP][self.TCP])
1103 )
1104 rules.append(
1105 self.create_rule(self.IPV6, self.DENY, port, self.proto[self.IP][self.TCP])
1106 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001107 # Permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001108 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
1109 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +01001110
1111 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001112 self.apply_rules(rules, "deny ip4/ip6 udp %d" % port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001113
1114 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001115 self.run_verify_negat_test(
1116 self.IP, self.IPRANDOM, self.proto[self.IP][self.TCP], port
1117 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001118
1119 self.logger.info("ACLP_TEST_FINISH_0019")
1120
1121 def test_0020_udp_deny_port(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001122 """deny single UDPv4/v6"""
Pavel Kotucek59dda062017-03-02 15:22:47 +01001123 self.logger.info("ACLP_TEST_START_0020")
1124
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001125 port = random.randint(16384, 65535)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001126 # Add an ACL
1127 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001128 rules.append(
1129 self.create_rule(self.IPV4, self.DENY, port, self.proto[self.IP][self.UDP])
1130 )
1131 rules.append(
1132 self.create_rule(self.IPV6, self.DENY, port, self.proto[self.IP][self.UDP])
1133 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001134 # Permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001135 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
1136 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Pavel Kotucek59dda062017-03-02 15:22:47 +01001137
1138 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001139 self.apply_rules(rules, "deny ip4/ip6 udp %d" % port)
Pavel Kotucek59dda062017-03-02 15:22:47 +01001140
1141 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001142 self.run_verify_negat_test(
1143 self.IP, self.IPRANDOM, self.proto[self.IP][self.UDP], port
1144 )
Pavel Kotucek59dda062017-03-02 15:22:47 +01001145
1146 self.logger.info("ACLP_TEST_FINISH_0020")
1147
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001148 def test_0021_udp_deny_port_verify_fragment_deny(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001149 """deny single UDPv4/v6, permit ip any, verify non-initial fragment
Chris Luked0421942018-04-10 15:19:54 -04001150 blocked
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001151 """
1152 self.logger.info("ACLP_TEST_START_0021")
1153
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001154 port = random.randint(16384, 65535)
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001155 # Add an ACL
1156 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001157 rules.append(
1158 self.create_rule(self.IPV4, self.DENY, port, self.proto[self.IP][self.UDP])
1159 )
1160 rules.append(
1161 self.create_rule(self.IPV6, self.DENY, port, self.proto[self.IP][self.UDP])
1162 )
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001163 # deny ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001164 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
1165 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001166
1167 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001168 self.apply_rules(rules, "deny ip4/ip6 udp %d" % port)
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001169
1170 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001171 self.run_verify_negat_test(
1172 self.IP, self.IPRANDOM, self.proto[self.IP][self.UDP], port, True
1173 )
Andrew Yourtchenkod1b05642017-04-04 14:10:40 +00001174
1175 self.logger.info("ACLP_TEST_FINISH_0021")
1176
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001177 def test_0022_zero_length_udp_ipv4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001178 """VPP-687 zero length udp ipv4 packet"""
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001179 self.logger.info("ACLP_TEST_START_0022")
1180
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001181 port = random.randint(16384, 65535)
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001182 # Add an ACL
1183 rules = []
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001184 rules.append(
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001185 self.create_rule(
1186 self.IPV4, self.PERMIT, port, self.proto[self.IP][self.UDP]
1187 )
1188 )
1189 # deny ip any any in the end
1190 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001191
1192 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001193 self.apply_rules(rules, "permit empty udp ip4 %d" % port)
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001194
1195 # Traffic should still pass
1196 # Create incoming packet streams for packet-generator interfaces
1197 pkts_cnt = 0
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001198 pkts = self.create_stream(
1199 self.pg0,
1200 self.pg_if_packet_sizes,
1201 self.IP,
1202 self.IPV4,
1203 self.proto[self.IP][self.UDP],
1204 port,
1205 False,
1206 False,
1207 )
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001208 if len(pkts) > 0:
1209 self.pg0.add_stream(pkts)
1210 pkts_cnt += len(pkts)
1211
1212 # Enable packet capture and start packet sendingself.IPV
1213 self.pg_enable_capture(self.pg_interfaces)
1214 self.pg_start()
1215
1216 self.pg1.get_capture(pkts_cnt)
1217
1218 self.logger.info("ACLP_TEST_FINISH_0022")
1219
1220 def test_0023_zero_length_udp_ipv6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001221 """VPP-687 zero length udp ipv6 packet"""
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001222 self.logger.info("ACLP_TEST_START_0023")
1223
Andrew Yourtchenkoec574ff2019-10-03 07:55:52 +00001224 port = random.randint(16384, 65535)
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001225 # Add an ACL
1226 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001227 rules.append(
1228 self.create_rule(
1229 self.IPV6, self.PERMIT, port, self.proto[self.IP][self.UDP]
1230 )
1231 )
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001232 # deny ip any any in the end
1233 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
1234
1235 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001236 self.apply_rules(rules, "permit empty udp ip6 %d" % port)
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001237
1238 # Traffic should still pass
1239 # Create incoming packet streams for packet-generator interfaces
1240 pkts_cnt = 0
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001241 pkts = self.create_stream(
1242 self.pg0,
1243 self.pg_if_packet_sizes,
1244 self.IP,
1245 self.IPV6,
1246 self.proto[self.IP][self.UDP],
1247 port,
1248 False,
1249 False,
1250 )
Pavel Kotuceke7b67342017-04-18 13:12:20 +02001251 if len(pkts) > 0:
1252 self.pg0.add_stream(pkts)
1253 pkts_cnt += len(pkts)
1254
1255 # Enable packet capture and start packet sendingself.IPV
1256 self.pg_enable_capture(self.pg_interfaces)
1257 self.pg_start()
1258
1259 # Verify outgoing packet streams per packet-generator interface
1260 self.pg1.get_capture(pkts_cnt)
1261
1262 self.logger.info("ACLP_TEST_FINISH_0023")
1263
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001264 def test_0108_tcp_permit_v4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001265 """permit TCPv4 + non-match range"""
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001266 self.logger.info("ACLP_TEST_START_0108")
1267
1268 # Add an ACL
1269 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001270 rules.append(
1271 self.create_rule(
1272 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1273 )
1274 )
1275 rules.append(
1276 self.create_rule(
1277 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1278 )
1279 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001280 # deny ip any any in the end
1281 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1282
1283 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001284 self.apply_rules(rules, "permit ipv4 tcp")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001285
1286 # Traffic should still pass
1287 self.run_verify_test(self.IP, self.IPV4, self.proto[self.IP][self.TCP])
1288
1289 self.logger.info("ACLP_TEST_FINISH_0108")
1290
1291 def test_0109_tcp_permit_v6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001292 """permit TCPv6 + non-match range"""
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001293 self.logger.info("ACLP_TEST_START_0109")
1294
1295 # Add an ACL
1296 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001297 rules.append(
1298 self.create_rule(
1299 self.IPV6, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1300 )
1301 )
1302 rules.append(
1303 self.create_rule(
1304 self.IPV6, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1305 )
1306 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001307 # deny ip any any in the end
1308 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
1309
1310 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001311 self.apply_rules(rules, "permit ip6 tcp")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001312
1313 # Traffic should still pass
1314 self.run_verify_test(self.IP, self.IPV6, self.proto[self.IP][self.TCP])
1315
1316 self.logger.info("ACLP_TEST_FINISH_0109")
1317
1318 def test_0110_udp_permit_v4(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001319 """permit UDPv4 + non-match range"""
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001320 self.logger.info("ACLP_TEST_START_0110")
1321
1322 # Add an ACL
1323 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001324 rules.append(
1325 self.create_rule(
1326 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.UDP]
1327 )
1328 )
1329 rules.append(
1330 self.create_rule(
1331 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
1332 )
1333 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001334 # deny ip any any in the end
1335 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1336
1337 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001338 self.apply_rules(rules, "permit ipv4 udp")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001339
1340 # Traffic should still pass
1341 self.run_verify_test(self.IP, self.IPV4, self.proto[self.IP][self.UDP])
1342
1343 self.logger.info("ACLP_TEST_FINISH_0110")
1344
1345 def test_0111_udp_permit_v6(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001346 """permit UDPv6 + non-match range"""
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001347 self.logger.info("ACLP_TEST_START_0111")
1348
1349 # Add an ACL
1350 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001351 rules.append(
1352 self.create_rule(
1353 self.IPV6, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.UDP]
1354 )
1355 )
1356 rules.append(
1357 self.create_rule(
1358 self.IPV6, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
1359 )
1360 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001361 # deny ip any any in the end
1362 rules.append(self.create_rule(self.IPV6, self.DENY, self.PORTS_ALL, 0))
1363
1364 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001365 self.apply_rules(rules, "permit ip6 udp")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001366
1367 # Traffic should still pass
1368 self.run_verify_test(self.IP, self.IPV6, self.proto[self.IP][self.UDP])
1369
1370 self.logger.info("ACLP_TEST_FINISH_0111")
1371
1372 def test_0112_tcp_deny(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001373 """deny TCPv4/v6 + non-match range"""
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001374 self.logger.info("ACLP_TEST_START_0112")
1375
1376 # Add an ACL
1377 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001378 rules.append(
1379 self.create_rule(
1380 self.IPV4,
1381 self.PERMIT,
1382 self.PORTS_RANGE_2,
1383 self.proto[self.IP][self.TCP],
1384 )
1385 )
1386 rules.append(
1387 self.create_rule(
1388 self.IPV6,
1389 self.PERMIT,
1390 self.PORTS_RANGE_2,
1391 self.proto[self.IP][self.TCP],
1392 )
1393 )
1394 rules.append(
1395 self.create_rule(
1396 self.IPV4, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1397 )
1398 )
1399 rules.append(
1400 self.create_rule(
1401 self.IPV6, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1402 )
1403 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001404 # permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001405 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
1406 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001407
1408 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001409 self.apply_rules(rules, "deny ip4/ip6 tcp")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001410
1411 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001412 self.run_verify_negat_test(
1413 self.IP, self.IPRANDOM, self.proto[self.IP][self.TCP]
1414 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001415
1416 self.logger.info("ACLP_TEST_FINISH_0112")
1417
1418 def test_0113_udp_deny(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001419 """deny UDPv4/v6 + non-match range"""
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001420 self.logger.info("ACLP_TEST_START_0113")
1421
1422 # Add an ACL
1423 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001424 rules.append(
1425 self.create_rule(
1426 self.IPV4,
1427 self.PERMIT,
1428 self.PORTS_RANGE_2,
1429 self.proto[self.IP][self.UDP],
1430 )
1431 )
1432 rules.append(
1433 self.create_rule(
1434 self.IPV6,
1435 self.PERMIT,
1436 self.PORTS_RANGE_2,
1437 self.proto[self.IP][self.UDP],
1438 )
1439 )
1440 rules.append(
1441 self.create_rule(
1442 self.IPV4, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
1443 )
1444 )
1445 rules.append(
1446 self.create_rule(
1447 self.IPV6, self.DENY, self.PORTS_RANGE, self.proto[self.IP][self.UDP]
1448 )
1449 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001450 # permit ip any any in the end
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001451 rules.append(self.create_rule(self.IPV4, self.PERMIT, self.PORTS_ALL, 0))
1452 rules.append(self.create_rule(self.IPV6, self.PERMIT, self.PORTS_ALL, 0))
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001453
1454 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001455 self.apply_rules(rules, "deny ip4/ip6 udp")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001456
1457 # Traffic should not pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001458 self.run_verify_negat_test(
1459 self.IP, self.IPRANDOM, self.proto[self.IP][self.UDP]
1460 )
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001461
1462 self.logger.info("ACLP_TEST_FINISH_0113")
1463
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001464 def test_0300_tcp_permit_v4_etype_aaaa(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001465 """permit TCPv4, send 0xAAAA etype"""
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001466 self.logger.info("ACLP_TEST_START_0300")
1467
1468 # Add an ACL
1469 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001470 rules.append(
1471 self.create_rule(
1472 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1473 )
1474 )
1475 rules.append(
1476 self.create_rule(
1477 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1478 )
1479 )
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001480 # deny ip any any in the end
1481 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1482
1483 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001484 self.apply_rules(rules, "permit ipv4 tcp")
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001485
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001486 # Traffic should still pass also for an odd ethertype
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001487 self.run_verify_test(
1488 self.IP, self.IPV4, self.proto[self.IP][self.TCP], 0, False, True, 0xAAAA
1489 )
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001490 self.logger.info("ACLP_TEST_FINISH_0300")
1491
1492 def test_0305_tcp_permit_v4_etype_blacklist_aaaa(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001493 """permit TCPv4, whitelist 0x0BBB ethertype, send 0xAAAA-blocked"""
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001494 self.logger.info("ACLP_TEST_START_0305")
1495
1496 # Add an ACL
1497 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001498 rules.append(
1499 self.create_rule(
1500 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1501 )
1502 )
1503 rules.append(
1504 self.create_rule(
1505 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1506 )
1507 )
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001508 # deny ip any any in the end
1509 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1510
1511 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001512 self.apply_rules(rules, "permit ipv4 tcp")
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001513 # whitelist the 0xbbbb etype - so the 0xaaaa should be blocked
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001514 self.etype_whitelist([0xBBB], 1)
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001515
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001516 # The oddball ethertype should be blocked
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001517 self.run_verify_negat_test(
1518 self.IP, self.IPV4, self.proto[self.IP][self.TCP], 0, False, 0xAAAA
1519 )
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001520
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001521 # remove the whitelist
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001522 self.etype_whitelist([], 0, add=False)
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001523
1524 self.logger.info("ACLP_TEST_FINISH_0305")
1525
1526 def test_0306_tcp_permit_v4_etype_blacklist_aaaa(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001527 """permit TCPv4, whitelist 0x0BBB ethertype, send 0x0BBB - pass"""
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001528 self.logger.info("ACLP_TEST_START_0306")
1529
1530 # Add an ACL
1531 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001532 rules.append(
1533 self.create_rule(
1534 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1535 )
1536 )
1537 rules.append(
1538 self.create_rule(
1539 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1540 )
1541 )
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001542 # deny ip any any in the end
1543 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1544
1545 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001546 self.apply_rules(rules, "permit ipv4 tcp")
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001547 # whitelist the 0xbbbb etype - so the 0xaaaa should be blocked
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001548 self.etype_whitelist([0xBBB], 1)
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001549
1550 # The whitelisted traffic, should pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001551 self.run_verify_test(
1552 self.IP, self.IPV4, self.proto[self.IP][self.TCP], 0, False, True, 0x0BBB
1553 )
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001554
1555 # remove the whitelist, the previously blocked 0xAAAA should pass now
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001556 self.etype_whitelist([], 0, add=False)
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001557
1558 self.logger.info("ACLP_TEST_FINISH_0306")
1559
1560 def test_0307_tcp_permit_v4_etype_blacklist_aaaa(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001561 """permit TCPv4, whitelist 0x0BBB, remove, send 0xAAAA - pass"""
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001562 self.logger.info("ACLP_TEST_START_0307")
1563
1564 # Add an ACL
1565 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001566 rules.append(
1567 self.create_rule(
1568 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1569 )
1570 )
1571 rules.append(
1572 self.create_rule(
1573 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1574 )
1575 )
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001576 # deny ip any any in the end
1577 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1578
1579 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001580 self.apply_rules(rules, "permit ipv4 tcp")
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001581
1582 # whitelist the 0xbbbb etype - so the 0xaaaa should be blocked
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001583 self.etype_whitelist([0xBBB], 1)
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001584 # remove the whitelist, the previously blocked 0xAAAA should pass now
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001585 self.etype_whitelist([], 0, add=False)
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001586
1587 # The whitelisted traffic, should pass
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001588 self.run_verify_test(
1589 self.IP, self.IPV4, self.proto[self.IP][self.TCP], 0, False, True, 0xAAAA
1590 )
Andrew Yourtchenkoc43b3f92018-02-06 17:42:32 +01001591
Andrew Yourtchenko7ff74532018-10-06 09:24:28 +02001592 self.logger.info("ACLP_TEST_FINISH_0306")
Andrew Yourtchenko6be72cd2017-08-10 17:02:58 +02001593
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +01001594 def test_0315_del_intf(self):
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001595 """apply an acl and delete the interface"""
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +01001596 self.logger.info("ACLP_TEST_START_0315")
1597
1598 # Add an ACL
1599 rules = []
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001600 rules.append(
1601 self.create_rule(
1602 self.IPV4, self.DENY, self.PORTS_RANGE_2, self.proto[self.IP][self.TCP]
1603 )
1604 )
1605 rules.append(
1606 self.create_rule(
1607 self.IPV4, self.PERMIT, self.PORTS_RANGE, self.proto[self.IP][self.TCP]
1608 )
1609 )
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +01001610 # deny ip any any in the end
1611 rules.append(self.create_rule(self.IPV4, self.DENY, self.PORTS_ALL, 0))
1612
1613 # create an interface
1614 intf = []
Klement Sekerabeaded52018-06-24 10:30:37 +02001615 intf.append(VppLoInterface(self))
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +01001616
1617 # Apply rules
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001618 self.apply_rules_to(rules, "permit ipv4 tcp", intf[0].sw_if_index)
Andrew Yourtchenkode3682f2018-03-23 10:38:46 +01001619
1620 # Remove the interface
1621 intf[0].remove_vpp_config()
1622
1623 self.logger.info("ACLP_TEST_FINISH_0315")
1624
Jakub Grajciar2f8cd912020-03-27 06:55:06 +01001625
Klement Sekerad9b0c6f2022-04-26 19:02:15 +02001626if __name__ == "__main__":
Pavel Kotucek59dda062017-03-02 15:22:47 +01001627 unittest.main(testRunner=VppTestRunner)