Skip to content

Commit

Permalink
Fix internal metrics for output split into multiple lines (influxdata…
Browse files Browse the repository at this point in the history
  • Loading branch information
danielnelson authored and HarshitOnGitHub committed May 7, 2020
1 parent 84fcb01 commit 0812d24
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 5 deletions.
15 changes: 10 additions & 5 deletions internal/models/buffer.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,11 @@ type Buffer struct {

// NewBuffer returns a new empty Buffer with the given capacity.
func NewBuffer(name string, alias string, capacity int) *Buffer {
tags := map[string]string{"output": name}
if alias != "" {
tags["alias"] = alias
}

b := &Buffer{
buf: make([]telegraf.Metric, capacity),
first: 0,
Expand All @@ -43,27 +48,27 @@ func NewBuffer(name string, alias string, capacity int) *Buffer {
MetricsAdded: selfstat.Register(
"write",
"metrics_added",
map[string]string{"output": name, "alias": alias},
tags,
),
MetricsWritten: selfstat.Register(
"write",
"metrics_written",
map[string]string{"output": name, "alias": alias},
tags,
),
MetricsDropped: selfstat.Register(
"write",
"metrics_dropped",
map[string]string{"output": name, "alias": alias},
tags,
),
BufferSize: selfstat.Register(
"write",
"buffer_size",
map[string]string{"output": name, "alias": alias},
tags,
),
BufferLimit: selfstat.Register(
"write",
"buffer_limit",
map[string]string{"output": name, "alias": alias},
tags,
),
}
b.BufferSize.Set(int64(0))
Expand Down
46 changes: 46 additions & 0 deletions internal/models/running_output_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,10 @@ import (
"fmt"
"sync"
"testing"
"time"

"github.com/influxdata/telegraf"
"github.com/influxdata/telegraf/selfstat"
"github.com/influxdata/telegraf/testutil"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
Expand Down Expand Up @@ -412,6 +414,50 @@ func TestRunningOutputWriteFailOrder3(t *testing.T) {
assert.Equal(t, expected, m.Metrics())
}

func TestInternalMetrics(t *testing.T) {
_ = NewRunningOutput(
"test_internal",
&mockOutput{},
&OutputConfig{
Filter: Filter{},
Name: "test_name",
Alias: "test_alias",
},
5,
10)

expected := []telegraf.Metric{
testutil.MustMetric(
"internal_write",
map[string]string{
"output": "test_name",
"alias": "test_alias",
},
map[string]interface{}{
"buffer_limit": 10,
"buffer_size": 0,
"errors": 0,
"metrics_added": 0,
"metrics_dropped": 0,
"metrics_filtered": 0,
"metrics_written": 0,
"write_time_ns": 0,
},
time.Unix(0, 0),
),
}

var actual []telegraf.Metric
for _, m := range selfstat.Metrics() {
output, _ := m.GetTag("output")
if m.Name() == "internal_write" && output == "test_name" {
actual = append(actual, m)
}
}

testutil.RequireMetricsEqual(t, expected, actual, testutil.IgnoreTime())
}

type mockOutput struct {
sync.Mutex

Expand Down

0 comments on commit 0812d24

Please sign in to comment.