mirror of
https://github.com/grafana/grafana.git
synced 2025-07-29 22:57:16 +08:00
Tests: use t.Setenv
to set env vars (#69516)
This commit replaces `os.Setenv` with `t.Setenv` in tests. The environment variable is automatically restored to its original value when the test and all its subtests complete. Reference: https://pkg.go.dev/testing#T.Setenv Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
This commit is contained in:
@ -64,11 +64,10 @@ func TestLoadingSettings(t *testing.T) {
|
||||
})
|
||||
|
||||
t.Run("Should be able to override via environment variables", func(t *testing.T) {
|
||||
err := os.Setenv("GF_SECURITY_ADMIN_USER", "superduper")
|
||||
require.NoError(t, err)
|
||||
t.Setenv("GF_SECURITY_ADMIN_USER", "superduper")
|
||||
|
||||
cfg := NewCfg()
|
||||
err = cfg.Load(CommandLineArgs{HomePath: "../../"})
|
||||
err := cfg.Load(CommandLineArgs{HomePath: "../../"})
|
||||
require.Nil(t, err)
|
||||
|
||||
require.Equal(t, "superduper", cfg.AdminUser)
|
||||
@ -77,22 +76,20 @@ func TestLoadingSettings(t *testing.T) {
|
||||
})
|
||||
|
||||
t.Run("Should replace password when defined in environment", func(t *testing.T) {
|
||||
err := os.Setenv("GF_SECURITY_ADMIN_PASSWORD", "supersecret")
|
||||
require.NoError(t, err)
|
||||
t.Setenv("GF_SECURITY_ADMIN_PASSWORD", "supersecret")
|
||||
|
||||
cfg := NewCfg()
|
||||
err = cfg.Load(CommandLineArgs{HomePath: "../../"})
|
||||
err := cfg.Load(CommandLineArgs{HomePath: "../../"})
|
||||
require.Nil(t, err)
|
||||
|
||||
require.Contains(t, appliedEnvOverrides, "GF_SECURITY_ADMIN_PASSWORD=*********")
|
||||
})
|
||||
|
||||
t.Run("Should replace password in URL when url environment is defined", func(t *testing.T) {
|
||||
err := os.Setenv("GF_DATABASE_URL", "mysql://user:secret@localhost:3306/database")
|
||||
require.NoError(t, err)
|
||||
t.Setenv("GF_DATABASE_URL", "mysql://user:secret@localhost:3306/database")
|
||||
|
||||
cfg := NewCfg()
|
||||
err = cfg.Load(CommandLineArgs{HomePath: "../../"})
|
||||
err := cfg.Load(CommandLineArgs{HomePath: "../../"})
|
||||
require.Nil(t, err)
|
||||
|
||||
require.Contains(t, appliedEnvOverrides, "GF_DATABASE_URL=mysql://user:xxxxx@localhost:3306/database")
|
||||
@ -208,10 +205,9 @@ func TestLoadingSettings(t *testing.T) {
|
||||
|
||||
t.Run("Can use environment variables in config values", func(t *testing.T) {
|
||||
if runtime.GOOS == windows {
|
||||
err := os.Setenv("GF_DATA_PATH", `c:\tmp\env_override`)
|
||||
require.NoError(t, err)
|
||||
t.Setenv("GF_DATA_PATH", `c:\tmp\env_override`)
|
||||
cfg := NewCfg()
|
||||
err = cfg.Load(CommandLineArgs{
|
||||
err := cfg.Load(CommandLineArgs{
|
||||
HomePath: "../../",
|
||||
Args: []string{"cfg:paths.data=${GF_DATA_PATH}"},
|
||||
})
|
||||
@ -219,10 +215,9 @@ func TestLoadingSettings(t *testing.T) {
|
||||
|
||||
require.Equal(t, `c:\tmp\env_override`, cfg.DataPath)
|
||||
} else {
|
||||
err := os.Setenv("GF_DATA_PATH", "/tmp/env_override")
|
||||
require.NoError(t, err)
|
||||
t.Setenv("GF_DATA_PATH", "/tmp/env_override")
|
||||
cfg := NewCfg()
|
||||
err = cfg.Load(CommandLineArgs{
|
||||
err := cfg.Load(CommandLineArgs{
|
||||
HomePath: "../../",
|
||||
Args: []string{"cfg:paths.data=${GF_DATA_PATH}"},
|
||||
})
|
||||
@ -282,12 +277,10 @@ func TestLoadingSettings(t *testing.T) {
|
||||
})
|
||||
|
||||
t.Run("grafana.com API URL can be set separately from grafana.com URL", func(t *testing.T) {
|
||||
err := os.Setenv("GF_GRAFANA_NET_URL", "https://grafana-dev.com")
|
||||
require.NoError(t, err)
|
||||
err = os.Setenv("GF_GRAFANA_COM_API_URL", "http://grafana-dev.internal/api")
|
||||
require.NoError(t, err)
|
||||
t.Setenv("GF_GRAFANA_NET_URL", "https://grafana-dev.com")
|
||||
t.Setenv("GF_GRAFANA_COM_API_URL", "http://grafana-dev.internal/api")
|
||||
cfg := NewCfg()
|
||||
err = cfg.Load(CommandLineArgs{HomePath: "../../", Config: "../../conf/defaults.ini"})
|
||||
err := cfg.Load(CommandLineArgs{HomePath: "../../", Config: "../../conf/defaults.ini"})
|
||||
require.Nil(t, err)
|
||||
require.Equal(t, "https://grafana-dev.com", cfg.GrafanaComURL)
|
||||
require.Equal(t, "http://grafana-dev.internal/api", cfg.GrafanaComAPIURL)
|
||||
|
Reference in New Issue
Block a user