2023-07-05 15:30:54 +00:00
|
|
|
package acc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-07-31 12:16:28 +00:00
|
|
|
"os"
|
2023-07-05 15:30:54 +00:00
|
|
|
|
2024-12-12 12:35:38 +00:00
|
|
|
"github.com/databricks/cli/internal/testutil"
|
2023-07-05 15:30:54 +00:00
|
|
|
"github.com/databricks/databricks-sdk-go"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/compute"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
type WorkspaceT struct {
|
2024-12-12 14:42:15 +00:00
|
|
|
testutil.TestingT
|
2023-07-05 15:30:54 +00:00
|
|
|
|
|
|
|
W *databricks.WorkspaceClient
|
|
|
|
|
|
|
|
ctx context.Context
|
|
|
|
|
|
|
|
exec *compute.CommandExecutorV2
|
|
|
|
}
|
|
|
|
|
2024-12-12 14:42:15 +00:00
|
|
|
func WorkspaceTest(t testutil.TestingT) (context.Context, *WorkspaceT) {
|
2025-01-02 09:49:21 +00:00
|
|
|
t.Helper()
|
2023-07-05 15:30:54 +00:00
|
|
|
loadDebugEnvIfRunFromIDE(t, "workspace")
|
|
|
|
|
2025-01-02 09:49:21 +00:00
|
|
|
t.Logf("CLOUD_ENV=%s", testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-07-05 15:30:54 +00:00
|
|
|
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
wt := &WorkspaceT{
|
2024-12-12 14:42:15 +00:00
|
|
|
TestingT: t,
|
2023-07-05 15:30:54 +00:00
|
|
|
|
|
|
|
W: w,
|
|
|
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
}
|
|
|
|
|
|
|
|
return wt.ctx, wt
|
|
|
|
}
|
|
|
|
|
2024-07-31 12:16:28 +00:00
|
|
|
// Run the workspace test only on UC workspaces.
|
2024-12-12 14:42:15 +00:00
|
|
|
func UcWorkspaceTest(t testutil.TestingT) (context.Context, *WorkspaceT) {
|
2025-01-02 09:49:21 +00:00
|
|
|
t.Helper()
|
2024-07-31 12:16:28 +00:00
|
|
|
loadDebugEnvIfRunFromIDE(t, "workspace")
|
|
|
|
|
2025-01-02 09:49:21 +00:00
|
|
|
t.Logf("CLOUD_ENV=%s", testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2024-07-31 12:16:28 +00:00
|
|
|
|
|
|
|
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{
|
2024-12-12 14:42:15 +00:00
|
|
|
TestingT: t,
|
2024-07-31 12:16:28 +00:00
|
|
|
|
|
|
|
W: w,
|
|
|
|
|
|
|
|
ctx: context.Background(),
|
|
|
|
}
|
|
|
|
|
|
|
|
return wt.ctx, wt
|
|
|
|
}
|
|
|
|
|
2023-07-05 15:30:54 +00:00
|
|
|
func (t *WorkspaceT) TestClusterID() string {
|
2025-01-02 09:49:21 +00:00
|
|
|
t.Helper()
|
2024-12-12 14:42:15 +00:00
|
|
|
clusterID := testutil.GetEnvOrSkipTest(t, "TEST_BRICKS_CLUSTER_ID")
|
2023-07-05 15:30:54 +00:00
|
|
|
err := t.W.Clusters.EnsureClusterIsRunning(t.ctx, clusterID)
|
2025-01-02 09:49:21 +00:00
|
|
|
require.NoError(t, err, "Unexpected error from EnsureClusterIsRunning for clusterID=%s", clusterID)
|
2023-07-05 15:30:54 +00:00
|
|
|
return clusterID
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *WorkspaceT) RunPython(code string) (string, error) {
|
2025-01-02 09:49:21 +00:00
|
|
|
t.Helper()
|
2023-07-05 15:30:54 +00:00
|
|
|
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)
|
2025-01-02 09:49:21 +00:00
|
|
|
require.NoError(t, err, "Unexpected error from CommandExecution.Start(clusterID=%v)", t.TestClusterID())
|
2023-07-05 15:30:54 +00:00
|
|
|
|
|
|
|
t.Cleanup(func() {
|
|
|
|
err := t.exec.Destroy(t.ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
results, err := t.exec.Execute(t.ctx, code)
|
2025-01-02 09:49:21 +00:00
|
|
|
require.NoError(t, err, "Unexpected error from Execute(%v)", code)
|
2023-07-05 15:30:54 +00:00
|
|
|
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
|
|
|
|
}
|