xref: /freebsd/tests/sys/netpfil/pf/pass_block.sh (revision fe2494903422ba3b924eba82cb63a6a9188fad7a)
1# $FreeBSD$
2
3. $(atf_get_srcdir)/utils.subr
4
5atf_test_case "v4" "cleanup"
6v4_head()
7{
8	atf_set descr 'Basic pass/block test for IPv4'
9	atf_set require.user root
10}
11
12v4_body()
13{
14	pft_init
15
16	epair=$(pft_mkepair)
17	ifconfig ${epair}a 192.0.2.1/24 up
18
19	# Set up a simple jail with one interface
20	pft_mkjail alcatraz ${epair}b
21	jexec alcatraz ifconfig ${epair}b 192.0.2.2/24 up
22
23	# Trivial ping to the jail, without pf
24	atf_check -s exit:0 -o ignore ping -c 1 -t 1 192.0.2.2
25
26	# pf without policy will let us ping
27	jexec alcatraz pfctl -e
28	atf_check -s exit:0 -o ignore ping -c 1 -t 1 192.0.2.2
29
30	# Block everything
31	pft_set_rules alcatraz "block in"
32	atf_check -s exit:2 -o ignore ping -c 1 -t 1 192.0.2.2
33
34	# Block everything but ICMP
35	pft_set_rules alcatraz "block in" "pass in proto icmp"
36	atf_check -s exit:0 -o ignore ping -c 1 -t 1 192.0.2.2
37}
38
39v4_cleanup()
40{
41	pft_cleanup
42}
43
44atf_test_case "v6" "cleanup"
45v6_head()
46{
47	atf_set descr 'Basic pass/block test for IPv6'
48	atf_set require.user root
49}
50
51v6_body()
52{
53	pft_init
54
55	epair=$(pft_mkepair)
56	ifconfig ${epair}a inet6 2001:db8:42::1/64 up no_dad
57
58	# Set up a simple jail with one interface
59	pft_mkjail alcatraz ${epair}b
60	jexec alcatraz ifconfig ${epair}b inet6 2001:db8:42::2/64 up no_dad
61
62	# Trivial ping to the jail, without pf
63	atf_check -s exit:0 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
64
65	# pf without policy will let us ping
66	jexec alcatraz pfctl -e
67	atf_check -s exit:0 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
68
69	# Block everything
70	pft_set_rules alcatraz "block in"
71	atf_check -s exit:2 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
72
73	# Block everything but ICMP
74	pft_set_rules alcatraz "block in" "pass in proto icmp6"
75	atf_check -s exit:0 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
76
77	# Allowing ICMPv4 does not allow ICMPv6
78	pft_set_rules alcatraz "block in" "pass in proto icmp"
79	atf_check -s exit:2 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
80}
81
82v6_cleanup()
83{
84	pft_cleanup
85}
86
87atf_test_case "noalias" "cleanup"
88noalias_head()
89{
90	atf_set descr 'Test the :0 noalias option'
91	atf_set require.user root
92}
93
94noalias_body()
95{
96	pft_init
97
98	epair=$(pft_mkepair)
99	ifconfig ${epair}a inet6 2001:db8:42::1/64 up no_dad
100
101	pft_mkjail alcatraz ${epair}b
102	jexec alcatraz ifconfig ${epair}b inet6 2001:db8:42::2/64 up no_dad
103
104	linklocaladdr=$(jexec alcatraz ifconfig ${epair}b inet6 \
105		| grep %${epair}b \
106		| awk '{ print $2; }' \
107		| cut -d % -f 1)
108
109	# Sanity check
110	atf_check -s exit:0 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
111	atf_check -s exit:0 -o ignore ping6 -c 1 -x 1 ${linklocaladdr}%${epair}a
112
113	jexec alcatraz pfctl -e
114	pft_set_rules alcatraz "block out inet6 from (epair0b:0) to any"
115
116	atf_check -s exit:2 -o ignore ping6 -c 1 -x 1 2001:db8:42::2
117
118	# We should still be able to ping the link-local address
119	atf_check -s exit:0 -o ignore ping6 -c 1 -x 1 ${linklocaladdr}%${epair}a
120
121	pft_set_rules alcatraz "block out inet6 from (epair0b) to any"
122
123	# We cannot ping to the link-local address
124	atf_check -s exit:2 -o ignore ping6 -c 1 -x 1 ${linklocaladdr}%${epair}a
125}
126
127noalias_cleanup()
128{
129	pft_cleanup
130}
131
132atf_init_test_cases()
133{
134	atf_add_test_case "v4"
135	atf_add_test_case "v6"
136	atf_add_test_case "noalias"
137}
138