115 lines
5.1 KiB
Go
115 lines
5.1 KiB
Go
|
package plugins
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/stretchr/testify/require"
|
||
|
)
|
||
|
|
||
|
func TestAvailablePlugins(t *testing.T) {
|
||
|
cases, err := AvailablePlugins()
|
||
|
require.NoError(t, err)
|
||
|
require.Equal(t, 223, len(cases.Plugins))
|
||
|
}
|
||
|
|
||
|
func TestAvailableBundles(t *testing.T) {
|
||
|
cases, err := AvailableBundles()
|
||
|
require.NoError(t, err)
|
||
|
require.Equal(t, 1, len(cases.Plugins))
|
||
|
}
|
||
|
|
||
|
func TestGetPlugin(t *testing.T) {
|
||
|
tests := []struct {
|
||
|
typ string
|
||
|
name string
|
||
|
expected string
|
||
|
ok bool
|
||
|
}{
|
||
|
{
|
||
|
typ: "input",
|
||
|
name: "cpu",
|
||
|
expected: "# Read metrics about cpu usage\n[[inputs.cpu]]\n # alias=\"cpu\"\n ## Whether to report per-cpu stats or not\n percpu = true\n ## Whether to report total system cpu stats or not\n totalcpu = true\n ## If true, collect raw CPU time metrics.\n collect_cpu_time = false\n ## If true, compute and report the sum of all non-idle CPU states.\n report_active = false\n\n",
|
||
|
ok: true,
|
||
|
},
|
||
|
{
|
||
|
typ: "output",
|
||
|
name: "file",
|
||
|
expected: "# Send telegraf metrics to file(s)\n[[outputs.file]]\n # alias=\"file\"\n ## Files to write to, \"stdout\" is a specially handled file.\n files = [\"stdout\", \"/tmp/metrics.out\"]\n\n ## Use batch serialization format instead of line based delimiting. The\n ## batch format allows for the production of non line based output formats and\n ## may more effiently encode metric groups.\n # use_batch_format = false\n\n ## The file will be rotated after the time interval specified. When set\n ## to 0 no time based rotation is performed.\n # rotation_interval = \"0d\"\n\n ## The logfile will be rotated when it becomes larger than the specified\n ## size. When set to 0 no size based rotation is performed.\n # rotation_max_size = \"0MB\"\n\n ## Maximum number of rotated archives to keep, any older logs are deleted.\n ## If set to -1, no archives are removed.\n # rotation_max_archives = 5\n\n ## Data format to output.\n ## Each data format has its own unique set of configuration options, read\n ## more about them here:\n ## https://github.com/influxdata/telegraf/blob/master/docs/DATA_FORMATS_OUTPUT.md\n data_format = \"influx\"\n\n",
|
||
|
ok: true,
|
||
|
},
|
||
|
{
|
||
|
typ: "processor",
|
||
|
name: "converter",
|
||
|
expected: "# Convert values to another metric value type\n[[processors.converter]]\n # alias=\"converter\"\n ## Tags to convert\n ##\n ## The table key determines the target type, and the array of key-values\n ## select the keys to convert. The array may contain globs.\n ## <target-type> = [<tag-key>...]\n [processors.converter.tags]\n string = []\n integer = []\n unsigned = []\n boolean = []\n float = []\n\n ## Fields to convert\n ##\n ## The table key determines the target type, and the array of key-values\n ## select the keys to convert. The array may contain globs.\n ## <target-type> = [<field-key>...]\n [processors.converter.fields]\n tag = []\n string = []\n integer = []\n unsigned = []\n boolean = []\n float = []\n\n",
|
||
|
ok: true,
|
||
|
},
|
||
|
{
|
||
|
typ: "aggregator",
|
||
|
name: "merge",
|
||
|
expected: "# Merge metrics into multifield metrics by series key\n[[aggregators.merge]]\n # alias=\"merge\"\n",
|
||
|
ok: true,
|
||
|
},
|
||
|
{
|
||
|
typ: "bundle",
|
||
|
name: "System Bundle",
|
||
|
expected: "# Read metrics about cpu usage\n[[inputs.cpu]]\n # alias=\"cpu\"\n ## Whether to report per-cpu stats or not\n percpu = true\n ## Whether to report total system cpu stats or not\n totalcpu = true\n ## If true, collect raw CPU time metrics.\n collect_cpu_time = false\n ## If true, compute and report the sum of all non-idle CPU states.\n report_active = false\n# Read metrics about swap memory usage\n[[inputs.swap]]\n # alias=\"swap\"\n# Read metrics about disk usage by mount point\n[[inputs.disk]]\n # alias=\"disk\"\n ## By default stats will be gathered for all mount points.\n ## Set mount_points will restrict the stats to only the specified mount points.\n # mount_points = [\"/\"]\n\n ## Ignore mount points by filesystem type.\n ignore_fs = [\"tmpfs\", \"devtmpfs\", \"devfs\", \"iso9660\", \"overlay\", \"aufs\", \"squashfs\"]\n# Read metrics about memory usage\n[[inputs.mem]]\n # alias=\"mem\"\n",
|
||
|
ok: true,
|
||
|
},
|
||
|
{
|
||
|
typ: "input",
|
||
|
name: "not-a-real-plugin",
|
||
|
expected: "",
|
||
|
ok: false,
|
||
|
},
|
||
|
}
|
||
|
for _, test := range tests {
|
||
|
p, ok := GetPlugin(test.typ, test.name)
|
||
|
require.Equal(t, test.ok, ok)
|
||
|
if ok {
|
||
|
require.Equal(t, test.expected, p.Config)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestListAvailablePlugins(t *testing.T) {
|
||
|
tests := []struct {
|
||
|
typ string
|
||
|
expected int
|
||
|
err string
|
||
|
}{
|
||
|
{
|
||
|
typ: "input",
|
||
|
expected: 170,
|
||
|
},
|
||
|
{
|
||
|
typ: "output",
|
||
|
expected: 33,
|
||
|
},
|
||
|
{
|
||
|
typ: "processor",
|
||
|
expected: 14,
|
||
|
},
|
||
|
{
|
||
|
typ: "aggregator",
|
||
|
expected: 6,
|
||
|
},
|
||
|
{
|
||
|
typ: "bundle",
|
||
|
expected: 1,
|
||
|
},
|
||
|
{
|
||
|
typ: "other",
|
||
|
expected: 0,
|
||
|
err: "unknown plugin type 'other'",
|
||
|
},
|
||
|
}
|
||
|
for _, test := range tests {
|
||
|
p, err := ListAvailablePlugins(test.typ)
|
||
|
if err != nil {
|
||
|
require.Equal(t, test.err, err.Error())
|
||
|
} else {
|
||
|
require.Equal(t, test.expected, len(p.Plugins))
|
||
|
}
|
||
|
}
|
||
|
}
|