databricks-cli/bundle/config/mutator/process_environment_mode.go

90 lines
2.3 KiB
Go
Raw Normal View History

package mutator
import (
"context"
"fmt"
2023-07-07 16:04:28 +00:00
"path"
"github.com/databricks/cli/bundle"
"github.com/databricks/cli/bundle/config"
2023-07-07 09:12:14 +00:00
"github.com/databricks/databricks-sdk-go/service/jobs"
"github.com/databricks/databricks-sdk-go/service/ml"
)
type processEnvironmentMode struct{}
2023-07-07 09:09:09 +00:00
const developmentConcurrentRuns = 4
func ProcessEnvironmentMode() bundle.Mutator {
return &processEnvironmentMode{}
}
func (m *processEnvironmentMode) Name() string {
return "ProcessEnvironmentMode"
}
2023-07-03 14:30:42 +00:00
// Mark all resources as being for 'development' purposes, i.e.
// changing their their name, adding tags, and (in the future)
// marking them as 'hidden' in the UI.
2023-07-03 14:30:42 +00:00
func processDevelopmentMode(b *bundle.Bundle) error {
r := b.Config.Resources
for i := range r.Jobs {
2023-07-03 14:30:42 +00:00
r.Jobs[i].Name = "[dev] " + r.Jobs[i].Name
if r.Jobs[i].Tags == nil {
r.Jobs[i].Tags = make(map[string]string)
}
2023-07-03 14:30:42 +00:00
r.Jobs[i].Tags["dev"] = ""
if r.Jobs[i].MaxConcurrentRuns == 0 {
2023-07-07 09:09:09 +00:00
r.Jobs[i].MaxConcurrentRuns = developmentConcurrentRuns
}
2023-06-20 09:21:33 +00:00
if r.Jobs[i].Schedule != nil {
2023-07-07 09:12:14 +00:00
r.Jobs[i].Schedule.PauseStatus = jobs.PauseStatusPaused
2023-06-20 09:21:33 +00:00
}
if r.Jobs[i].Continuous != nil {
2023-07-07 09:12:14 +00:00
r.Jobs[i].Continuous.PauseStatus = jobs.PauseStatusPaused
2023-06-20 09:21:33 +00:00
}
if r.Jobs[i].Trigger != nil {
2023-07-07 09:12:14 +00:00
r.Jobs[i].Trigger.PauseStatus = jobs.PauseStatusPaused
2023-06-20 09:21:33 +00:00
}
}
for i := range r.Pipelines {
2023-07-03 14:30:42 +00:00
r.Pipelines[i].Name = "[dev] " + r.Pipelines[i].Name
r.Pipelines[i].Development = true
// (pipelines don't yet support tags)
}
for i := range r.Models {
2023-07-03 14:30:42 +00:00
r.Models[i].Name = "[dev] " + r.Models[i].Name
r.Models[i].Tags = append(r.Models[i].Tags, ml.ModelTag{Key: "dev", Value: ""})
}
for i := range r.Experiments {
2023-07-07 16:04:28 +00:00
filepath := r.Experiments[i].Name
dir := path.Dir(filepath)
base := path.Base(filepath)
if dir == "." {
r.Experiments[i].Name = "[dev] " + base
} else {
r.Experiments[i].Name = dir + "/[dev] " + base
}
2023-07-03 14:30:42 +00:00
r.Experiments[i].Tags = append(r.Experiments[i].Tags, ml.ExperimentTag{Key: "dev", Value: ""})
}
return nil
}
func (m *processEnvironmentMode) Apply(ctx context.Context, b *bundle.Bundle) error {
switch b.Config.Bundle.Mode {
2023-07-03 14:30:42 +00:00
case config.Development:
return processDevelopmentMode(b)
case "":
// No action
default:
return fmt.Errorf("unsupported value specified for 'mode': %s", b.Config.Bundle.Mode)
}
return nil
}