package helm import ( "fmt" "github.com/stretchr/testify/suite" "os" "strings" "testing" ) type ConfigTestSuite struct { suite.Suite // These tests need to mutate the environment, so the suite.setenv and .unsetenv functions store the original contents of the // relevant variable in this map. Its use of *string is so they can distinguish between "not set" and "set to empty string" envBackup map[string]*string } func TestConfigTestSuite(t *testing.T) { suite.Run(t, new(ConfigTestSuite)) } func (suite *ConfigTestSuite) TestNewConfigWithPluginPrefix() { suite.unsetenv("HELM_COMMAND") suite.unsetenv("UPDATE_DEPENDENCIES") suite.unsetenv("DEBUG") suite.setenv("PLUGIN_HELM_COMMAND", "execute order 66") suite.setenv("PLUGIN_UPDATE_DEPENDENCIES", "true") suite.setenv("PLUGIN_DEBUG", "true") cfg, err := NewConfig(&strings.Builder{}, &strings.Builder{}) suite.Require().NoError(err) suite.Equal("execute order 66", cfg.Command) suite.True(cfg.UpdateDependencies) suite.True(cfg.Debug) } func (suite *ConfigTestSuite) TestNewConfigWithNoPrefix() { suite.unsetenv("PLUGIN_HELM_COMMAND") suite.unsetenv("PLUGIN_UPDATE_DEPENDENCIES") suite.unsetenv("PLUGIN_DEBUG") suite.setenv("HELM_COMMAND", "execute order 66") suite.setenv("UPDATE_DEPENDENCIES", "true") suite.setenv("DEBUG", "true") cfg, err := NewConfig(&strings.Builder{}, &strings.Builder{}) suite.Require().NoError(err) suite.Equal("execute order 66", cfg.Command) suite.True(cfg.UpdateDependencies) suite.True(cfg.Debug) } func (suite *ConfigTestSuite) TestNewConfigWithConflictingVariables() { suite.setenv("PLUGIN_HELM_COMMAND", "execute order 66") suite.setenv("HELM_COMMAND", "defend the jedi") // values from the `environment` block override those from `settings` cfg, err := NewConfig(&strings.Builder{}, &strings.Builder{}) suite.Require().NoError(err) suite.Equal("defend the jedi", cfg.Command) } func (suite *ConfigTestSuite) TestNewConfigInfersNumbersAreSeconds() { suite.setenv("PLUGIN_TIMEOUT", "42") cfg, err := NewConfig(&strings.Builder{}, &strings.Builder{}) suite.Require().NoError(err) suite.Equal("42s", cfg.Timeout) } func (suite *ConfigTestSuite) TestNewConfigSetsWriters() { stdout := &strings.Builder{} stderr := &strings.Builder{} cfg, err := NewConfig(stdout, stderr) suite.Require().NoError(err) suite.Equal(stdout, cfg.Stdout) suite.Equal(stderr, cfg.Stderr) } func (suite *ConfigTestSuite) TestDeprecatedSettingWarnings() { for _, varname := range deprecatedVars { suite.setenv(varname, "deprecoat") // environment-block entries should cause warnings } suite.unsetenv("PURGE") suite.setenv("PLUGIN_PURGE", "true") // settings-block entries should cause warnings suite.setenv("UPGRADE", "") // entries should cause warnings even when set to empty string stderr := &strings.Builder{} _, err := NewConfig(&strings.Builder{}, stderr) suite.NoError(err) for _, varname := range deprecatedVars { suite.Contains(stderr.String(), fmt.Sprintf("Warning: ignoring deprecated '%s' setting\n", strings.ToLower(varname))) } } func (suite *ConfigTestSuite) TestLogDebug() { suite.setenv("DEBUG", "true") suite.setenv("HELM_COMMAND", "upgrade") stderr := strings.Builder{} stdout := strings.Builder{} _, err := NewConfig(&stdout, &stderr) suite.Require().NoError(err) suite.Equal("", stdout.String()) suite.Regexp(`^Generated config: \{Command:upgrade.*\}`, stderr.String()) } func (suite *ConfigTestSuite) TestLogDebugCensorsKubeToken() { stderr := &strings.Builder{} kubeToken := "I'm shy! Don't put me in your build logs!" cfg := Config{ Debug: true, KubeToken: kubeToken, Stderr: stderr, } cfg.logDebug() suite.Contains(stderr.String(), "KubeToken:(redacted)") suite.Equal(kubeToken, cfg.KubeToken) // The actual config value should be left unchanged } func (suite *ConfigTestSuite) setenv(key, val string) { orig, ok := os.LookupEnv(key) if ok { suite.envBackup[key] = &orig } else { suite.envBackup[key] = nil } os.Setenv(key, val) } func (suite *ConfigTestSuite) unsetenv(key string) { orig, ok := os.LookupEnv(key) if ok { suite.envBackup[key] = &orig } else { suite.envBackup[key] = nil } os.Unsetenv(key) } func (suite *ConfigTestSuite) BeforeTest(_, _ string) { suite.envBackup = make(map[string]*string) } func (suite *ConfigTestSuite) AfterTest(_, _ string) { for key, val := range suite.envBackup { if val == nil { os.Unsetenv(key) } else { os.Setenv(key, *val) } } }