2023-02-23 02:28:27 +08:00
|
|
|
//go:build windows
|
|
|
|
|
// +build windows
|
|
|
|
|
|
|
|
|
|
package win_wmi
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"os"
|
|
|
|
|
"regexp"
|
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
|
|
"github.com/influxdata/telegraf/testutil"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// initialize test data
|
|
|
|
|
var sysDrive = fmt.Sprintf(`%s\`, os.Getenv("SystemDrive")) // C:\
|
|
|
|
|
|
|
|
|
|
// include Name as a tag, FreeSpace as a field, and Purpose as a known-null class property
|
2023-06-09 16:24:43 +08:00
|
|
|
var testQuery = Query{
|
2023-07-14 21:58:19 +08:00
|
|
|
Namespace: "ROOT\\cimv2",
|
|
|
|
|
ClassName: "Win32_Volume",
|
|
|
|
|
Properties: []string{"Name", "FreeSpace", "Purpose"},
|
|
|
|
|
//nolint:gocritic // sprintfQuotedString - "%s" used by purpose, string escaping is done by special function
|
2023-02-23 02:28:27 +08:00
|
|
|
Filter: fmt.Sprintf(`NOT Name LIKE "\\\\?\\%%" AND Name LIKE "%s"`, regexp.QuoteMeta(sysDrive)),
|
|
|
|
|
TagPropertiesInclude: []string{"Name"},
|
|
|
|
|
tagFilter: nil, // this is filled in by CompileInputs()
|
|
|
|
|
}
|
2023-07-14 21:58:19 +08:00
|
|
|
|
|
|
|
|
//nolint:gocritic // sprintfQuotedString - "%s" used by purpose, string escaping is done by special function
|
2023-02-23 02:28:27 +08:00
|
|
|
var expectedWql = fmt.Sprintf(
|
|
|
|
|
`SELECT Name, FreeSpace, Purpose FROM Win32_Volume WHERE NOT Name LIKE "\\\\?\\%%" AND Name LIKE "%s"`,
|
2023-07-14 21:58:19 +08:00
|
|
|
regexp.QuoteMeta(sysDrive),
|
|
|
|
|
)
|
2023-02-23 02:28:27 +08:00
|
|
|
|
|
|
|
|
// test buildWqlStatements
|
|
|
|
|
func TestWmi_buildWqlStatements(t *testing.T) {
|
|
|
|
|
var logger = new(testutil.Logger)
|
|
|
|
|
plugin := Wmi{Queries: []Query{testQuery}, Log: logger}
|
|
|
|
|
require.NoError(t, compileInputs(&plugin))
|
|
|
|
|
require.Equal(t, expectedWql, plugin.Queries[0].query)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// test DoQuery
|
|
|
|
|
func TestWmi_DoQuery(t *testing.T) {
|
|
|
|
|
var logger = new(testutil.Logger)
|
|
|
|
|
var acc = new(testutil.Accumulator)
|
|
|
|
|
plugin := Wmi{Queries: []Query{testQuery}, Log: logger}
|
|
|
|
|
require.NoError(t, compileInputs(&plugin))
|
|
|
|
|
for _, q := range plugin.Queries {
|
|
|
|
|
require.NoError(t, q.doQuery(acc))
|
|
|
|
|
}
|
|
|
|
|
// no errors in accumulator
|
|
|
|
|
require.Empty(t, acc.Errors)
|
|
|
|
|
// Only one metric was returned (because we filtered for SystemDrive)
|
|
|
|
|
require.Len(t, acc.Metrics, 1)
|
|
|
|
|
// Name property collected and is the SystemDrive
|
|
|
|
|
require.Equal(t, sysDrive, acc.Metrics[0].Tags["Name"])
|
|
|
|
|
// FreeSpace property was collected as a field
|
|
|
|
|
require.NotEmpty(t, acc.Metrics[0].Fields["FreeSpace"])
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// test Init function
|
|
|
|
|
func TestWmi_Init(t *testing.T) {
|
|
|
|
|
var logger = new(testutil.Logger)
|
|
|
|
|
plugin := Wmi{Queries: []Query{testQuery}, Log: logger}
|
|
|
|
|
require.NoError(t, plugin.Init())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// test Gather function
|
|
|
|
|
func TestWmi_Gather(t *testing.T) {
|
|
|
|
|
var logger = new(testutil.Logger)
|
|
|
|
|
var acc = new(testutil.Accumulator)
|
|
|
|
|
plugin := Wmi{Queries: []Query{testQuery}, Log: logger}
|
2023-04-25 21:15:55 +08:00
|
|
|
require.NoError(t, plugin.Init())
|
2023-02-23 02:28:27 +08:00
|
|
|
require.NoError(t, plugin.Gather(acc))
|
|
|
|
|
// no errors in accumulator
|
|
|
|
|
require.Empty(t, acc.Errors)
|
|
|
|
|
}
|