]> git.proxmox.com Git - mirror_ubuntu-eoan-kernel.git/commitdiff
selftests: rtnetlink.sh: add test case for device ifalias
authorFlorian Westphal <fw@strlen.de>
Tue, 19 Sep 2017 12:42:17 +0000 (14:42 +0200)
committerDavid S. Miller <davem@davemloft.net>
Tue, 19 Sep 2017 22:30:33 +0000 (15:30 -0700)
Signed-off-by: Florian Westphal <fw@strlen.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
tools/testing/selftests/net/rtnetlink.sh

index 57b5ff5762403e0b00e3034aaab2804ee2cc3e73..4b48de565caef96cf0f4bd6aa79e01daa2619a45 100755 (executable)
@@ -15,6 +15,14 @@ check_err()
        fi
 }
 
+# same but inverted -- used when command must fail for test to pass
+check_fail()
+{
+       if [ $1 -eq 0 ]; then
+               ret=1
+       fi
+}
+
 kci_add_dummy()
 {
        ip link add name "$devdummy" type dummy
@@ -235,6 +243,54 @@ kci_test_addrlabel()
        echo "PASS: ipv6 addrlabel"
 }
 
+kci_test_ifalias()
+{
+       ret=0
+       namewant=$(uuidgen)
+       syspathname="/sys/class/net/$devdummy/ifalias"
+
+       ip link set dev "$devdummy" alias "$namewant"
+       check_err $?
+
+       if [ $ret -ne 0 ]; then
+               echo "FAIL: cannot set interface alias of $devdummy to $namewant"
+               return 1
+       fi
+
+       ip link show "$devdummy" | grep -q "alias $namewant"
+       check_err $?
+
+       if [ -r "$syspathname" ] ; then
+               read namehave < "$syspathname"
+               if [ "$namewant" != "$namehave" ]; then
+                       echo "FAIL: did set ifalias $namewant but got $namehave"
+                       return 1
+               fi
+
+               namewant=$(uuidgen)
+               echo "$namewant" > "$syspathname"
+               ip link show "$devdummy" | grep -q "alias $namewant"
+               check_err $?
+
+               # sysfs interface allows to delete alias again
+               echo "" > "$syspathname"
+
+               ip link show "$devdummy" | grep -q "alias $namewant"
+               check_fail $?
+
+               # re-add the alias -- kernel should free mem when dummy dev is removed
+               ip link set dev "$devdummy" alias "$namewant"
+               check_err $?
+       fi
+
+       if [ $ret -ne 0 ]; then
+               echo "FAIL: set interface alias $devdummy to $namewant"
+               return 1
+       fi
+
+       echo "PASS: set ifalias $namewant for $devdummy"
+}
+
 kci_test_rtnl()
 {
        kci_add_dummy
@@ -249,6 +305,7 @@ kci_test_rtnl()
        kci_test_gre
        kci_test_bridge
        kci_test_addrlabel
+       kci_test_ifalias
 
        kci_del_dummy
 }