From e93a9892f68c7d09a38d81fa7858a14b20338737 Mon Sep 17 00:00:00 2001 From: kkotula Date: Wed, 13 Dec 2023 14:43:51 +0100 Subject: [PATCH] fix(config): changed two feature flags types from boolean to string. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit When merging two configurations - the default one defined in the application’s code and the user-defined one - if a feature flag is set to false in the user config but set to true in the default config, the default value will take precedence over the user-defined value. In such case, it is impossible to disable the feature. --- pkg/settings/global/settings.go | 10 +++++----- pkg/settings/global/settings_test.go | 4 ++-- pkg/web/routes.go | 2 +- pkg/web/routes_test.go | 6 +++--- 4 files changed, 11 insertions(+), 11 deletions(-) diff --git a/pkg/settings/global/settings.go b/pkg/settings/global/settings.go index 29b069b7..e8668cab 100644 --- a/pkg/settings/global/settings.go +++ b/pkg/settings/global/settings.go @@ -90,8 +90,8 @@ func NewDefaultSettings() Settings { EventLogsOnly: false, }, UserWritePermissionsCheckEnabled: false, - MultipleBranchesEnabled: true, - DinghyIgnoreRegexp2Enabled: true, + MultipleBranchesEnabled: "true", + DinghyIgnoreRegexp2Enabled: "true", } } @@ -158,13 +158,13 @@ type Settings struct { // SQL configuration for dinghy SQL Sqlconfig `json:"sql,omitempty" yaml:"sql"` // Enable regexp2 for .dinghyignore file - DinghyIgnoreRegexp2Enabled bool `json:"dinghyIgnoreRegexp2Enabled" yaml:"dinghyIgnoreRegexp2Enabled"` + DinghyIgnoreRegexp2Enabled string `json:"dinghyIgnoreRegexp2Enabled" yaml:"dinghyIgnoreRegexp2Enabled"` // Check user's write permissions by calling Fiat /authorize/${user}/roles before updating application UserWritePermissionsCheckEnabled bool `json:"userWritePermissionsCheckEnabled" yaml:"userWritePermissionsCheckEnabled"` // Users for whom we should ignore and skip write permissions validations IgnoreUsersPermissions []string `json:"ignoreUsersWritePermissions" yaml:"ignoreUsersWritePermissions"` // Enable processing of multiple branches in single repository - MultipleBranchesEnabled bool `json:"multipleBranchesEnabled" yaml:"multipleBranchesEnabled"` + MultipleBranchesEnabled string `json:"multipleBranchesEnabled" yaml:"multipleBranchesEnabled"` // Enable using savePipeline and updatePipeline tasks from Orca UpsertPipelineUsingOrcaTaskEnabled bool `json:"upsertPipelineUsingOrcaTaskEnabled" yaml:"upsertPipelineUsingOrcaTaskEnabled"` } @@ -259,7 +259,7 @@ type RepoConfig struct { func (s *Settings) GetRepoConfig(provider, repo, branch string) *RepoConfig { var match = func(repositoryConfiguration RepoConfig) bool { - if s.MultipleBranchesEnabled { + if "true" == s.MultipleBranchesEnabled { return repositoryConfiguration.Provider == provider && repositoryConfiguration.Repo == repo && repositoryConfiguration.Branch == branch } return repositoryConfiguration.Provider == provider && repositoryConfiguration.Repo == repo diff --git a/pkg/settings/global/settings_test.go b/pkg/settings/global/settings_test.go index ecb787e8..71d541ad 100644 --- a/pkg/settings/global/settings_test.go +++ b/pkg/settings/global/settings_test.go @@ -85,7 +85,7 @@ func TestSettings_GetRepoConfig(t *testing.T) { }, "when feature flag enabled, search by provider and repo and branch": { settings: Settings{ - MultipleBranchesEnabled: true, + MultipleBranchesEnabled: "true", RepoConfig: []RepoConfig{ { Provider: "github", @@ -106,7 +106,7 @@ func TestSettings_GetRepoConfig(t *testing.T) { }, "when feature flag disabled, search just by provider and repo": { settings: Settings{ - MultipleBranchesEnabled: false, + MultipleBranchesEnabled: "false", RepoConfig: []RepoConfig{ { Provider: "github", diff --git a/pkg/web/routes.go b/pkg/web/routes.go index 81aea5f1..0ebf5a58 100644 --- a/pkg/web/routes.go +++ b/pkg/web/routes.go @@ -700,7 +700,7 @@ func (wa *WebAPI) buildPipelines( var ignoreFile IgnoreFile - if s.DinghyIgnoreRegexp2Enabled { + if "true" == s.DinghyIgnoreRegexp2Enabled { ignoreFile = NewRegexp2IgnoreFile(ignoreFilePatterns, l) } else { ignoreFile = NewRegexpIgnoreFile(ignoreFilePatterns, l) diff --git a/pkg/web/routes_test.go b/pkg/web/routes_test.go index 1448b45b..bfb862c4 100644 --- a/pkg/web/routes_test.go +++ b/pkg/web/routes_test.go @@ -593,7 +593,7 @@ func TestShouldRunValidationWhenBranchIsWrongAndIsMaster(t *testing.T) { Ref: "master", } s := &global.Settings{ - MultipleBranchesEnabled: true, + MultipleBranchesEnabled: "true", DinghyFilename: "dinghyfile", TemplateOrg: "test_org", TemplateRepo: "test_repo", @@ -696,7 +696,7 @@ func TestBuildPipelinesWhenDinghyIgnoreRegexp2Enabled(t *testing.T) { }, }, GitHubToken: "test_github_token", - DinghyIgnoreRegexp2Enabled: true, + DinghyIgnoreRegexp2Enabled: "true", } sc := source.NewMockSourceConfiguration(c) @@ -753,7 +753,7 @@ func TestBuildPipelinesWhenDinghyIgnoreRegexp2Disabled(t *testing.T) { }, }, GitHubToken: "test_github_token", - DinghyIgnoreRegexp2Enabled: false, + DinghyIgnoreRegexp2Enabled: "false", } sc := source.NewMockSourceConfiguration(c)