2023-05-26 12:46:08 +00:00
|
|
|
package internal
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"regexp"
|
|
|
|
"testing"
|
|
|
|
|
2024-12-09 14:25:06 +00:00
|
|
|
"github.com/databricks/cli/internal/acc"
|
2024-12-12 16:48:51 +00:00
|
|
|
"github.com/databricks/cli/internal/testcli"
|
2024-12-12 12:35:38 +00:00
|
|
|
"github.com/databricks/cli/internal/testutil"
|
2024-12-09 14:25:06 +00:00
|
|
|
"github.com/databricks/databricks-sdk-go/listing"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/compute"
|
2023-05-26 12:46:08 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
2024-12-09 14:25:06 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
2023-05-26 12:46:08 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestAccClustersList(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-05-26 12:46:08 +00:00
|
|
|
|
2024-12-12 16:48:51 +00:00
|
|
|
stdout, stderr := testcli.RequireSuccessfulRun(t, "clusters", "list")
|
2023-05-26 12:46:08 +00:00
|
|
|
outStr := stdout.String()
|
|
|
|
assert.Contains(t, outStr, "ID")
|
|
|
|
assert.Contains(t, outStr, "Name")
|
|
|
|
assert.Contains(t, outStr, "State")
|
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
idRegExp := regexp.MustCompile(`[0-9]{4}\-[0-9]{6}-[a-z0-9]{8}`)
|
2024-12-09 14:25:06 +00:00
|
|
|
clusterId := idRegExp.FindString(outStr)
|
2023-05-26 12:46:08 +00:00
|
|
|
assert.NotEmpty(t, clusterId)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestAccClustersGet(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-05-26 12:46:08 +00:00
|
|
|
|
2024-12-09 14:25:06 +00:00
|
|
|
clusterId := findValidClusterID(t)
|
2024-12-12 16:48:51 +00:00
|
|
|
stdout, stderr := testcli.RequireSuccessfulRun(t, "clusters", "get", clusterId)
|
2023-05-26 12:46:08 +00:00
|
|
|
outStr := stdout.String()
|
|
|
|
assert.Contains(t, outStr, fmt.Sprintf(`"cluster_id":"%s"`, clusterId))
|
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
}
|
2023-06-05 17:38:45 +00:00
|
|
|
|
|
|
|
func TestClusterCreateErrorWhenNoArguments(t *testing.T) {
|
2024-12-12 16:48:51 +00:00
|
|
|
_, _, err := testcli.RequireErrorRun(t, "clusters", "create")
|
2024-03-12 14:12:34 +00:00
|
|
|
assert.Contains(t, err.Error(), "accepts 1 arg(s), received 0")
|
2023-06-05 17:38:45 +00:00
|
|
|
}
|
2024-12-09 14:25:06 +00:00
|
|
|
|
|
|
|
// findValidClusterID lists clusters in the workspace to find a valid cluster ID.
|
|
|
|
func findValidClusterID(t *testing.T) string {
|
|
|
|
ctx, wt := acc.WorkspaceTest(t)
|
|
|
|
it := wt.W.Clusters.List(ctx, compute.ListClustersRequest{
|
|
|
|
FilterBy: &compute.ListClustersFilterBy{
|
|
|
|
ClusterSources: []compute.ClusterSource{
|
|
|
|
compute.ClusterSourceApi,
|
|
|
|
compute.ClusterSourceUi,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
clusterIDs, err := listing.ToSliceN(ctx, it, 1)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Len(t, clusterIDs, 1)
|
|
|
|
|
|
|
|
return clusterIDs[0].ClusterId
|
|
|
|
}
|