You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
173 lines
5.5 KiB
173 lines
5.5 KiB
package config_test
|
|
|
|
import (
|
|
"github.com/analogj/scrutiny/collector/pkg/config"
|
|
"github.com/analogj/scrutiny/collector/pkg/models"
|
|
"github.com/stretchr/testify/require"
|
|
"path"
|
|
"testing"
|
|
)
|
|
|
|
func TestConfiguration_InvalidConfigPath(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig("does_not_exist.yaml")
|
|
|
|
//assert
|
|
require.Error(t, err, "should return an error")
|
|
}
|
|
|
|
func TestConfiguration_GetScanOverrides_Simple(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "simple_device.yaml"))
|
|
require.NoError(t, err, "should correctly load simple device config")
|
|
scanOverrides := testConfig.GetDeviceOverrides()
|
|
|
|
//assert
|
|
require.Equal(t, []models.ScanOverride{{Device: "/dev/sda", DeviceType: []string{"sat"}, Ignore: false}}, scanOverrides)
|
|
}
|
|
|
|
// fixes #418
|
|
func TestConfiguration_GetScanOverrides_DeviceTypeComma(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "device_type_comma.yaml"))
|
|
require.NoError(t, err, "should correctly load simple device config")
|
|
scanOverrides := testConfig.GetDeviceOverrides()
|
|
|
|
//assert
|
|
require.Equal(t, []models.ScanOverride{
|
|
{Device: "/dev/sda", DeviceType: []string{"sat", "auto"}, Ignore: false},
|
|
{Device: "/dev/sdb", DeviceType: []string{"sat,auto"}, Ignore: false},
|
|
}, scanOverrides)
|
|
}
|
|
|
|
func TestConfiguration_GetScanOverrides_Ignore(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "ignore_device.yaml"))
|
|
require.NoError(t, err, "should correctly load ignore device config")
|
|
scanOverrides := testConfig.GetDeviceOverrides()
|
|
|
|
//assert
|
|
require.Equal(t, []models.ScanOverride{{Device: "/dev/sda", DeviceType: nil, Ignore: true}}, scanOverrides)
|
|
}
|
|
|
|
func TestConfiguration_GetScanOverrides_Raid(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "raid_device.yaml"))
|
|
require.NoError(t, err, "should correctly load ignore device config")
|
|
scanOverrides := testConfig.GetDeviceOverrides()
|
|
|
|
//assert
|
|
require.Equal(t, []models.ScanOverride{
|
|
{
|
|
Device: "/dev/bus/0",
|
|
DeviceType: []string{"megaraid,14", "megaraid,15", "megaraid,18", "megaraid,19", "megaraid,20", "megaraid,21"},
|
|
Ignore: false,
|
|
},
|
|
{
|
|
Device: "/dev/twa0",
|
|
DeviceType: []string{"3ware,0", "3ware,1", "3ware,2", "3ware,3", "3ware,4", "3ware,5"},
|
|
Ignore: false,
|
|
}}, scanOverrides)
|
|
}
|
|
|
|
func TestConfiguration_InvalidCommands_MissingJson(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "invalid_commands_missing_json.yaml"))
|
|
require.EqualError(t, err, `ConfigValidationError: "configuration key 'commands.metrics_scan_args' is missing '--json' flag"`, "should throw an error because json flag is missing")
|
|
}
|
|
|
|
func TestConfiguration_InvalidCommands_IncludesDevice(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "invalid_commands_includes_device.yaml"))
|
|
require.EqualError(t, err, `ConfigValidationError: "configuration key 'commands.metrics_info_args' must not contain '--device' or '-d' flag, configuration key 'commands.metrics_smart_args' must not contain '--device' or '-d' flag"`, "should throw an error because device flags detected")
|
|
}
|
|
|
|
func TestConfiguration_OverrideCommands(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "override_commands.yaml"))
|
|
require.NoError(t, err, "should not throw an error")
|
|
require.Equal(t, "--xall --json -T permissive", testConfig.GetString("commands.metrics_smart_args"))
|
|
}
|
|
|
|
func TestConfiguration_OverrideDeviceCommands_MetricsInfoArgs(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
//setup
|
|
testConfig, _ := config.Create()
|
|
|
|
//test
|
|
err := testConfig.ReadConfig(path.Join("testdata", "override_device_commands.yaml"))
|
|
require.NoError(t, err, "should correctly override device command")
|
|
|
|
//assert
|
|
require.Equal(t, "--info --json -T permissive", testConfig.GetCommandMetricsInfoArgs("/dev/sda"))
|
|
require.Equal(t, "--info --json", testConfig.GetCommandMetricsInfoArgs("/dev/sdb"))
|
|
//require.Equal(t, []models.ScanOverride{{Device: "/dev/sda", DeviceType: nil, Commands: {MetricsInfoArgs: "--info --json -T "}}}, scanOverrides)
|
|
}
|
|
|
|
func TestConfiguration_DeviceAllowList(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("present", func(t *testing.T) {
|
|
testConfig, err := config.Create()
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, testConfig.ReadConfig(path.Join("testdata", "allow_listed_devices_present.yaml")))
|
|
|
|
require.True(t, testConfig.IsAllowlistedDevice("/dev/sda"), "/dev/sda should be allow listed")
|
|
require.False(t, testConfig.IsAllowlistedDevice("/dev/sdc"), "/dev/sda should not be allow listed")
|
|
})
|
|
|
|
t.Run("missing", func(t *testing.T) {
|
|
testConfig, err := config.Create()
|
|
require.NoError(t, err)
|
|
|
|
// Really just any other config where the key is full missing
|
|
require.NoError(t, testConfig.ReadConfig(path.Join("testdata", "override_device_commands.yaml")))
|
|
|
|
// Anything should be allow listed if the key isnt there
|
|
require.True(t, testConfig.IsAllowlistedDevice("/dev/sda"), "/dev/sda should be allow listed")
|
|
require.True(t, testConfig.IsAllowlistedDevice("/dev/sdc"), "/dev/sda should be allow listed")
|
|
})
|
|
}
|