2019-04-25 04:52:08 +07:00
|
|
|
package configuration
|
|
|
|
|
|
|
|
import (
|
2020-01-22 03:56:44 +07:00
|
|
|
"os"
|
2019-04-25 04:52:08 +07:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2020-01-22 03:56:44 +07:00
|
|
|
"github.com/stretchr/testify/require"
|
2019-04-25 04:52:08 +07:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestShouldParseConfigFile(t *testing.T) {
|
2020-01-22 05:02:03 +07:00
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_JWT_SECRET", "secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_DUO_API_SECRET_KEY", "duo_secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_SESSION_SECRET", "session_secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_AUTHENTICATION_BACKEND_LDAP_PASSWORD", "ldap_secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_NOTIFIER_SMTP_PASSWORD", "smtp_secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_SESSION_REDIS_PASSWORD", "redis_secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_STORAGE_MYSQL_PASSWORD", "mysql_secret_from_env"))
|
|
|
|
require.NoError(t, os.Setenv("AUTHELIA_STORAGE_POSTGRES_PASSWORD", "postgres_secret_from_env"))
|
2020-01-22 03:56:44 +07:00
|
|
|
|
2019-11-30 21:27:39 +07:00
|
|
|
config, errors := Read("./test_resources/config.yml")
|
2019-04-25 04:52:08 +07:00
|
|
|
|
2020-01-22 03:56:44 +07:00
|
|
|
require.Len(t, errors, 0)
|
2019-04-25 04:52:08 +07:00
|
|
|
|
|
|
|
assert.Equal(t, 9091, config.Port)
|
2020-03-10 02:57:53 +07:00
|
|
|
assert.Equal(t, "debug", config.LogLevel)
|
2019-04-25 04:52:08 +07:00
|
|
|
assert.Equal(t, "https://home.example.com:8080/", config.DefaultRedirectionURL)
|
|
|
|
assert.Equal(t, "authelia.com", config.TOTP.Issuer)
|
2020-01-22 03:56:44 +07:00
|
|
|
assert.Equal(t, "secret_from_env", config.JWTSecret)
|
2019-04-25 04:52:08 +07:00
|
|
|
|
|
|
|
assert.Equal(t, "api-123456789.example.com", config.DuoAPI.Hostname)
|
|
|
|
assert.Equal(t, "ABCDEF", config.DuoAPI.IntegrationKey)
|
2020-01-22 03:56:44 +07:00
|
|
|
assert.Equal(t, "duo_secret_from_env", config.DuoAPI.SecretKey)
|
|
|
|
|
2020-01-22 05:02:03 +07:00
|
|
|
assert.Equal(t, "session_secret_from_env", config.Session.Secret)
|
|
|
|
assert.Equal(t, "ldap_secret_from_env", config.AuthenticationBackend.Ldap.Password)
|
|
|
|
assert.Equal(t, "smtp_secret_from_env", config.Notifier.SMTP.Password)
|
|
|
|
assert.Equal(t, "redis_secret_from_env", config.Session.Redis.Password)
|
|
|
|
assert.Equal(t, "mysql_secret_from_env", config.Storage.MySQL.Password)
|
|
|
|
assert.Equal(t, "postgres_secret_from_env", config.Storage.PostgreSQL.Password)
|
|
|
|
|
2020-01-22 03:56:44 +07:00
|
|
|
assert.Equal(t, "deny", config.AccessControl.DefaultPolicy)
|
2020-04-16 07:18:11 +07:00
|
|
|
assert.Len(t, config.AccessControl.Rules, 12)
|
2019-04-25 04:52:08 +07:00
|
|
|
}
|