mirror of https://github.com/databricks/cli.git
feat: Change metadata.file_path, print warning when file_path is explicitly set
This commit is contained in:
parent
a65dc982a9
commit
42cad1413a
|
@ -29,10 +29,10 @@ func (m *applySourceLinkedDeploymentPreset) Apply(ctx context.Context, b *bundle
|
||||||
|
|
||||||
var diags diag.Diagnostics
|
var diags diag.Diagnostics
|
||||||
isDatabricksWorkspace := dbr.RunsOnRuntime(ctx) && strings.HasPrefix(b.SyncRootPath, "/Workspace/")
|
isDatabricksWorkspace := dbr.RunsOnRuntime(ctx) && strings.HasPrefix(b.SyncRootPath, "/Workspace/")
|
||||||
|
target := b.Config.Bundle.Target
|
||||||
|
|
||||||
if config.IsExplicitlyEnabled((b.Config.Presets.SourceLinkedDeployment)) {
|
if config.IsExplicitlyEnabled((b.Config.Presets.SourceLinkedDeployment)) {
|
||||||
if !isDatabricksWorkspace {
|
if !isDatabricksWorkspace {
|
||||||
target := b.Config.Bundle.Target
|
|
||||||
path := dyn.NewPath(dyn.Key("targets"), dyn.Key(target), dyn.Key("presets"), dyn.Key("source_linked_deployment"))
|
path := dyn.NewPath(dyn.Key("targets"), dyn.Key(target), dyn.Key("presets"), dyn.Key("source_linked_deployment"))
|
||||||
diags = diags.Append(
|
diags = diags.Append(
|
||||||
diag.Diagnostic{
|
diag.Diagnostic{
|
||||||
|
@ -56,5 +56,20 @@ func (m *applySourceLinkedDeploymentPreset) Apply(ctx context.Context, b *bundle
|
||||||
b.Config.Presets.SourceLinkedDeployment = &enabled
|
b.Config.Presets.SourceLinkedDeployment = &enabled
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if b.Config.Workspace.FilePath != "" && config.IsExplicitlyEnabled(b.Config.Presets.SourceLinkedDeployment) {
|
||||||
|
path := dyn.NewPath(dyn.Key("targets"), dyn.Key(target), dyn.Key("workspace"), dyn.Key("file_path"))
|
||||||
|
|
||||||
|
diags = diags.Append(
|
||||||
|
diag.Diagnostic{
|
||||||
|
Severity: diag.Warning,
|
||||||
|
Summary: "workspace.file_path setting will be ignored in source-linked deployment mode",
|
||||||
|
Paths: []dyn.Path{
|
||||||
|
path[2:],
|
||||||
|
},
|
||||||
|
Locations: b.Config.GetLocations(path[2:].String()),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
return diags
|
return diags
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,81 +25,87 @@ func TestApplyPresetsSourceLinkedDeployment(t *testing.T) {
|
||||||
workspacePath := "/Workspace/user.name@company.com"
|
workspacePath := "/Workspace/user.name@company.com"
|
||||||
|
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
bundlePath string
|
|
||||||
ctx context.Context
|
|
||||||
name string
|
name string
|
||||||
mode config.Mode
|
ctx context.Context
|
||||||
|
mutateBundle func(b *bundle.Bundle)
|
||||||
initialValue *bool
|
initialValue *bool
|
||||||
expectedValue *bool
|
expectedValue *bool
|
||||||
expectedWarning string
|
expectedWarning string
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "preset enabled, bundle in Workspace, databricks runtime",
|
name: "preset enabled, bundle in Workspace, databricks runtime",
|
||||||
bundlePath: workspacePath,
|
|
||||||
ctx: dbr.MockRuntime(testContext, true),
|
ctx: dbr.MockRuntime(testContext, true),
|
||||||
mode: config.Production,
|
|
||||||
initialValue: &enabled,
|
initialValue: &enabled,
|
||||||
expectedValue: &enabled,
|
expectedValue: &enabled,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "preset enabled, bundle not in Workspace, databricks runtime",
|
name: "preset enabled, bundle not in Workspace, databricks runtime",
|
||||||
bundlePath: "/Users/user.name@company.com",
|
ctx: dbr.MockRuntime(testContext, true),
|
||||||
ctx: dbr.MockRuntime(testContext, true),
|
mutateBundle: func(b *bundle.Bundle) {
|
||||||
mode: config.Production,
|
b.SyncRootPath = "/Users/user.name@company.com"
|
||||||
|
},
|
||||||
initialValue: &enabled,
|
initialValue: &enabled,
|
||||||
expectedValue: &disabled,
|
expectedValue: &disabled,
|
||||||
expectedWarning: "source-linked deployment is available only in the Databricks Workspace",
|
expectedWarning: "source-linked deployment is available only in the Databricks Workspace",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "preset enabled, bundle in Workspace, not databricks runtime",
|
name: "preset enabled, bundle in Workspace, not databricks runtime",
|
||||||
bundlePath: workspacePath,
|
|
||||||
ctx: dbr.MockRuntime(testContext, false),
|
ctx: dbr.MockRuntime(testContext, false),
|
||||||
mode: config.Production,
|
|
||||||
initialValue: &enabled,
|
initialValue: &enabled,
|
||||||
expectedValue: &disabled,
|
expectedValue: &disabled,
|
||||||
expectedWarning: "source-linked deployment is available only in the Databricks Workspace",
|
expectedWarning: "source-linked deployment is available only in the Databricks Workspace",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "preset disabled, bundle in Workspace, databricks runtime",
|
name: "preset disabled, bundle in Workspace, databricks runtime",
|
||||||
bundlePath: workspacePath,
|
|
||||||
ctx: dbr.MockRuntime(testContext, true),
|
ctx: dbr.MockRuntime(testContext, true),
|
||||||
mode: config.Production,
|
|
||||||
initialValue: &disabled,
|
initialValue: &disabled,
|
||||||
expectedValue: &disabled,
|
expectedValue: &disabled,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "preset nil, bundle in Workspace, databricks runtime",
|
name: "preset nil, bundle in Workspace, databricks runtime",
|
||||||
bundlePath: workspacePath,
|
|
||||||
ctx: dbr.MockRuntime(testContext, true),
|
ctx: dbr.MockRuntime(testContext, true),
|
||||||
mode: config.Production,
|
|
||||||
initialValue: nil,
|
initialValue: nil,
|
||||||
expectedValue: nil,
|
expectedValue: nil,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "preset nil, dev mode true, bundle in Workspace, databricks runtime",
|
name: "preset nil, dev mode true, bundle in Workspace, databricks runtime",
|
||||||
bundlePath: workspacePath,
|
ctx: dbr.MockRuntime(testContext, true),
|
||||||
ctx: dbr.MockRuntime(testContext, true),
|
mutateBundle: func(b *bundle.Bundle) {
|
||||||
mode: config.Development,
|
b.Config.Bundle.Mode = config.Development
|
||||||
|
},
|
||||||
initialValue: nil,
|
initialValue: nil,
|
||||||
expectedValue: &enabled,
|
expectedValue: &enabled,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "preset enabled, workspace.file_path is defined by user",
|
||||||
|
ctx: dbr.MockRuntime(testContext, true),
|
||||||
|
mutateBundle: func(b *bundle.Bundle) {
|
||||||
|
b.Config.Workspace.FilePath = "file_path"
|
||||||
|
},
|
||||||
|
initialValue: &enabled,
|
||||||
|
expectedValue: &enabled,
|
||||||
|
expectedWarning: "workspace.file_path setting will be ignored in source-linked deployment mode",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
b := &bundle.Bundle{
|
b := &bundle.Bundle{
|
||||||
SyncRootPath: tt.bundlePath,
|
SyncRootPath: workspacePath,
|
||||||
Config: config.Root{
|
Config: config.Root{
|
||||||
Presets: config.Presets{
|
Presets: config.Presets{
|
||||||
SourceLinkedDeployment: tt.initialValue,
|
SourceLinkedDeployment: tt.initialValue,
|
||||||
},
|
},
|
||||||
Bundle: config.Bundle{
|
|
||||||
Mode: tt.mode,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if tt.mutateBundle != nil {
|
||||||
|
tt.mutateBundle(b)
|
||||||
|
}
|
||||||
|
|
||||||
bundletest.SetLocation(b, "presets.source_linked_deployment", []dyn.Location{{File: "databricks.yml"}})
|
bundletest.SetLocation(b, "presets.source_linked_deployment", []dyn.Location{{File: "databricks.yml"}})
|
||||||
|
bundletest.SetLocation(b, "workspace.file_path", []dyn.Location{{File: "databricks.yml"}})
|
||||||
|
|
||||||
diags := bundle.Apply(tt.ctx, b, mutator.ApplySourceLinkedDeploymentPreset())
|
diags := bundle.Apply(tt.ctx, b, mutator.ApplySourceLinkedDeploymentPreset())
|
||||||
if diags.HasError() {
|
if diags.HasError() {
|
||||||
t.Fatalf("unexpected error: %v", diags)
|
t.Fatalf("unexpected error: %v", diags)
|
||||||
|
|
|
@ -54,5 +54,8 @@ func (m *compute) Apply(_ context.Context, b *bundle.Bundle) diag.Diagnostics {
|
||||||
|
|
||||||
// Set file upload destination of the bundle in metadata
|
// Set file upload destination of the bundle in metadata
|
||||||
b.Metadata.Config.Workspace.FilePath = b.Config.Workspace.FilePath
|
b.Metadata.Config.Workspace.FilePath = b.Config.Workspace.FilePath
|
||||||
|
if config.IsExplicitlyEnabled(b.Config.Presets.SourceLinkedDeployment) {
|
||||||
|
b.Metadata.Config.Workspace.FilePath = b.SyncRootPath
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,3 +97,24 @@ func TestComputeMetadataMutator(t *testing.T) {
|
||||||
|
|
||||||
assert.Equal(t, expectedMetadata, b.Metadata)
|
assert.Equal(t, expectedMetadata, b.Metadata)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestComputeMetadataMutatorSourceLinked(t *testing.T) {
|
||||||
|
syncRootPath := "/Users/shreyas.goenka@databricks.com/source"
|
||||||
|
enabled := true
|
||||||
|
b := &bundle.Bundle{
|
||||||
|
SyncRootPath: syncRootPath,
|
||||||
|
Config: config.Root{
|
||||||
|
Presets: config.Presets{
|
||||||
|
SourceLinkedDeployment: &enabled,
|
||||||
|
},
|
||||||
|
Workspace: config.Workspace{
|
||||||
|
FilePath: "/Users/shreyas.goenka@databricks.com/files",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
diags := bundle.Apply(context.Background(), b, Compute())
|
||||||
|
require.NoError(t, diags.Error())
|
||||||
|
|
||||||
|
assert.Equal(t, syncRootPath, b.Metadata.Config.Workspace.FilePath)
|
||||||
|
}
|
||||||
|
|
|
@ -41,6 +41,10 @@ func Initialize() bundle.Mutator {
|
||||||
mutator.PopulateCurrentUser(),
|
mutator.PopulateCurrentUser(),
|
||||||
mutator.LoadGitDetails(),
|
mutator.LoadGitDetails(),
|
||||||
|
|
||||||
|
// This mutator needs to be run before variable interpolation and defining default workspace paths
|
||||||
|
// because it affects how workspace variables are resolved.
|
||||||
|
mutator.ApplySourceLinkedDeploymentPreset(),
|
||||||
|
|
||||||
mutator.DefineDefaultWorkspaceRoot(),
|
mutator.DefineDefaultWorkspaceRoot(),
|
||||||
mutator.ExpandWorkspaceRoot(),
|
mutator.ExpandWorkspaceRoot(),
|
||||||
mutator.DefineDefaultWorkspacePaths(),
|
mutator.DefineDefaultWorkspacePaths(),
|
||||||
|
@ -52,10 +56,6 @@ func Initialize() bundle.Mutator {
|
||||||
|
|
||||||
mutator.SetVariables(),
|
mutator.SetVariables(),
|
||||||
|
|
||||||
// This mutator needs to be run before variable interpolation because it affects
|
|
||||||
// how workspace variables are resolved.
|
|
||||||
mutator.ApplySourceLinkedDeploymentPreset(),
|
|
||||||
|
|
||||||
// Intentionally placed before ResolveVariableReferencesInLookup, ResolveResourceReferences,
|
// Intentionally placed before ResolveVariableReferencesInLookup, ResolveResourceReferences,
|
||||||
// ResolveVariableReferencesInComplexVariables and ResolveVariableReferences.
|
// ResolveVariableReferencesInComplexVariables and ResolveVariableReferences.
|
||||||
// See what is expected in PythonMutatorPhaseInit doc
|
// See what is expected in PythonMutatorPhaseInit doc
|
||||||
|
|
Loading…
Reference in New Issue