aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tests/sys/netpfil/pf/altq.sh45
1 files changed, 45 insertions, 0 deletions
diff --git a/tests/sys/netpfil/pf/altq.sh b/tests/sys/netpfil/pf/altq.sh
index 89da4c0deb6f..294c01e9f8bd 100644
--- a/tests/sys/netpfil/pf/altq.sh
+++ b/tests/sys/netpfil/pf/altq.sh
@@ -42,8 +42,53 @@ hfsc_cleanup()
altq_cleanup
}
+atf_test_case "match" "cleanup"
+match_head()
+{
+ atf_set descr 'Basic match keyword test'
+ atf_set require.user root
+}
+
+match_body()
+{
+ altq_init
+ is_altq_supported hfsc
+
+ epair=$(vnet_mkepair)
+ vnet_mkjail altq_match ${epair}b
+
+ ifconfig ${epair}a 192.0.2.1/24 up
+ jexec altq_match ifconfig ${epair}b 192.0.2.2/24 up
+
+ # Sanity check
+ atf_check -s exit:0 -o ignore ping -i .1 -c 3 -s 1200 192.0.2.2
+
+ jexec altq_match pfctl -e
+ pft_set_rules altq_match \
+ "altq on ${epair}b bandwidth 100000000b hfsc queue { default, slow }" \
+ "queue default hfsc(default linkshare 80000000b)" \
+ "queue slow hfsc(linkshare 80b upperlimit 80b)" \
+ "match proto icmp queue slow" \
+ "pass"
+
+ # single ping succeeds just fine
+ atf_check -s exit:0 -o ignore ping -c 1 192.0.2.2
+
+ # "Saturate the link"
+ ping -i .1 -c 5 -s 1200 192.0.2.2
+
+ # We should now be hitting the limits and get this packet dropped.
+ atf_check -s exit:2 -o ignore ping -c 1 -s 1200 192.0.2.2
+}
+
+match_cleanup()
+{
+ altq_cleanup
+}
+
atf_init_test_cases()
{
atf_add_test_case "hfsc"
+ atf_add_test_case "match"
}