mirror of
https://github.com/0rangebananaspy/authelia.git
synced 2024-09-14 22:47:21 +07:00
a7e867a699
This commit replaces github.com/spf13/viper with github.com/knadh/koanf. Koanf is very similar library to viper, with less dependencies and several quality of life differences. This also allows most config options to be defined by ENV. Lastly it also enables the use of split configuration files which can be configured by setting the --config flag multiple times. Co-authored-by: Amir Zarrinkafsh <nightah@me.com>
112 lines
3.5 KiB
Go
112 lines
3.5 KiB
Go
package validator
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/authelia/authelia/internal/configuration/schema"
|
|
)
|
|
|
|
func TestShouldSetDefaultLoggingValues(t *testing.T) {
|
|
config := &schema.Configuration{}
|
|
|
|
validator := schema.NewStructValidator()
|
|
|
|
ValidateLogging(config, validator)
|
|
|
|
assert.Len(t, validator.Warnings(), 0)
|
|
assert.Len(t, validator.Errors(), 0)
|
|
|
|
require.NotNil(t, config.Log.KeepStdout)
|
|
|
|
assert.Equal(t, "", config.LogLevel) // TODO: DEPRECATED TEST. Remove in 4.33.0.
|
|
assert.Equal(t, "", config.LogFormat) // TODO: DEPRECATED TEST. Remove in 4.33.0.
|
|
assert.Equal(t, "", config.LogFilePath) // TODO: DEPRECATED TEST. Remove in 4.33.0.
|
|
|
|
assert.Equal(t, "info", config.Log.Level)
|
|
assert.Equal(t, "text", config.Log.Format)
|
|
assert.Equal(t, "", config.Log.FilePath)
|
|
}
|
|
|
|
func TestShouldRaiseErrorOnInvalidLoggingLevel(t *testing.T) {
|
|
config := &schema.Configuration{
|
|
Log: schema.LogConfiguration{
|
|
Level: "TRACE",
|
|
},
|
|
}
|
|
|
|
validator := schema.NewStructValidator()
|
|
|
|
ValidateLogging(config, validator)
|
|
|
|
assert.Len(t, validator.Warnings(), 0)
|
|
require.Len(t, validator.Errors(), 1)
|
|
|
|
assert.EqualError(t, validator.Errors()[0], "the log level 'TRACE' is invalid, must be one of: trace, debug, info, warn, error")
|
|
}
|
|
|
|
// TODO: DEPRECATED TEST. Remove in 4.33.0.
|
|
func TestShouldMigrateDeprecatedLoggingConfig(t *testing.T) {
|
|
config := &schema.Configuration{
|
|
LogLevel: "trace",
|
|
LogFormat: "json",
|
|
LogFilePath: "/a/b/c",
|
|
}
|
|
|
|
validator := schema.NewStructValidator()
|
|
|
|
ValidateLogging(config, validator)
|
|
|
|
assert.Len(t, validator.Errors(), 0)
|
|
require.Len(t, validator.Warnings(), 3)
|
|
|
|
require.NotNil(t, config.Log.KeepStdout)
|
|
|
|
assert.Equal(t, "trace", config.LogLevel)
|
|
assert.Equal(t, "json", config.LogFormat)
|
|
assert.Equal(t, "/a/b/c", config.LogFilePath)
|
|
|
|
assert.Equal(t, "trace", config.Log.Level)
|
|
assert.Equal(t, "json", config.Log.Format)
|
|
assert.Equal(t, "/a/b/c", config.Log.FilePath)
|
|
|
|
assert.EqualError(t, validator.Warnings()[0], fmt.Sprintf(errFmtDeprecatedConfigurationKey, "log_level", "4.33.0", "log.level"))
|
|
assert.EqualError(t, validator.Warnings()[1], fmt.Sprintf(errFmtDeprecatedConfigurationKey, "log_format", "4.33.0", "log.format"))
|
|
assert.EqualError(t, validator.Warnings()[2], fmt.Sprintf(errFmtDeprecatedConfigurationKey, "log_file_path", "4.33.0", "log.file_path"))
|
|
}
|
|
|
|
func TestShouldRaiseErrorsAndNotOverwriteConfigurationWhenUsingDeprecatedLoggingConfig(t *testing.T) {
|
|
config := &schema.Configuration{
|
|
Log: schema.LogConfiguration{
|
|
Level: "info",
|
|
Format: "text",
|
|
FilePath: "/x/y/z",
|
|
KeepStdout: true,
|
|
},
|
|
LogLevel: "debug",
|
|
LogFormat: "json",
|
|
LogFilePath: "/a/b/c",
|
|
}
|
|
|
|
validator := schema.NewStructValidator()
|
|
|
|
ValidateLogging(config, validator)
|
|
|
|
require.NotNil(t, config.Log.KeepStdout)
|
|
|
|
assert.Equal(t, "info", config.Log.Level)
|
|
assert.Equal(t, "text", config.Log.Format)
|
|
assert.True(t, config.Log.KeepStdout)
|
|
assert.Equal(t, "/x/y/z", config.Log.FilePath)
|
|
|
|
assert.Len(t, validator.Errors(), 0)
|
|
require.Len(t, validator.Warnings(), 3)
|
|
|
|
assert.EqualError(t, validator.Warnings()[0], fmt.Sprintf(errFmtDeprecatedConfigurationKey, "log_level", "4.33.0", "log.level"))
|
|
assert.EqualError(t, validator.Warnings()[1], fmt.Sprintf(errFmtDeprecatedConfigurationKey, "log_format", "4.33.0", "log.format"))
|
|
assert.EqualError(t, validator.Warnings()[2], fmt.Sprintf(errFmtDeprecatedConfigurationKey, "log_file_path", "4.33.0", "log.file_path"))
|
|
}
|