2023-06-18 14:47:01 +00:00
|
|
|
package mutator
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/databricks/cli/bundle"
|
|
|
|
"github.com/databricks/cli/bundle/config"
|
|
|
|
"github.com/databricks/cli/bundle/config/resources"
|
|
|
|
)
|
|
|
|
|
2023-07-03 15:56:45 +00:00
|
|
|
type overrideCompute struct{}
|
2023-06-18 14:47:01 +00:00
|
|
|
|
2023-07-03 15:56:45 +00:00
|
|
|
func OverrideCompute() bundle.Mutator {
|
|
|
|
return &overrideCompute{}
|
2023-06-18 14:47:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (m *overrideCompute) Name() string {
|
|
|
|
return "OverrideCompute"
|
|
|
|
}
|
|
|
|
|
2023-07-03 15:56:45 +00:00
|
|
|
func overrideJobCompute(j *resources.Job, compute string) {
|
2023-06-18 14:47:01 +00:00
|
|
|
for i := range j.Tasks {
|
|
|
|
task := &j.Tasks[i]
|
|
|
|
if task.NewCluster != nil {
|
|
|
|
task.NewCluster = nil
|
2023-07-03 15:56:45 +00:00
|
|
|
task.ExistingClusterId = compute
|
2023-06-18 14:47:01 +00:00
|
|
|
} else if task.ExistingClusterId != "" {
|
2023-07-03 15:56:45 +00:00
|
|
|
task.ExistingClusterId = compute
|
2023-06-18 14:47:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *overrideCompute) Apply(ctx context.Context, b *bundle.Bundle) error {
|
2023-07-03 15:56:45 +00:00
|
|
|
if b.Config.Bundle.Compute == "" {
|
2023-06-18 14:47:01 +00:00
|
|
|
return nil
|
|
|
|
}
|
2023-07-03 14:30:42 +00:00
|
|
|
if b.Config.Bundle.Mode != config.Development {
|
2023-06-18 14:47:01 +00:00
|
|
|
return fmt.Errorf("cannot override compute for an environment that does not use 'mode: debug'")
|
|
|
|
}
|
|
|
|
|
|
|
|
r := b.Config.Resources
|
|
|
|
for i := range r.Jobs {
|
2023-07-03 15:56:45 +00:00
|
|
|
overrideJobCompute(r.Jobs[i], b.Config.Bundle.Compute)
|
2023-06-18 14:47:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|