mirror of https://github.com/databricks/cli.git
address comments
This commit is contained in:
parent
ed59500c1e
commit
fcc47de4fe
|
@ -40,6 +40,9 @@ func findSchema(b *bundle.Bundle, catalogName, schemaName string) (string, *reso
|
||||||
}
|
}
|
||||||
|
|
||||||
func resolveVolume(v *resources.Volume, b *bundle.Bundle) {
|
func resolveVolume(v *resources.Volume, b *bundle.Bundle) {
|
||||||
|
if v.CreateVolumeRequestContent == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
schemaK, schema := findSchema(b, v.CatalogName, v.SchemaName)
|
schemaK, schema := findSchema(b, v.CatalogName, v.SchemaName)
|
||||||
if schema == nil {
|
if schema == nil {
|
||||||
return
|
return
|
||||||
|
@ -49,6 +52,9 @@ func resolveVolume(v *resources.Volume, b *bundle.Bundle) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func resolvePipeline(p *resources.Pipeline, b *bundle.Bundle) {
|
func resolvePipeline(p *resources.Pipeline, b *bundle.Bundle) {
|
||||||
|
if p.PipelineSpec == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
// schema and target have the same semantics in the DLT API but are mutually
|
// schema and target have the same semantics in the DLT API but are mutually
|
||||||
// exclusive. If schema is set, the pipeline is in direct publishing mode
|
// exclusive. If schema is set, the pipeline is in direct publishing mode
|
||||||
// and can write tables to multiple schemas (vs target which is limited to a single schema).
|
// and can write tables to multiple schemas (vs target which is limited to a single schema).
|
||||||
|
|
|
@ -72,6 +72,10 @@ func TestCaptureSchemaDependencyForVolume(t *testing.T) {
|
||||||
SchemaName: "schemaX",
|
SchemaName: "schemaX",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
"nilVolume": {},
|
||||||
|
"emptyVolume": {
|
||||||
|
CreateVolumeRequestContent: &catalog.CreateVolumeRequestContent{},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -79,11 +83,15 @@ func TestCaptureSchemaDependencyForVolume(t *testing.T) {
|
||||||
|
|
||||||
d := bundle.Apply(context.Background(), b, CaptureSchemaDependency())
|
d := bundle.Apply(context.Background(), b, CaptureSchemaDependency())
|
||||||
require.Nil(t, d)
|
require.Nil(t, d)
|
||||||
assert.Equal(t, b.Config.Resources.Volumes["volume1"].CreateVolumeRequestContent.SchemaName, "${resources.schemas.schema1.name}")
|
|
||||||
assert.Equal(t, b.Config.Resources.Volumes["volume2"].CreateVolumeRequestContent.SchemaName, "${resources.schemas.schema2.name}")
|
assert.Equal(t, "${resources.schemas.schema1.name}", b.Config.Resources.Volumes["volume1"].CreateVolumeRequestContent.SchemaName)
|
||||||
assert.Equal(t, b.Config.Resources.Volumes["volume3"].CreateVolumeRequestContent.SchemaName, "${resources.schemas.schema3.name}")
|
assert.Equal(t, "${resources.schemas.schema2.name}", b.Config.Resources.Volumes["volume2"].CreateVolumeRequestContent.SchemaName)
|
||||||
assert.Equal(t, b.Config.Resources.Volumes["volume4"].CreateVolumeRequestContent.SchemaName, "foobar")
|
assert.Equal(t, "${resources.schemas.schema3.name}", b.Config.Resources.Volumes["volume3"].CreateVolumeRequestContent.SchemaName)
|
||||||
assert.Equal(t, b.Config.Resources.Volumes["volume5"].CreateVolumeRequestContent.SchemaName, "schemaX")
|
assert.Equal(t, "foobar", b.Config.Resources.Volumes["volume4"].CreateVolumeRequestContent.SchemaName)
|
||||||
|
assert.Equal(t, "schemaX", b.Config.Resources.Volumes["volume5"].CreateVolumeRequestContent.SchemaName)
|
||||||
|
|
||||||
|
assert.Nil(t, b.Config.Resources.Volumes["nilVolume"].CreateVolumeRequestContent)
|
||||||
|
assert.Empty(t, b.Config.Resources.Volumes["emptyVolume"].CreateVolumeRequestContent)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCaptureSchemaDependencyForPipelinesWithTarget(t *testing.T) {
|
func TestCaptureSchemaDependencyForPipelinesWithTarget(t *testing.T) {
|
||||||
|
@ -109,6 +117,10 @@ func TestCaptureSchemaDependencyForPipelinesWithTarget(t *testing.T) {
|
||||||
Name: "barfoo",
|
Name: "barfoo",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
"nilschema": {},
|
||||||
|
"emptyschema": {
|
||||||
|
CreateSchema: &catalog.CreateSchema{},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
Pipelines: map[string]*resources.Pipeline{
|
Pipelines: map[string]*resources.Pipeline{
|
||||||
"pipeline1": {
|
"pipeline1": {
|
||||||
|
@ -154,6 +166,10 @@ func TestCaptureSchemaDependencyForPipelinesWithTarget(t *testing.T) {
|
||||||
Name: "whatever",
|
Name: "whatever",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
"nilPipeline": {},
|
||||||
|
"emptyPipeline": {
|
||||||
|
PipelineSpec: &pipelines.PipelineSpec{},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -161,13 +177,17 @@ func TestCaptureSchemaDependencyForPipelinesWithTarget(t *testing.T) {
|
||||||
|
|
||||||
d := bundle.Apply(context.Background(), b, CaptureSchemaDependency())
|
d := bundle.Apply(context.Background(), b, CaptureSchemaDependency())
|
||||||
require.Nil(t, d)
|
require.Nil(t, d)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline1"].Schema, "${resources.schemas.schema1.name}")
|
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline2"].Schema, "${resources.schemas.schema2.name}")
|
assert.Equal(t, "${resources.schemas.schema1.name}", b.Config.Resources.Pipelines["pipeline1"].Schema)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline3"].Schema, "${resources.schemas.schema3.name}")
|
assert.Equal(t, "${resources.schemas.schema2.name}", b.Config.Resources.Pipelines["pipeline2"].Schema)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline4"].Schema, "foobar")
|
assert.Equal(t, "${resources.schemas.schema3.name}", b.Config.Resources.Pipelines["pipeline3"].Schema)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline5"].Schema, "schemaX")
|
assert.Equal(t, "foobar", b.Config.Resources.Pipelines["pipeline4"].Schema)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline6"].Schema, "foobar")
|
assert.Equal(t, "schemaX", b.Config.Resources.Pipelines["pipeline5"].Schema)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline7"].Schema, "")
|
assert.Equal(t, "foobar", b.Config.Resources.Pipelines["pipeline6"].Schema)
|
||||||
|
assert.Equal(t, "", b.Config.Resources.Pipelines["pipeline7"].Schema)
|
||||||
|
|
||||||
|
assert.Nil(t, b.Config.Resources.Pipelines["nilPipeline"].PipelineSpec)
|
||||||
|
assert.Empty(t, b.Config.Resources.Pipelines["emptyPipeline"].PipelineSpec)
|
||||||
|
|
||||||
for _, k := range []string{"pipeline1", "pipeline2", "pipeline3", "pipeline4", "pipeline5", "pipeline6", "pipeline7"} {
|
for _, k := range []string{"pipeline1", "pipeline2", "pipeline3", "pipeline4", "pipeline5", "pipeline6", "pipeline7"} {
|
||||||
assert.Empty(t, b.Config.Resources.Pipelines[k].Target)
|
assert.Empty(t, b.Config.Resources.Pipelines[k].Target)
|
||||||
|
@ -197,6 +217,10 @@ func TestCaptureSchemaDependencyForPipelinesWithSchema(t *testing.T) {
|
||||||
Name: "barfoo",
|
Name: "barfoo",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
"nilschema": {},
|
||||||
|
"emptyschema": {
|
||||||
|
CreateSchema: &catalog.CreateSchema{},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
Pipelines: map[string]*resources.Pipeline{
|
Pipelines: map[string]*resources.Pipeline{
|
||||||
"pipeline1": {
|
"pipeline1": {
|
||||||
|
@ -249,13 +273,13 @@ func TestCaptureSchemaDependencyForPipelinesWithSchema(t *testing.T) {
|
||||||
|
|
||||||
d := bundle.Apply(context.Background(), b, CaptureSchemaDependency())
|
d := bundle.Apply(context.Background(), b, CaptureSchemaDependency())
|
||||||
require.Nil(t, d)
|
require.Nil(t, d)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline1"].Target, "${resources.schemas.schema1.name}")
|
assert.Equal(t, "${resources.schemas.schema1.name}", b.Config.Resources.Pipelines["pipeline1"].Target)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline2"].Target, "${resources.schemas.schema2.name}")
|
assert.Equal(t, "${resources.schemas.schema2.name}", b.Config.Resources.Pipelines["pipeline2"].Target)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline3"].Target, "${resources.schemas.schema3.name}")
|
assert.Equal(t, "${resources.schemas.schema3.name}", b.Config.Resources.Pipelines["pipeline3"].Target)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline4"].Target, "foobar")
|
assert.Equal(t, "foobar", b.Config.Resources.Pipelines["pipeline4"].Target)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline5"].Target, "schemaX")
|
assert.Equal(t, "schemaX", b.Config.Resources.Pipelines["pipeline5"].Target)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline6"].Target, "foobar")
|
assert.Equal(t, "foobar", b.Config.Resources.Pipelines["pipeline6"].Target)
|
||||||
assert.Equal(t, b.Config.Resources.Pipelines["pipeline7"].Target, "")
|
assert.Equal(t, "", b.Config.Resources.Pipelines["pipeline7"].Target)
|
||||||
|
|
||||||
for _, k := range []string{"pipeline1", "pipeline2", "pipeline3", "pipeline4", "pipeline5", "pipeline6", "pipeline7"} {
|
for _, k := range []string{"pipeline1", "pipeline2", "pipeline3", "pipeline4", "pipeline5", "pipeline6", "pipeline7"} {
|
||||||
assert.Empty(t, b.Config.Resources.Pipelines[k].Schema)
|
assert.Empty(t, b.Config.Resources.Pipelines[k].Schema)
|
||||||
|
|
Loading…
Reference in New Issue