2022-05-21 12:31:26 +00:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"path"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform-exec/tfexec"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestSomething(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
2022-05-23 09:46:37 +00:00
|
|
|
tf, err := newTerraform(ctx, "testdata/simplest", map[string]string{
|
2022-05-21 12:31:26 +00:00
|
|
|
"DATABRICKS_HOST": "..",
|
|
|
|
"DATABRICKS_TOKEN": "..",
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
err = tf.Init(ctx)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
planLoc := path.Join(t.TempDir(), "tfplan.zip")
|
|
|
|
hasChanges, err := tf.Plan(ctx, tfexec.Out(planLoc))
|
|
|
|
assert.True(t, hasChanges)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
plan, err := tf.ShowPlanFile(ctx, planLoc)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.NotNil(t, plan)
|
|
|
|
|
|
|
|
found := false
|
|
|
|
for _, r := range plan.Config.RootModule.Resources {
|
|
|
|
// TODO: add validator to prevent non-Databricks resources in *.tf files, as
|
|
|
|
// we're not replacing terraform, we're wrapping it up for the average user.
|
|
|
|
if r.Type != "databricks_job" {
|
|
|
|
continue
|
|
|
|
}
|
2022-05-23 09:46:37 +00:00
|
|
|
// TODO: validate that libraries on jobs defined in *.tf and libraries
|
|
|
|
// in `install_requires` defined in setup.py are the same. Exist with
|
2022-05-21 13:23:37 +00:00
|
|
|
// the explanatory error otherwise.
|
2022-05-21 12:31:26 +00:00
|
|
|
found = true
|
|
|
|
// resource "databricks_job" "this"
|
|
|
|
assert.Equal(t, "this", r.Name)
|
|
|
|
// this is just a PoC to show how to retrieve DBR version from definitions.
|
|
|
|
// production code should perform rigorous nil checks...
|
|
|
|
nc := r.Expressions["new_cluster"]
|
|
|
|
firstBlock := nc.NestedBlocks[0]
|
|
|
|
ver := firstBlock["spark_version"].ConstantValue.(string)
|
|
|
|
assert.Equal(t, "10.0.1", ver)
|
|
|
|
}
|
|
|
|
assert.True(t, found)
|
|
|
|
}
|