| // 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. |
| |
| package route |
| |
| import ( |
| "syscall" |
| "testing" |
| ) |
| |
| func TestFetchAndParseRIBOnFreeBSD(t *testing.T) { |
| for _, typ := range []RIBType{syscall.NET_RT_IFMALIST} { |
| var lastErr error |
| var ms []Message |
| for _, af := range []int{syscall.AF_UNSPEC, syscall.AF_INET, syscall.AF_INET6} { |
| rs, err := fetchAndParseRIB(af, typ) |
| if err != nil { |
| lastErr = err |
| continue |
| } |
| ms = append(ms, rs...) |
| } |
| if len(ms) == 0 && lastErr != nil { |
| t.Error(typ, lastErr) |
| continue |
| } |
| ss, err := msgs(ms).validate() |
| if err != nil { |
| t.Error(typ, err) |
| continue |
| } |
| for _, s := range ss { |
| t.Log(s) |
| } |
| } |
| } |
| |
| func TestFetchAndParseRIBOnFreeBSD10AndAbove(t *testing.T) { |
| if _, err := FetchRIB(syscall.AF_UNSPEC, syscall.NET_RT_IFLISTL, 0); err != nil { |
| t.Skip("NET_RT_IFLISTL not supported") |
| } |
| if compatFreeBSD32 { |
| t.Skip("NET_RT_IFLIST vs. NET_RT_IFLISTL doesn't work for 386 emulation on amd64") |
| } |
| |
| var tests = [2]struct { |
| typ RIBType |
| b []byte |
| msgs []Message |
| ss []string |
| }{ |
| {typ: syscall.NET_RT_IFLIST}, |
| {typ: syscall.NET_RT_IFLISTL}, |
| } |
| for i := range tests { |
| var lastErr error |
| for _, af := range []int{syscall.AF_UNSPEC, syscall.AF_INET, syscall.AF_INET6} { |
| rs, err := fetchAndParseRIB(af, tests[i].typ) |
| if err != nil { |
| lastErr = err |
| continue |
| } |
| tests[i].msgs = append(tests[i].msgs, rs...) |
| } |
| if len(tests[i].msgs) == 0 && lastErr != nil { |
| t.Error(tests[i].typ, lastErr) |
| continue |
| } |
| tests[i].ss, lastErr = msgs(tests[i].msgs).validate() |
| if lastErr != nil { |
| t.Error(tests[i].typ, lastErr) |
| continue |
| } |
| for _, s := range tests[i].ss { |
| t.Log(s) |
| } |
| } |
| for i := len(tests) - 1; i > 0; i-- { |
| if len(tests[i].ss) != len(tests[i-1].ss) { |
| t.Errorf("got %v; want %v", tests[i].ss, tests[i-1].ss) |
| continue |
| } |
| for j, s1 := range tests[i].ss { |
| s0 := tests[i-1].ss[j] |
| if s1 != s0 { |
| t.Errorf("got %s; want %s", s1, s0) |
| } |
| } |
| } |
| } |