Skip to content

Commit

Permalink
Add a recommendation for pipeline catalogs
Browse files Browse the repository at this point in the history
  • Loading branch information
lennartkats-db committed Dec 20, 2024
1 parent 65f10d1 commit e0b6fad
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 2 deletions.
29 changes: 28 additions & 1 deletion bundle/config/mutator/apply_presets_catalog_schema.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,13 +65,24 @@ func (m *applyPresetsCatalogSchema) Apply(ctx context.Context, b *bundle.Bundle)
}

// Pipelines
for _, pl := range r.Pipelines {
allSameCatalog := allPipelinesSameCatalog(&r)
for key, pl := range r.Pipelines {
if pl.PipelineSpec == nil {
continue
}
if pl.Catalog == "" {
pl.Catalog = p.Catalog
}
if allSameCatalog && pl.Catalog == p.Catalog {
// Just for the common case where all pipelines have the same catalog,
// we show a recommendation to leave it out and rely on presets.
// This can happen when using the original default template.
diags = diags.Extend(diag.Diagnostics{{
Summary: "Omit the catalog field since it will be automatically populated from presets.catalog",
Severity: diag.Recommendation,
Locations: b.Config.GetLocations("resources.pipelines." + key + ".catalog"),
}})
}
if pl.GatewayDefinition != nil {
if pl.GatewayDefinition.GatewayStorageCatalog == "" {
pl.GatewayDefinition.GatewayStorageCatalog = p.Catalog
Expand Down Expand Up @@ -347,3 +358,19 @@ func fileIncludesPattern(ctx context.Context, filePath string, expected string)
}
return matched
}

func allPipelinesSameCatalog(r *config.Resources) bool {
var firstCatalog string

for _, pl := range r.Pipelines {
if pl.PipelineSpec == nil || pl.PipelineSpec.Catalog == "" {
return false
}
if firstCatalog == "" {
firstCatalog = pl.PipelineSpec.Catalog
} else if pl.PipelineSpec.Catalog != firstCatalog {
return false
}
}
return firstCatalog != ""
}
12 changes: 11 additions & 1 deletion bundle/config/mutator/apply_presets_catalog_schema_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ func TestApplyPresetsCatalogSchemaWhenAlreadySet(t *testing.T) {
b := mockPresetsCatalogSchema()
recordedFields := recordPlaceholderFields(t, b)

diags := bundle.Apply(context.Background(), b, mutator.ApplyPresets())
diags := bundle.Apply(context.Background(), b, mutator.ApplyPresetsCatalogSchema())
require.NoError(t, diags.Error())

for _, f := range recordedFields {
Expand All @@ -190,6 +190,16 @@ func TestApplyPresetsCatalogSchemaWhenAlreadySet(t *testing.T) {
}
}

func TestApplyPresetsCatalogSchemaRecommmendRemovingCatalog(t *testing.T) {
b := mockPresetsCatalogSchema()
b.Config.Resources.Jobs["key"].Parameters = nil // avoid warnings about the job parameters
b.Config.Resources.Pipelines["key"].Catalog = "my_catalog"

diags := bundle.Apply(context.Background(), b, mutator.ApplyPresetsCatalogSchema())
require.Equal(t, 1, len(diags))
require.Equal(t, "Omit the catalog field since it will be automatically populated from presets.catalog", diags[0].Summary)
}

func TestApplyPresetsCatalogSchemaWhenNotSet(t *testing.T) {
b := mockPresetsCatalogSchema()
recordedFields := recordPlaceholderFields(t, b)
Expand Down

0 comments on commit e0b6fad

Please sign in to comment.