summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2026-01-12 13:49:54 +0000
committerMark Johnston <markj@FreeBSD.org>2026-01-12 15:34:43 +0000
commit74999aac5effb9b32d12f413ef51e87b15c8a0d8 (patch)
tree42e896f6452a340c7540b7355120d50e89515823 /tests
parentfb08f80eaf90eb7ace202d8604634fc181be8980 (diff)
in6: Modify address prefix lifetimes when updating address lifetimes
When one uses SIOCAIFADDR_IN6 to add a v6 address, it's possible to set the preferred and valid lifetimes of the address. If the address already exists, this ioctl will recalculate and update the expiry times based on the provided timestamps. When adding a new address, the lifetimes are inherited by the prefix as well, but only if we create a new prefix. If the prefix already exists, as it will in the case where an address is being updated rather than being added, we do not touch the prefix lifetimes at all. This means that the original address lifetime still applies to the route associated with that prefix, so when the prefix expires, the route goes away. This behaviour doesn't make a lot of sense: if the admin updates an address lifetime, we should ensure that the prefix lifetime is updated too. Make that change, ensuring that we do not shorten the prefix lifetime, as the prefix might be shared among multiple interface addresses. Add a regression test. Co-authored by: Franco Fichtner <franco@opnsense.org> Reviewed by: pouria, zlei, ae MFC after: 2 weeks Sponsored by: OPNsense Sponsored by: Klara, Inc. Differential Revision: https://reviews.freebsd.org/D54562
Diffstat (limited to 'tests')
-rwxr-xr-xtests/sys/netinet6/ndp.sh76
1 files changed, 76 insertions, 0 deletions
diff --git a/tests/sys/netinet6/ndp.sh b/tests/sys/netinet6/ndp.sh
index 3464ac59c898..8a16316740be 100755
--- a/tests/sys/netinet6/ndp.sh
+++ b/tests/sys/netinet6/ndp.sh
@@ -287,6 +287,81 @@ ndp_prefix_lifetime_cleanup() {
vnet_cleanup
}
+atf_test_case "ndp_prefix_lifetime_extend"
+ndp_prefix_lifetime_extend_head() {
+ atf_set descr 'Test prefix lifetime updates via ifconfig'
+ atf_set require.user root
+ atf_set require.progs jq
+}
+
+get_prefix_attr() {
+ local prefix=$1
+ local attr=$2
+
+ ndp -p --libxo json | \
+ jq -r '.ndp.["prefix-list"][] |
+ select(.prefix == "'${prefix}'") | .["'${attr}'"]'
+}
+
+# Given a prefix, return its expiry time in seconds.
+prefix_expiry() {
+ get_prefix_attr $1 "expires_sec"
+}
+
+# Given a prefix, return its valid and preferred lifetimes.
+prefix_lifetimes() {
+ local p v
+
+ v=$(get_prefix_attr $1 "valid-lifetime")
+ p=$(get_prefix_attr $1 "preferred-lifetime")
+ echo $v $p
+}
+
+ndp_prefix_lifetime_extend_body() {
+ local epair ex1 ex2 ex3 prefix pltime vltime
+
+ atf_check -o save:epair ifconfig epair create
+ epair=$(cat epair)
+ atf_check ifconfig ${epair} up
+
+ prefix="2001:db8:ffff:1000::"
+
+ atf_check ifconfig ${epair} inet6 ${prefix}1/64 pltime 5 vltime 10
+ t=$(prefix_lifetimes ${prefix}/64)
+ if [ "${t}" != "10 5" ]; then
+ atf_fail "Unexpected lifetimes: ${t}"
+ fi
+ ex1=$(prefix_expiry ${prefix}/64)
+ if [ "${ex1}" -gt 10 ]; then
+ atf_fail "Unexpected expiry time: ${ex1}"
+ fi
+
+ # Double the address lifetime and verify that the prefix is
+ # updated.
+ atf_check ifconfig ${epair} inet6 ${prefix}1/64 pltime 10 vltime 20
+ t=$(prefix_lifetimes ${prefix}/64)
+ if [ "${t}" != "20 10" ]; then
+ atf_fail "Unexpected lifetimes: ${t}"
+ fi
+ ex2=$(prefix_expiry ${prefix}/64)
+ if [ "${ex2}" -le "${ex1}" ]; then
+ atf_fail "Expiry time was not extended: ${ex1} <= ${ex2}"
+ fi
+
+ # Add a second address from the same prefix with a shorter
+ # lifetime, and make sure that the prefix lifetime is not
+ # shortened.
+ atf_check ifconfig ${epair} inet6 ${prefix}2/64 pltime 5 vltime 10
+ t=$(prefix_lifetimes ${prefix}/64)
+ if [ "${t}" != "20 10" ]; then
+ atf_fail "Unexpected lifetimes: ${t}"
+ fi
+ ex3=$(prefix_expiry ${prefix}/64)
+ if [ "${ex3}" -lt "${ex2}" ]; then
+ atf_fail "Expiry time was shortened: ${ex2} <= ${ex3}"
+ fi
+}
+
atf_init_test_cases()
{
atf_add_test_case "ndp_add_gu_success"
@@ -294,4 +369,5 @@ atf_init_test_cases()
atf_add_test_case "ndp_slaac_default_route"
atf_add_test_case "ndp_prefix_len_mismatch"
atf_add_test_case "ndp_prefix_lifetime"
+ atf_add_test_case "ndp_prefix_lifetime_extend"
}