| // Copyright 2016 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| // +build solaris |
| |
| package lif |
| |
| import ( |
| "fmt" |
| "testing" |
| ) |
| |
| func (ll *Link) String() string { |
| return fmt.Sprintf("name=%s index=%d type=%d flags=%#x mtu=%d addr=%v", ll.Name, ll.Index, ll.Type, ll.Flags, ll.MTU, llAddr(ll.Addr)) |
| } |
| |
| type linkPack struct { |
| af int |
| lls []Link |
| } |
| |
| func linkPacks() ([]linkPack, error) { |
| var lastErr error |
| var lps []linkPack |
| for _, af := range [...]int{sysAF_UNSPEC, sysAF_INET, sysAF_INET6} { |
| lls, err := Links(af, "") |
| if err != nil { |
| lastErr = err |
| continue |
| } |
| lps = append(lps, linkPack{af: af, lls: lls}) |
| } |
| return lps, lastErr |
| } |
| |
| func TestLinks(t *testing.T) { |
| lps, err := linkPacks() |
| if len(lps) == 0 && err != nil { |
| t.Fatal(err) |
| } |
| for _, lp := range lps { |
| n := 0 |
| for _, sll := range lp.lls { |
| lls, err := Links(lp.af, sll.Name) |
| if err != nil { |
| t.Fatal(lp.af, sll.Name, err) |
| } |
| for _, ll := range lls { |
| if ll.Name != sll.Name || ll.Index != sll.Index { |
| t.Errorf("af=%s got %v; want %v", addrFamily(lp.af), &ll, &sll) |
| continue |
| } |
| t.Logf("af=%s name=%s %v", addrFamily(lp.af), sll.Name, &ll) |
| n++ |
| } |
| } |
| if n != len(lp.lls) { |
| t.Errorf("af=%s got %d; want %d", addrFamily(lp.af), n, len(lp.lls)) |
| continue |
| } |
| } |
| } |