package acc import ( "context" "os" "github.com/databricks/cli/internal/testutil" "github.com/databricks/databricks-sdk-go" "github.com/databricks/databricks-sdk-go/service/compute" "github.com/stretchr/testify/require" ) type WorkspaceT struct { testutil.TestingT W *databricks.WorkspaceClient ctx context.Context exec *compute.CommandExecutorV2 } func WorkspaceTest(t testutil.TestingT) (context.Context, *WorkspaceT) { t.Helper() loadDebugEnvIfRunFromIDE(t, "workspace") t.Logf("CLOUD_ENV=%s", testutil.GetEnvOrSkipTest(t, "CLOUD_ENV")) w, err := databricks.NewWorkspaceClient() require.NoError(t, err) wt := &WorkspaceT{ TestingT: t, W: w, ctx: context.Background(), } return wt.ctx, wt } // Run the workspace test only on UC workspaces. func UcWorkspaceTest(t testutil.TestingT) (context.Context, *WorkspaceT) { t.Helper() loadDebugEnvIfRunFromIDE(t, "workspace") t.Logf("CLOUD_ENV=%s", testutil.GetEnvOrSkipTest(t, "CLOUD_ENV")) if os.Getenv("TEST_METASTORE_ID") == "" { t.Skipf("Skipping on non-UC workspaces") } if os.Getenv("DATABRICKS_ACCOUNT_ID") != "" { t.Skipf("Skipping on accounts") } w, err := databricks.NewWorkspaceClient() require.NoError(t, err) wt := &WorkspaceT{ TestingT: t, W: w, ctx: context.Background(), } return wt.ctx, wt } func (t *WorkspaceT) TestClusterID() string { t.Helper() clusterID := testutil.GetEnvOrSkipTest(t, "TEST_BRICKS_CLUSTER_ID") err := t.W.Clusters.EnsureClusterIsRunning(t.ctx, clusterID) require.NoError(t, err, "Unexpected error from EnsureClusterIsRunning for clusterID=%s", clusterID) return clusterID } func (t *WorkspaceT) RunPython(code string) (string, error) { t.Helper() var err error // Create command executor only once per test. if t.exec == nil { t.exec, err = t.W.CommandExecution.Start(t.ctx, t.TestClusterID(), compute.LanguagePython) require.NoError(t, err, "Unexpected error from CommandExecution.Start(clusterID=%v)", t.TestClusterID()) t.Cleanup(func() { err := t.exec.Destroy(t.ctx) require.NoError(t, err) }) } results, err := t.exec.Execute(t.ctx, code) require.NoError(t, err, "Unexpected error from Execute(%v)", code) require.NotEqual(t, compute.ResultTypeError, results.ResultType, results.Cause) output, ok := results.Data.(string) require.True(t, ok, "unexpected type %T", results.Data) return output, nil }