From 8fd1b633090ab39d4711ff093cc3d0be97a48e01 Mon Sep 17 00:00:00 2001 From: steiler Date: Thu, 29 Feb 2024 10:35:23 +0100 Subject: [PATCH] Link: Fix LinkByName with long (>15 char) name by using altnames --- link_linux.go | 3 +++ link_test.go | 74 +++++++++++++++++++++++---------------------------- 2 files changed, 37 insertions(+), 40 deletions(-) diff --git a/link_linux.go b/link_linux.go index 528c50f1..a2a4f4aa 100644 --- a/link_linux.go +++ b/link_linux.go @@ -1867,6 +1867,9 @@ func (h *Handle) LinkByName(name string) (Link, error) { req.AddData(attr) nameData := nl.NewRtAttr(unix.IFLA_IFNAME, nl.ZeroTerminated(name)) + if len(name) > 15 { + nameData = nl.NewRtAttr(unix.IFLA_ALT_IFNAME, nl.ZeroTerminated(name)) + } req.AddData(nameData) link, err := execGetLink(req) diff --git a/link_test.go b/link_test.go index 7841f529..cd652b52 100644 --- a/link_test.go +++ b/link_test.go @@ -10,6 +10,8 @@ import ( "net" "os" "os/exec" + "sort" + "strings" "syscall" "testing" "time" @@ -1899,14 +1901,15 @@ func TestLinkAltName(t *testing.T) { t.Fatal(err) } - err = LinkAddAltName(link, "altname") - if err != nil { - t.Fatalf("Could not add altname: %v", err) - } + altNames := []string{"altname", "altname2", "some_longer_altname"} + sort.Strings(altNames) + altNamesStr := strings.Join(altNames, ",") - err = LinkAddAltName(link, "altname2") - if err != nil { - t.Fatalf("Could not add altname: %v", err) + for _, altname := range altNames { + err = LinkAddAltName(link, altname) + if err != nil { + t.Fatalf("Could not add %s: %v", altname, err) + } } link, err = LinkByName("bar") @@ -1914,49 +1917,40 @@ func TestLinkAltName(t *testing.T) { t.Fatal(err) } - altNameExist := false - altName2Exist := false - for _, altName := range link.Attrs().AltNames { - if altName == "altname" { - altNameExist = true - } else if altName == "altname2" { - altName2Exist = true - } + sort.Strings(link.Attrs().AltNames) + linkAltNamesStr := strings.Join(link.Attrs().AltNames, ",") - } - if !altNameExist { - t.Fatal("Could not find altname") + if altNamesStr != linkAltNamesStr { + t.Fatalf("Expected %s AltNames, got %s", altNamesStr, linkAltNamesStr) } - if !altName2Exist { - t.Fatal("Could not find altname2") + for _, altname := range altNames { + link, err = LinkByName(altname) + if err != nil { + t.Fatal(err) + } } - link, err = LinkByName("altname") - if err != nil { - t.Fatal(err) - } + for idx, altName := range altNames { + err = LinkDelAltName(link, altName) + if err != nil { + t.Fatalf("Could not delete %s: %v", altName, err) + } - err = LinkDelAltName(link, "altname") - if err != nil { - t.Fatalf("Could not delete altname: %v", err) - } + link, err = LinkByName("bar") + if err != nil { + t.Fatal(err) + } - link, err = LinkByName("bar") - if err != nil { - t.Fatal(err) - } + sort.Strings(link.Attrs().AltNames) + linkAltNamesStr := strings.Join(link.Attrs().AltNames, ",") + altNamesStr := strings.Join(altNames[idx+1:], ",") - altNameExist = false - for _, altName := range link.Attrs().AltNames { - if altName == "altname" { - altNameExist = true - break + if linkAltNamesStr != altNamesStr { + t.Fatalf("Expected %s AltNames, got %s", altNamesStr, linkAltNamesStr) } } - if altNameExist { - t.Fatal("altname still exist") - } + } func TestLinkSetARP(t *testing.T) {