parsing for channels
This commit is contained in:
parent
1ce2e0ac53
commit
5aa2e04ce7
@ -1,9 +1,9 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/czerwonk/bird_exporter/parser"
|
||||||
"github.com/czerwonk/bird_exporter/protocol"
|
"github.com/czerwonk/bird_exporter/protocol"
|
||||||
"github.com/czerwonk/bird_socket"
|
"github.com/czerwonk/bird_socket"
|
||||||
"github.com/czerwonk/bird_exporter/parser"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func getProtocols() ([]*protocol.Protocol, error) {
|
func getProtocols() ([]*protocol.Protocol, error) {
|
||||||
@ -11,7 +11,7 @@ func getProtocols() ([]*protocol.Protocol, error) {
|
|||||||
var err error = nil
|
var err error = nil
|
||||||
|
|
||||||
if *birdV2 {
|
if *birdV2 {
|
||||||
protocols, err = getProtocolsFromBird(*birdSocket, 0)
|
protocols, err = getProtocolsFromBird(*birdSocket, "")
|
||||||
} else {
|
} else {
|
||||||
protocols, err = getProtocolsFromBird1()
|
protocols, err = getProtocolsFromBird1()
|
||||||
}
|
}
|
||||||
@ -23,7 +23,7 @@ func getProtocolsFromBird1() ([]*protocol.Protocol, error) {
|
|||||||
protocols := make([]*protocol.Protocol, 0)
|
protocols := make([]*protocol.Protocol, 0)
|
||||||
|
|
||||||
if *birdEnabled {
|
if *birdEnabled {
|
||||||
s, err := getProtocolsFromBird(*birdSocket, 4)
|
s, err := getProtocolsFromBird(*birdSocket, "4")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -31,7 +31,7 @@ func getProtocolsFromBird1() ([]*protocol.Protocol, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if *bird6Enabled {
|
if *bird6Enabled {
|
||||||
s, err := getProtocolsFromBird(*bird6Socket, 6)
|
s, err := getProtocolsFromBird(*bird6Socket, "6")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -41,7 +41,7 @@ func getProtocolsFromBird1() ([]*protocol.Protocol, error) {
|
|||||||
return protocols, nil
|
return protocols, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func getProtocolsFromBird(socketPath string, ipVersion int) ([]*protocol.Protocol, error) {
|
func getProtocolsFromBird(socketPath string, ipVersion string) ([]*protocol.Protocol, error) {
|
||||||
b, err := birdsocket.Query(socketPath, "show protocols all")
|
b, err := birdsocket.Query(socketPath, "show protocols all")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -2,7 +2,6 @@ package metrics
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/czerwonk/bird_exporter/protocol"
|
"github.com/czerwonk/bird_exporter/protocol"
|
||||||
"strconv"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type DefaultLabelStrategy struct {
|
type DefaultLabelStrategy struct {
|
||||||
@ -13,14 +12,14 @@ func (*DefaultLabelStrategy) labelNames() []string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (*DefaultLabelStrategy) labelValues(p *protocol.Protocol) []string {
|
func (*DefaultLabelStrategy) labelValues(p *protocol.Protocol) []string {
|
||||||
return []string{p.Name, protoString(p), strconv.Itoa(p.IpVersion)}
|
return []string{p.Name, protoString(p), p.IpVersion}
|
||||||
}
|
}
|
||||||
func protoString(p *protocol.Protocol) string {
|
func protoString(p *protocol.Protocol) string {
|
||||||
switch p.Proto {
|
switch p.Proto {
|
||||||
case protocol.BGP:
|
case protocol.BGP:
|
||||||
return "BGP"
|
return "BGP"
|
||||||
case protocol.OSPF:
|
case protocol.OSPF:
|
||||||
if p.IpVersion == 4 {
|
if p.IpVersion == "4" {
|
||||||
return "OSPF"
|
return "OSPF"
|
||||||
} else {
|
} else {
|
||||||
return "OSPFv3"
|
return "OSPFv3"
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
package metrics
|
package metrics
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
|
||||||
"github.com/czerwonk/bird_exporter/protocol"
|
"github.com/czerwonk/bird_exporter/protocol"
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
)
|
)
|
||||||
|
|
||||||
type LegacyMetricExporter struct {
|
type LegacyMetricExporter struct {
|
||||||
@ -11,7 +11,7 @@ type LegacyMetricExporter struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NewLegacyMetricExporter(prefixIpv4, prefixIpv6 string, labelStrategy LabelStrategy) MetricExporter {
|
func NewLegacyMetricExporter(prefixIpv4, prefixIpv6 string, labelStrategy LabelStrategy) MetricExporter {
|
||||||
return &LegacyMetricExporter {
|
return &LegacyMetricExporter{
|
||||||
ipv4Exporter: NewGenericProtocolMetricExporter(prefixIpv4, false, labelStrategy),
|
ipv4Exporter: NewGenericProtocolMetricExporter(prefixIpv4, false, labelStrategy),
|
||||||
ipv6Exporter: NewGenericProtocolMetricExporter(prefixIpv6, false, labelStrategy),
|
ipv6Exporter: NewGenericProtocolMetricExporter(prefixIpv6, false, labelStrategy),
|
||||||
}
|
}
|
||||||
@ -23,7 +23,7 @@ func (e *LegacyMetricExporter) Describe(ch chan<- *prometheus.Desc) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (e *LegacyMetricExporter) Export(p *protocol.Protocol, ch chan<- prometheus.Metric) {
|
func (e *LegacyMetricExporter) Export(p *protocol.Protocol, ch chan<- prometheus.Metric) {
|
||||||
if p.IpVersion == 4 {
|
if p.IpVersion == "4" {
|
||||||
e.ipv4Exporter.Export(p, ch)
|
e.ipv4Exporter.Export(p, ch)
|
||||||
} else {
|
} else {
|
||||||
e.ipv6Exporter.Export(p, ch)
|
e.ipv6Exporter.Export(p, ch)
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
package ospf
|
package ospf
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/czerwonk/bird_exporter/metrics"
|
||||||
"github.com/czerwonk/bird_exporter/protocol"
|
"github.com/czerwonk/bird_exporter/protocol"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/czerwonk/bird_exporter/metrics"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type desc struct {
|
type desc struct {
|
||||||
@ -11,13 +11,13 @@ type desc struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type ospfMetricExporter struct {
|
type ospfMetricExporter struct {
|
||||||
descriptions map[int]*desc
|
descriptions map[string]*desc
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewExporter(prefix string) metrics.MetricExporter {
|
func NewExporter(prefix string) metrics.MetricExporter {
|
||||||
d := make(map[int]*desc)
|
d := make(map[string]*desc)
|
||||||
d[4] = getDesc(prefix+"ospf")
|
d["4"] = getDesc(prefix + "ospf")
|
||||||
d[6] = getDesc(prefix+"ospfv3")
|
d["6"] = getDesc(prefix + "ospfv3")
|
||||||
|
|
||||||
return &ospfMetricExporter{descriptions: d}
|
return &ospfMetricExporter{descriptions: d}
|
||||||
}
|
}
|
||||||
@ -32,8 +32,8 @@ func getDesc(prefix string) *desc {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *ospfMetricExporter) Describe(ch chan<- *prometheus.Desc) {
|
func (m *ospfMetricExporter) Describe(ch chan<- *prometheus.Desc) {
|
||||||
ch <- m.descriptions[4].runningDesc
|
ch <- m.descriptions["4"].runningDesc
|
||||||
ch <- m.descriptions[6].runningDesc
|
ch <- m.descriptions["6"].runningDesc
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *ospfMetricExporter) Export(p *protocol.Protocol, ch chan<- prometheus.Metric) {
|
func (m *ospfMetricExporter) Export(p *protocol.Protocol, ch chan<- prometheus.Metric) {
|
||||||
|
157
parser/parser.go
157
parser/parser.go
@ -21,6 +21,14 @@ var (
|
|||||||
channelRegex *regexp.Regexp
|
channelRegex *regexp.Regexp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type context struct {
|
||||||
|
current *protocol.Protocol
|
||||||
|
line string
|
||||||
|
handled bool
|
||||||
|
protocols []*protocol.Protocol
|
||||||
|
ipVersion string
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
protocolRegex = regexp.MustCompile("^(?:1002\\-)?([^\\s]+)\\s+(BGP|OSPF|Direct|Device|Kernel)\\s+([^\\s]+)\\s+([^\\s]+)\\s+([^\\s]+)(?:\\s+(.*?))?$")
|
protocolRegex = regexp.MustCompile("^(?:1002\\-)?([^\\s]+)\\s+(BGP|OSPF|Direct|Device|Kernel)\\s+([^\\s]+)\\s+([^\\s]+)\\s+([^\\s]+)(?:\\s+(.*?))?$")
|
||||||
routeRegex = regexp.MustCompile("^\\s+Routes:\\s+(\\d+) imported, (?:(\\d+) filtered, )?(\\d+) exported(?:, (\\d+) preferred)?")
|
routeRegex = regexp.MustCompile("^\\s+Routes:\\s+(\\d+) imported, (?:(\\d+) filtered, )?(\\d+) exported(?:, (\\d+) preferred)?")
|
||||||
@ -30,49 +38,60 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Parser parses bird output and returns protocol.Protocol structs
|
// Parser parses bird output and returns protocol.Protocol structs
|
||||||
func Parse(data []byte, ipVersion int) []*protocol.Protocol {
|
func Parse(data []byte, ipVersion string) []*protocol.Protocol {
|
||||||
protocols := make([]*protocol.Protocol, 0)
|
|
||||||
|
|
||||||
reader := bytes.NewReader(data)
|
reader := bytes.NewReader(data)
|
||||||
scanner := bufio.NewScanner(reader)
|
scanner := bufio.NewScanner(reader)
|
||||||
var current *protocol.Protocol = nil
|
|
||||||
|
c := &context{protocols: make([]*protocol.Protocol, 0), ipVersion: ipVersion}
|
||||||
|
|
||||||
|
var handlers = []func(*context){
|
||||||
|
handleEmptyLine,
|
||||||
|
parseLineForProtocol,
|
||||||
|
parseLineForChannel,
|
||||||
|
parseLineForRoutes,
|
||||||
|
parseLineForRouteChanges,
|
||||||
|
}
|
||||||
|
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
line := strings.TrimRight(scanner.Text(), " ")
|
c.line = strings.TrimRight(scanner.Text(), " ")
|
||||||
if p, ok := parseLineForProtocol(line, ipVersion); ok {
|
c.handled = false
|
||||||
current = p
|
|
||||||
protocols = append(protocols, current)
|
|
||||||
}
|
|
||||||
|
|
||||||
if current != nil {
|
for _, h := range handlers {
|
||||||
parseLineForRoutes(line, current)
|
if !c.handled {
|
||||||
parseLineForRouteChanges(line, current)
|
h(c)
|
||||||
}
|
}
|
||||||
|
|
||||||
if line == "" {
|
|
||||||
current = nil
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return protocols
|
return c.protocols
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseLineForProtocol(line string, ipVersion int) (*protocol.Protocol, bool) {
|
func handleEmptyLine(c *context) {
|
||||||
match := protocolRegex.FindStringSubmatch(line)
|
if c.line != "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
c.current = nil
|
||||||
|
c.handled = true
|
||||||
|
}
|
||||||
|
|
||||||
|
func parseLineForProtocol(c *context) {
|
||||||
|
match := protocolRegex.FindStringSubmatch(c.line)
|
||||||
|
|
||||||
if match == nil {
|
if match == nil {
|
||||||
return nil, false
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
proto := parseProto(match[2])
|
proto := parseProto(match[2])
|
||||||
ut := parseUptime(match[5])
|
ut := parseUptime(match[5])
|
||||||
|
|
||||||
p := protocol.NewProtocol(match[1], proto, ipVersion, ut)
|
c.current = protocol.NewProtocol(match[1], proto, c.ipVersion, ut)
|
||||||
p.Up = parseState(match[4])
|
c.current.Up = parseState(match[4])
|
||||||
|
|
||||||
fillAttributes(p, match)
|
fillAttributes(c.current, match)
|
||||||
|
|
||||||
return p, true
|
c.protocols = append(c.protocols, c.current)
|
||||||
|
c.handled = true
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseProto(val string) int {
|
func parseProto(val string) int {
|
||||||
@ -94,25 +113,6 @@ func parseProto(val string) int {
|
|||||||
return protocol.PROTO_UNKNOWN
|
return protocol.PROTO_UNKNOWN
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseLineForRoutes(line string, p *protocol.Protocol) {
|
|
||||||
match := routeRegex.FindStringSubmatch(line)
|
|
||||||
|
|
||||||
if match == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
p.Imported, _ = strconv.ParseInt(match[1], 10, 64)
|
|
||||||
p.Exported, _ = strconv.ParseInt(match[3], 10, 64)
|
|
||||||
|
|
||||||
if len(match[2]) > 0 {
|
|
||||||
p.Filtered, _ = strconv.ParseInt(match[2], 10, 64)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(match[4]) > 0 {
|
|
||||||
p.Preferred, _ = strconv.ParseInt(match[4], 10, 64)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func parseState(state string) int {
|
func parseState(state string) int {
|
||||||
if state == "up" {
|
if state == "up" {
|
||||||
return 1
|
return 1
|
||||||
@ -123,6 +123,7 @@ func parseState(state string) int {
|
|||||||
|
|
||||||
func parseUptime(value string) int {
|
func parseUptime(value string) int {
|
||||||
match := uptimeRegex.FindStringSubmatch(value)
|
match := uptimeRegex.FindStringSubmatch(value)
|
||||||
|
|
||||||
if match == nil {
|
if match == nil {
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
@ -158,18 +159,74 @@ func parseUptimeForTimestamp(timestamp string) int {
|
|||||||
return int(d.Seconds())
|
return int(d.Seconds())
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseLineForRouteChanges(line string, p *protocol.Protocol) {
|
func parseLineForChannel(c *context) {
|
||||||
match := routeChangeRegex.FindStringSubmatch(line)
|
if c.ipVersion != "" || c.current == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
channel := channelRegex.FindStringSubmatch(c.line)
|
||||||
|
if channel == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(c.current.IpVersion) == 0 {
|
||||||
|
c.current.IpVersion = channel[1]
|
||||||
|
} else {
|
||||||
|
c.current = &protocol.Protocol{
|
||||||
|
Name: c.current.Name,
|
||||||
|
Proto: c.current.Proto,
|
||||||
|
Up: c.current.Up,
|
||||||
|
Uptime: c.current.Uptime,
|
||||||
|
IpVersion: channel[1],
|
||||||
|
}
|
||||||
|
c.protocols = append(c.protocols, c.current)
|
||||||
|
}
|
||||||
|
|
||||||
|
c.handled = true
|
||||||
|
}
|
||||||
|
|
||||||
|
func parseLineForRoutes(c *context) {
|
||||||
|
if c.current == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
match := routeRegex.FindStringSubmatch(c.line)
|
||||||
if match == nil {
|
if match == nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
c := getRouteChangeCount(match, p)
|
c.current.Imported, _ = strconv.ParseInt(match[1], 10, 64)
|
||||||
c.Received = parseRouteChangeValue(match[3])
|
c.current.Exported, _ = strconv.ParseInt(match[3], 10, 64)
|
||||||
c.Rejected = parseRouteChangeValue(match[4])
|
|
||||||
c.Filtered = parseRouteChangeValue(match[5])
|
if len(match[2]) > 0 {
|
||||||
c.Ignored = parseRouteChangeValue(match[6])
|
c.current.Filtered, _ = strconv.ParseInt(match[2], 10, 64)
|
||||||
c.Accepted = parseRouteChangeValue(match[7])
|
}
|
||||||
|
|
||||||
|
if len(match[4]) > 0 {
|
||||||
|
c.current.Preferred, _ = strconv.ParseInt(match[4], 10, 64)
|
||||||
|
}
|
||||||
|
|
||||||
|
c.handled = true
|
||||||
|
}
|
||||||
|
|
||||||
|
func parseLineForRouteChanges(c *context) {
|
||||||
|
if c.current == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
match := routeChangeRegex.FindStringSubmatch(c.line)
|
||||||
|
if match == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
x := getRouteChangeCount(match, c.current)
|
||||||
|
x.Received = parseRouteChangeValue(match[3])
|
||||||
|
x.Rejected = parseRouteChangeValue(match[4])
|
||||||
|
x.Filtered = parseRouteChangeValue(match[5])
|
||||||
|
x.Ignored = parseRouteChangeValue(match[6])
|
||||||
|
x.Accepted = parseRouteChangeValue(match[7])
|
||||||
|
|
||||||
|
c.handled = true
|
||||||
}
|
}
|
||||||
|
|
||||||
func getRouteChangeCount(values []string, p *protocol.Protocol) *protocol.RouteChangeCount {
|
func getRouteChangeCount(values []string, p *protocol.Protocol) *protocol.RouteChangeCount {
|
||||||
|
173
parser_test.go
173
parser_test.go
@ -10,7 +10,7 @@ import (
|
|||||||
|
|
||||||
func TestEstablishedBgpOldTimeFormat(t *testing.T) {
|
func TestEstablishedBgpOldTimeFormat(t *testing.T) {
|
||||||
data := "foo BGP master up 1481973060 Established\ntest\nbar\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nxxx"
|
data := "foo BGP master up 1481973060 Established\ntest\nbar\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -21,12 +21,12 @@ func TestEstablishedBgpOldTimeFormat(t *testing.T) {
|
|||||||
assert.Int64Equal("exported", 34, x.Exported, t)
|
assert.Int64Equal("exported", 34, x.Exported, t)
|
||||||
assert.Int64Equal("filtered", 1, x.Filtered, t)
|
assert.Int64Equal("filtered", 1, x.Filtered, t)
|
||||||
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
||||||
assert.IntEqual("ipVersion", 4, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "4", x.IpVersion, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEstablishedBgpCurrentTimeFormat(t *testing.T) {
|
func TestEstablishedBgpCurrentTimeFormat(t *testing.T) {
|
||||||
data := "foo BGP master up 00:01:00 Established\ntest\nbar\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nxxx"
|
data := "foo BGP master up 00:01:00 Established\ntest\nbar\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -37,22 +37,22 @@ func TestEstablishedBgpCurrentTimeFormat(t *testing.T) {
|
|||||||
assert.Int64Equal("exported", 34, x.Exported, t)
|
assert.Int64Equal("exported", 34, x.Exported, t)
|
||||||
assert.Int64Equal("filtered", 1, x.Filtered, t)
|
assert.Int64Equal("filtered", 1, x.Filtered, t)
|
||||||
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
||||||
assert.IntEqual("ipVersion", 4, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "4", x.IpVersion, t)
|
||||||
assert.IntEqual("uptime", 60, x.Uptime, t)
|
assert.IntEqual("uptime", 60, x.Uptime, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIpv6Bgp(t *testing.T) {
|
func TestIpv6Bgp(t *testing.T) {
|
||||||
data := "foo BGP master up 00:01:00 Established\ntest\nbar\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nxxx"
|
data := "foo BGP master up 00:01:00 Established\ntest\nbar\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 6)
|
p := parser.Parse([]byte(data), "6")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
assert.IntEqual("ipVersion", 6, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "6", x.IpVersion, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestActiveBgp(t *testing.T) {
|
func TestActiveBgp(t *testing.T) {
|
||||||
data := "bar BGP master start 2016-01-01 Active\ntest\nbar"
|
data := "bar BGP master start 2016-01-01 Active\ntest\nbar"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -61,13 +61,13 @@ func TestActiveBgp(t *testing.T) {
|
|||||||
assert.IntEqual("established", 0, x.Up, t)
|
assert.IntEqual("established", 0, x.Up, t)
|
||||||
assert.IntEqual("imported", 0, int(x.Imported), t)
|
assert.IntEqual("imported", 0, int(x.Imported), t)
|
||||||
assert.IntEqual("exported", 0, int(x.Exported), t)
|
assert.IntEqual("exported", 0, int(x.Exported), t)
|
||||||
assert.IntEqual("ipVersion", 4, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "4", x.IpVersion, t)
|
||||||
assert.IntEqual("uptime", 0, int(x.Uptime), t)
|
assert.IntEqual("uptime", 0, int(x.Uptime), t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test2BgpSessions(t *testing.T) {
|
func Test2BgpSessions(t *testing.T) {
|
||||||
data := "foo BGP master up 00:01:00 Established\ntest\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nbar BGP master start 2016-01-01 Active\nxxx"
|
data := "foo BGP master up 00:01:00 Established\ntest\n Routes: 12 imported, 1 filtered, 34 exported, 100 preferred\nbar BGP master start 2016-01-01 Active\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 2, len(p), t)
|
assert.IntEqual("protocols", 2, len(p), t)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -79,7 +79,7 @@ func TestUpdateAndWithdrawCounts(t *testing.T) {
|
|||||||
" Import withdraws: 6 7 8 9 10\n" +
|
" Import withdraws: 6 7 8 9 10\n" +
|
||||||
" Export updates: 11 12 13 14 15\n" +
|
" Export updates: 11 12 13 14 15\n" +
|
||||||
" Export withdraws: 16 17 18 19 ---"
|
" Export withdraws: 16 17 18 19 ---"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
x := p[0]
|
x := p[0]
|
||||||
|
|
||||||
assert.Int64Equal("import updates received", 1, x.ImportUpdates.Received, t)
|
assert.Int64Equal("import updates received", 1, x.ImportUpdates.Received, t)
|
||||||
@ -106,6 +106,10 @@ func TestUpdateAndWithdrawCounts(t *testing.T) {
|
|||||||
|
|
||||||
func TestWithBird2(t *testing.T) {
|
func TestWithBird2(t *testing.T) {
|
||||||
data := "Name Proto Table State Since Info\n" +
|
data := "Name Proto Table State Since Info\n" +
|
||||||
|
"bgp1 BGP master up 1494926415\n" +
|
||||||
|
" Channel ipv6\n" +
|
||||||
|
" Routes: 1 imported, 2 filtered, 3 exported, 4 preferred\n" +
|
||||||
|
"\n" +
|
||||||
"direct1 Direct --- up 1513027903\n" +
|
"direct1 Direct --- up 1513027903\n" +
|
||||||
" Channel ipv4\n" +
|
" Channel ipv4\n" +
|
||||||
" State: UP\n" +
|
" State: UP\n" +
|
||||||
@ -130,69 +134,96 @@ func TestWithBird2(t *testing.T) {
|
|||||||
" Import updates: 20 21 22 23 24\n" +
|
" Import updates: 20 21 22 23 24\n" +
|
||||||
" Import withdraws: 25 26 27 28 29\n" +
|
" Import withdraws: 25 26 27 28 29\n" +
|
||||||
" Export updates: 30 31 32 33 34\n" +
|
" Export updates: 30 31 32 33 34\n" +
|
||||||
" Export withdraws: 35 36 37 38 ---\n"
|
" Export withdraws: 35 36 37 38 ---\n" +
|
||||||
|
"\n" +
|
||||||
|
"ospf1 OSPF master up 1494926415\n" +
|
||||||
|
" Channel ipv4\n" +
|
||||||
|
" Routes: 4 imported, 3 filtered, 2 exported, 1 preferred\n" +
|
||||||
|
"\n"
|
||||||
|
|
||||||
p := parser.Parse([]byte(data), 0)
|
p := parser.Parse([]byte(data), "")
|
||||||
assert.IntEqual("protocols", 2, len(p), t)
|
assert.IntEqual("protocols", 4, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
assert.IntEqual("ipv4 ip version", 4, x.IpVersion, t)
|
assert.StringEqual("BGP ipv6 name", "bgp1", x.Name, t)
|
||||||
assert.Int64Equal("ipv4 imported", 12, x.Imported, t)
|
assert.IntEqual("BGP ipv6 proto", protocol.BGP, x.Proto, t)
|
||||||
assert.Int64Equal("ipv4 exported", 34, x.Exported, t)
|
assert.StringEqual("BGP ipv6 ip version", "6", x.IpVersion, t)
|
||||||
assert.Int64Equal("ipv4 filtered", 1, x.Filtered, t)
|
assert.Int64Equal("BGP ipv6 imported", 1, x.Imported, t)
|
||||||
assert.Int64Equal("ipv4 preferred", 100, x.Preferred, t)
|
assert.Int64Equal("BGP ipv6 exported", 3, x.Exported, t)
|
||||||
assert.Int64Equal("ipv4 import updates received", 1, x.ImportUpdates.Received, t)
|
assert.Int64Equal("BGP ipv6 filtered", 2, x.Filtered, t)
|
||||||
assert.Int64Equal("ipv4 import updates rejected", 2, x.ImportUpdates.Rejected, t)
|
assert.Int64Equal("BGP ipv6 preferred", 4, x.Preferred, t)
|
||||||
assert.Int64Equal("ipv4 import updates filtered", 3, x.ImportUpdates.Filtered, t)
|
|
||||||
assert.Int64Equal("ipv4 import updates ignored", 4, x.ImportUpdates.Ignored, t)
|
|
||||||
assert.Int64Equal("ipv4 import updates accepted", 5, x.ImportUpdates.Accepted, t)
|
|
||||||
assert.Int64Equal("ipv4 import withdraws received", 6, x.ImportWithdraws.Received, t)
|
|
||||||
assert.Int64Equal("ipv4 import withdraws rejected", 7, x.ImportWithdraws.Rejected, t)
|
|
||||||
assert.Int64Equal("ipv4 import withdraws filtered", 8, x.ImportWithdraws.Filtered, t)
|
|
||||||
assert.Int64Equal("ipv4 import withdraws ignored", 9, x.ImportWithdraws.Ignored, t)
|
|
||||||
assert.Int64Equal("ipv4 import withdraws accepted", 10, x.ImportWithdraws.Accepted, t)
|
|
||||||
assert.Int64Equal("ipv4 export updates received", 11, x.ExportUpdates.Received, t)
|
|
||||||
assert.Int64Equal("ipv4 export updates rejected", 12, x.ExportUpdates.Rejected, t)
|
|
||||||
assert.Int64Equal("ipv4 export updates filtered", 13, x.ExportUpdates.Filtered, t)
|
|
||||||
assert.Int64Equal("ipv4 export updates ignored", 14, x.ExportUpdates.Ignored, t)
|
|
||||||
assert.Int64Equal("ipv4 export updates accepted", 15, x.ExportUpdates.Accepted, t)
|
|
||||||
assert.Int64Equal("ipv4 export withdraws received", 16, x.ExportWithdraws.Received, t)
|
|
||||||
assert.Int64Equal("ipv4 export withdraws rejected", 17, x.ExportWithdraws.Rejected, t)
|
|
||||||
assert.Int64Equal("ipv4 export withdraws filtered", 18, x.ExportWithdraws.Filtered, t)
|
|
||||||
assert.Int64Equal("ipv4 export withdraws ignored", 19, x.ExportWithdraws.Ignored, t)
|
|
||||||
assert.Int64Equal("ipv4 export withdraws accepted", 0, x.ExportWithdraws.Accepted, t)
|
|
||||||
|
|
||||||
x = p[1]
|
x = p[1]
|
||||||
assert.IntEqual("ipv6 ip version", 6, x.IpVersion, t)
|
assert.StringEqual("BGP ipv4 name", "direct1", x.Name, t)
|
||||||
assert.Int64Equal("ipv6 imported", 3, x.Imported, t)
|
assert.IntEqual("Direct ipv4 proto", protocol.Direct, x.Proto, t)
|
||||||
assert.Int64Equal("ipv6 exported", 5, x.Exported, t)
|
assert.StringEqual("Direct ipv4 ip version", "4", x.IpVersion, t)
|
||||||
assert.Int64Equal("ipv6 filtered", 7, x.Filtered, t)
|
assert.Int64Equal("Direct ipv4 imported", 12, x.Imported, t)
|
||||||
assert.Int64Equal("ipv6 preferred", 13, x.Preferred, t)
|
assert.Int64Equal("Direct ipv4 exported", 34, x.Exported, t)
|
||||||
assert.Int64Equal("ipv6 import updates received", 20, x.ImportUpdates.Received, t)
|
assert.Int64Equal("Direct ipv4 filtered", 1, x.Filtered, t)
|
||||||
assert.Int64Equal("ipv6 import updates rejected", 21, x.ImportUpdates.Rejected, t)
|
assert.Int64Equal("Direct ipv4 preferred", 100, x.Preferred, t)
|
||||||
assert.Int64Equal("ipv6 import updates filtered", 22, x.ImportUpdates.Filtered, t)
|
assert.Int64Equal("Direct ipv4 import updates received", 1, x.ImportUpdates.Received, t)
|
||||||
assert.Int64Equal("ipv6 import updates ignored", 23, x.ImportUpdates.Ignored, t)
|
assert.Int64Equal("Direct ipv4 import updates rejected", 2, x.ImportUpdates.Rejected, t)
|
||||||
assert.Int64Equal("ipv6 import updates accepted", 24, x.ImportUpdates.Accepted, t)
|
assert.Int64Equal("Direct ipv4 import updates filtered", 3, x.ImportUpdates.Filtered, t)
|
||||||
assert.Int64Equal("ipv6 import withdraws received", 25, x.ImportWithdraws.Received, t)
|
assert.Int64Equal("Direct ipv4 import updates ignored", 4, x.ImportUpdates.Ignored, t)
|
||||||
assert.Int64Equal("ipv6 import withdraws rejected", 26, x.ImportWithdraws.Rejected, t)
|
assert.Int64Equal("Direct ipv4 import updates accepted", 5, x.ImportUpdates.Accepted, t)
|
||||||
assert.Int64Equal("ipv6 import withdraws filtered", 27, x.ImportWithdraws.Filtered, t)
|
assert.Int64Equal("Direct ipv4 import withdraws received", 6, x.ImportWithdraws.Received, t)
|
||||||
assert.Int64Equal("ipv6 import withdraws ignored", 28, x.ImportWithdraws.Ignored, t)
|
assert.Int64Equal("Direct ipv4 import withdraws rejected", 7, x.ImportWithdraws.Rejected, t)
|
||||||
assert.Int64Equal("ipv6 import withdraws accepted", 29, x.ImportWithdraws.Accepted, t)
|
assert.Int64Equal("Direct ipv4 import withdraws filtered", 8, x.ImportWithdraws.Filtered, t)
|
||||||
assert.Int64Equal("ipv6 export updates received", 30, x.ExportUpdates.Received, t)
|
assert.Int64Equal("Direct ipv4 import withdraws ignored", 9, x.ImportWithdraws.Ignored, t)
|
||||||
assert.Int64Equal("ipv6 export updates rejected", 31, x.ExportUpdates.Rejected, t)
|
assert.Int64Equal("Direct ipv4 import withdraws accepted", 10, x.ImportWithdraws.Accepted, t)
|
||||||
assert.Int64Equal("ipv6 export updates filtered", 32, x.ExportUpdates.Filtered, t)
|
assert.Int64Equal("Direct ipv4 export updates received", 11, x.ExportUpdates.Received, t)
|
||||||
assert.Int64Equal("ipv6 export updates ignored", 33, x.ExportUpdates.Ignored, t)
|
assert.Int64Equal("Direct ipv4 export updates rejected", 12, x.ExportUpdates.Rejected, t)
|
||||||
assert.Int64Equal("ipv6 export updates accepted", 34, x.ExportUpdates.Accepted, t)
|
assert.Int64Equal("Direct ipv4 export updates filtered", 13, x.ExportUpdates.Filtered, t)
|
||||||
assert.Int64Equal("ipv6 export withdraws received", 35, x.ExportWithdraws.Received, t)
|
assert.Int64Equal("Direct ipv4 export updates ignored", 14, x.ExportUpdates.Ignored, t)
|
||||||
assert.Int64Equal("ipv6 export withdraws rejected", 36, x.ExportWithdraws.Rejected, t)
|
assert.Int64Equal("Direct ipv4 export updates accepted", 15, x.ExportUpdates.Accepted, t)
|
||||||
assert.Int64Equal("ipv6 export withdraws filtered", 37, x.ExportWithdraws.Filtered, t)
|
assert.Int64Equal("Direct ipv4 export withdraws received", 16, x.ExportWithdraws.Received, t)
|
||||||
assert.Int64Equal("ipv6 export withdraws ignored", 38, x.ExportWithdraws.Ignored, t)
|
assert.Int64Equal("Direct ipv4 export withdraws rejected", 17, x.ExportWithdraws.Rejected, t)
|
||||||
assert.Int64Equal("ipv6 export withdraws accepted", 0, x.ExportWithdraws.Accepted, t)
|
assert.Int64Equal("Direct ipv4 export withdraws filtered", 18, x.ExportWithdraws.Filtered, t)
|
||||||
|
assert.Int64Equal("Direct ipv4 export withdraws ignored", 19, x.ExportWithdraws.Ignored, t)
|
||||||
|
assert.Int64Equal("Direct ipv4 export withdraws accepted", 0, x.ExportWithdraws.Accepted, t)
|
||||||
|
|
||||||
|
x = p[2]
|
||||||
|
assert.StringEqual("BGP ipv4 name", "direct1", x.Name, t)
|
||||||
|
assert.IntEqual("Direct ipv6 proto", protocol.Direct, x.Proto, t)
|
||||||
|
assert.StringEqual("Direct ipv6 ip version", "6", x.IpVersion, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 imported", 3, x.Imported, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 exported", 5, x.Exported, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 filtered", 7, x.Filtered, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 preferred", 13, x.Preferred, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import updates received", 20, x.ImportUpdates.Received, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import updates rejected", 21, x.ImportUpdates.Rejected, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import updates filtered", 22, x.ImportUpdates.Filtered, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import updates ignored", 23, x.ImportUpdates.Ignored, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import updates accepted", 24, x.ImportUpdates.Accepted, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import withdraws received", 25, x.ImportWithdraws.Received, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import withdraws rejected", 26, x.ImportWithdraws.Rejected, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import withdraws filtered", 27, x.ImportWithdraws.Filtered, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import withdraws ignored", 28, x.ImportWithdraws.Ignored, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 import withdraws accepted", 29, x.ImportWithdraws.Accepted, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export updates received", 30, x.ExportUpdates.Received, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export updates rejected", 31, x.ExportUpdates.Rejected, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export updates filtered", 32, x.ExportUpdates.Filtered, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export updates ignored", 33, x.ExportUpdates.Ignored, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export updates accepted", 34, x.ExportUpdates.Accepted, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export withdraws received", 35, x.ExportWithdraws.Received, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export withdraws rejected", 36, x.ExportWithdraws.Rejected, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export withdraws filtered", 37, x.ExportWithdraws.Filtered, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export withdraws ignored", 38, x.ExportWithdraws.Ignored, t)
|
||||||
|
assert.Int64Equal("Direct ipv6 export withdraws accepted", 0, x.ExportWithdraws.Accepted, t)
|
||||||
|
|
||||||
|
x = p[3]
|
||||||
|
assert.StringEqual("OSPF ipv4 name", "ospf1", x.Name, t)
|
||||||
|
assert.IntEqual("OSPF ipv4 proto", protocol.OSPF, x.Proto, t)
|
||||||
|
assert.StringEqual("OSPF ipv4 ip version", "4", x.IpVersion, t)
|
||||||
|
assert.Int64Equal("OSPF ipv4 imported", 4, x.Imported, t)
|
||||||
|
assert.Int64Equal("OSPF ipv4 exported", 2, x.Exported, t)
|
||||||
|
assert.Int64Equal("OSPF ipv4 filtered", 3, x.Filtered, t)
|
||||||
|
assert.Int64Equal("OSPF ipv4 preferred", 1, x.Preferred, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOspfOldTimeFormat(t *testing.T) {
|
func TestOspfOldTimeFormat(t *testing.T) {
|
||||||
data := "ospf1 OSPF master up 1481973060 Running\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
data := "ospf1 OSPF master up 1481973060 Running\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -202,12 +233,12 @@ func TestOspfOldTimeFormat(t *testing.T) {
|
|||||||
assert.Int64Equal("imported", 12, x.Imported, t)
|
assert.Int64Equal("imported", 12, x.Imported, t)
|
||||||
assert.Int64Equal("exported", 34, x.Exported, t)
|
assert.Int64Equal("exported", 34, x.Exported, t)
|
||||||
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
||||||
assert.IntEqual("ipVersion", 4, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "4", x.IpVersion, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOspfCurrentTimeFormat(t *testing.T) {
|
func TestOspfCurrentTimeFormat(t *testing.T) {
|
||||||
data := "ospf1 OSPF master up 00:01:00 Running\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
data := "ospf1 OSPF master up 00:01:00 Running\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -217,13 +248,13 @@ func TestOspfCurrentTimeFormat(t *testing.T) {
|
|||||||
assert.Int64Equal("imported", 12, x.Imported, t)
|
assert.Int64Equal("imported", 12, x.Imported, t)
|
||||||
assert.Int64Equal("exported", 34, x.Exported, t)
|
assert.Int64Equal("exported", 34, x.Exported, t)
|
||||||
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
assert.Int64Equal("preferred", 100, x.Preferred, t)
|
||||||
assert.IntEqual("ipVersion", 4, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "4", x.IpVersion, t)
|
||||||
assert.IntEqual("uptime", 60, x.Uptime, t)
|
assert.IntEqual("uptime", 60, x.Uptime, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOspfProtocolDown(t *testing.T) {
|
func TestOspfProtocolDown(t *testing.T) {
|
||||||
data := "o_hrz OSPF t_hrz down 1494926415 \n Preference: 150\n Input filter: ACCEPT\n Output filter: REJECT\nxxx"
|
data := "o_hrz OSPF t_hrz down 1494926415 \n Preference: 150\n Input filter: ACCEPT\n Output filter: REJECT\nxxx"
|
||||||
p := parser.Parse([]byte(data), 6)
|
p := parser.Parse([]byte(data), "6")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -232,12 +263,12 @@ func TestOspfProtocolDown(t *testing.T) {
|
|||||||
assert.IntEqual("up", 0, x.Up, t)
|
assert.IntEqual("up", 0, x.Up, t)
|
||||||
assert.Int64Equal("imported", 0, x.Imported, t)
|
assert.Int64Equal("imported", 0, x.Imported, t)
|
||||||
assert.Int64Equal("exported", 0, x.Exported, t)
|
assert.Int64Equal("exported", 0, x.Exported, t)
|
||||||
assert.IntEqual("ipVersion", 6, x.IpVersion, t)
|
assert.StringEqual("ipVersion", "6", x.IpVersion, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOspfRunning(t *testing.T) {
|
func TestOspfRunning(t *testing.T) {
|
||||||
data := "ospf1 OSPF master up 00:01:00 Running\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
data := "ospf1 OSPF master up 00:01:00 Running\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
@ -246,7 +277,7 @@ func TestOspfRunning(t *testing.T) {
|
|||||||
|
|
||||||
func TestOspfAlone(t *testing.T) {
|
func TestOspfAlone(t *testing.T) {
|
||||||
data := "ospf1 OSPF master up 00:01:00 Alone\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
data := "ospf1 OSPF master up 00:01:00 Alone\ntest\nbar\n Routes: 12 imported, 34 exported, 100 preferred\nxxx"
|
||||||
p := parser.Parse([]byte(data), 4)
|
p := parser.Parse([]byte(data), "4")
|
||||||
assert.IntEqual("protocols", 1, len(p), t)
|
assert.IntEqual("protocols", 1, len(p), t)
|
||||||
|
|
||||||
x := p[0]
|
x := p[0]
|
||||||
|
@ -12,7 +12,7 @@ const (
|
|||||||
|
|
||||||
type Protocol struct {
|
type Protocol struct {
|
||||||
Name string
|
Name string
|
||||||
IpVersion int
|
IpVersion string
|
||||||
Proto int
|
Proto int
|
||||||
Up int
|
Up int
|
||||||
Imported int64
|
Imported int64
|
||||||
@ -35,6 +35,6 @@ type RouteChangeCount struct {
|
|||||||
Accepted int64
|
Accepted int64
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewProtocol(name string, proto, ipVersion, uptime int) *Protocol {
|
func NewProtocol(name string, proto int, ipVersion string, uptime int) *Protocol {
|
||||||
return &Protocol{Name: name, Proto: proto, IpVersion: ipVersion, Uptime: uptime, Attributes: make(map[string]float64)}
|
return &Protocol{Name: name, Proto: proto, IpVersion: ipVersion, Uptime: uptime, Attributes: make(map[string]float64)}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user