2024-12-13 14:38:58 +00:00
|
|
|
package bundle_test
|
2024-09-23 10:42:34 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2024-12-17 07:45:58 +00:00
|
|
|
"github.com/databricks/cli/integration/internal/acc"
|
2024-09-23 10:42:34 +00:00
|
|
|
"github.com/databricks/cli/internal/testutil"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/compute"
|
|
|
|
"github.com/google/uuid"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
2024-12-13 14:47:50 +00:00
|
|
|
func TestDeployBundleWithCluster(t *testing.T) {
|
2024-12-17 17:34:09 +00:00
|
|
|
if testutil.GetCloud(t) == testutil.AWS {
|
2024-09-23 10:42:34 +00:00
|
|
|
t.Skip("Skipping test for AWS cloud because it is not permitted to create clusters")
|
|
|
|
}
|
|
|
|
|
2024-12-17 17:34:09 +00:00
|
|
|
ctx, wt := acc.WorkspaceTest(t)
|
|
|
|
|
2024-12-12 21:28:04 +00:00
|
|
|
nodeTypeId := testutil.GetCloud(t).NodeTypeID()
|
2024-09-23 10:42:34 +00:00
|
|
|
uniqueId := uuid.New().String()
|
2024-12-16 12:41:32 +00:00
|
|
|
root := initTestTemplate(t, ctx, "clusters", map[string]any{
|
2024-09-23 10:42:34 +00:00
|
|
|
"unique_id": uniqueId,
|
|
|
|
"node_type_id": nodeTypeId,
|
|
|
|
"spark_version": defaultSparkVersion,
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Cleanup(func() {
|
2024-12-16 12:41:32 +00:00
|
|
|
destroyBundle(t, ctx, root)
|
2024-09-23 10:42:34 +00:00
|
|
|
|
2025-01-07 10:49:23 +00:00
|
|
|
cluster, err := wt.W.Clusters.GetByClusterName(ctx, "test-cluster-"+uniqueId)
|
2024-09-23 10:42:34 +00:00
|
|
|
if err != nil {
|
|
|
|
require.ErrorContains(t, err, "does not exist")
|
|
|
|
} else {
|
|
|
|
require.Contains(t, []compute.State{compute.StateTerminated, compute.StateTerminating}, cluster.State)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2024-12-16 12:41:32 +00:00
|
|
|
deployBundle(t, ctx, root)
|
2024-09-23 10:42:34 +00:00
|
|
|
|
|
|
|
// Cluster should exists after bundle deployment
|
2025-01-07 10:49:23 +00:00
|
|
|
cluster, err := wt.W.Clusters.GetByClusterName(ctx, "test-cluster-"+uniqueId)
|
2024-09-23 10:42:34 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotNil(t, cluster)
|
|
|
|
|
2024-12-17 17:16:58 +00:00
|
|
|
if testing.Short() {
|
|
|
|
t.Log("Skip the job run in short mode")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-09-23 10:42:34 +00:00
|
|
|
out, err := runResource(t, ctx, root, "foo")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Contains(t, out, "Hello World!")
|
|
|
|
}
|