2024-12-13 14:38:58 +00:00
|
|
|
package repos_test
|
2023-06-26 23:37:05 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"strconv"
|
|
|
|
"testing"
|
|
|
|
|
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"
|
2023-06-26 23:37:05 +00:00
|
|
|
"github.com/databricks/databricks-sdk-go"
|
|
|
|
"github.com/databricks/databricks-sdk-go/apierr"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/workspace"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
2024-12-13 14:38:58 +00:00
|
|
|
const repoUrl = "https://github.com/databricks/databricks-empty-ide-project.git"
|
|
|
|
|
2023-06-27 12:17:13 +00:00
|
|
|
func synthesizeTemporaryRepoPath(t *testing.T, w *databricks.WorkspaceClient, ctx context.Context) string {
|
2023-06-26 23:37:05 +00:00
|
|
|
me, err := w.CurrentUser.Me(ctx)
|
|
|
|
require.NoError(t, err)
|
2024-12-12 12:35:38 +00:00
|
|
|
repoPath := fmt.Sprintf("/Repos/%s/%s", me.UserName, testutil.RandomName("empty-repo-integration-"))
|
2023-06-27 12:17:13 +00:00
|
|
|
|
|
|
|
// Cleanup if repo was created at specified path.
|
|
|
|
t.Cleanup(func() {
|
|
|
|
oi, err := w.Workspace.GetStatusByPath(ctx, repoPath)
|
|
|
|
if apierr.IsMissing(err) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
require.NoError(t, err)
|
|
|
|
err = w.Repos.DeleteByRepoId(ctx, oi.ObjectId)
|
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
|
|
|
|
return repoPath
|
|
|
|
}
|
|
|
|
|
|
|
|
func createTemporaryRepo(t *testing.T, w *databricks.WorkspaceClient, ctx context.Context) (int64, string) {
|
|
|
|
repoPath := synthesizeTemporaryRepoPath(t, w, ctx)
|
2024-10-07 13:21:05 +00:00
|
|
|
repoInfo, err := w.Repos.Create(ctx, workspace.CreateRepoRequest{
|
2023-06-26 23:37:05 +00:00
|
|
|
Path: repoPath,
|
|
|
|
Url: repoUrl,
|
|
|
|
Provider: "gitHub",
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
2023-06-27 12:17:13 +00:00
|
|
|
return repoInfo.Id, repoPath
|
|
|
|
}
|
2023-06-26 23:37:05 +00:00
|
|
|
|
2024-03-14 12:56:21 +00:00
|
|
|
func TestAccReposCreateWithProvider(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-06-26 23:37:05 +00:00
|
|
|
|
2023-06-27 12:17:13 +00:00
|
|
|
ctx := context.Background()
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
repoPath := synthesizeTemporaryRepoPath(t, w, ctx)
|
|
|
|
|
2024-12-12 16:48:51 +00:00
|
|
|
_, stderr := testcli.RequireSuccessfulRun(t, "repos", "create", repoUrl, "gitHub", "--path", repoPath)
|
2023-06-27 12:17:13 +00:00
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Confirm the repo was created.
|
|
|
|
oi, err := w.Workspace.GetStatusByPath(ctx, repoPath)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, workspace.ObjectTypeRepo, oi.ObjectType)
|
|
|
|
}
|
|
|
|
|
2024-03-14 12:56:21 +00:00
|
|
|
func TestAccReposCreateWithoutProvider(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-06-27 12:17:13 +00:00
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
repoPath := synthesizeTemporaryRepoPath(t, w, ctx)
|
|
|
|
|
2024-12-12 16:48:51 +00:00
|
|
|
_, stderr := testcli.RequireSuccessfulRun(t, "repos", "create", repoUrl, "--path", repoPath)
|
2023-06-27 12:17:13 +00:00
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Confirm the repo was created.
|
|
|
|
oi, err := w.Workspace.GetStatusByPath(ctx, repoPath)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, workspace.ObjectTypeRepo, oi.ObjectType)
|
2023-06-26 23:37:05 +00:00
|
|
|
}
|
|
|
|
|
2024-03-14 12:56:21 +00:00
|
|
|
func TestAccReposGet(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-06-26 23:37:05 +00:00
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
repoId, repoPath := createTemporaryRepo(t, w, ctx)
|
|
|
|
|
|
|
|
// Get by ID
|
2024-12-12 16:48:51 +00:00
|
|
|
byIdOutput, stderr := testcli.RequireSuccessfulRun(t, "repos", "get", strconv.FormatInt(repoId, 10), "--output=json")
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Get by path
|
2024-12-12 16:48:51 +00:00
|
|
|
byPathOutput, stderr := testcli.RequireSuccessfulRun(t, "repos", "get", repoPath, "--output=json")
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Output should be the same
|
|
|
|
assert.Equal(t, byIdOutput.String(), byPathOutput.String())
|
|
|
|
|
|
|
|
// Get by path fails
|
2024-12-12 16:48:51 +00:00
|
|
|
_, stderr, err = testcli.RequireErrorRun(t, "repos", "get", repoPath+"-doesntexist", "--output=json")
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.ErrorContains(t, err, "failed to look up repo")
|
|
|
|
|
|
|
|
// Get by path resolves to something other than a repo
|
2024-12-12 16:48:51 +00:00
|
|
|
_, stderr, err = testcli.RequireErrorRun(t, "repos", "get", "/Repos", "--output=json")
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.ErrorContains(t, err, "is not a repo")
|
|
|
|
}
|
|
|
|
|
2024-03-14 12:56:21 +00:00
|
|
|
func TestAccReposUpdate(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-06-26 23:37:05 +00:00
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
repoId, repoPath := createTemporaryRepo(t, w, ctx)
|
|
|
|
|
|
|
|
// Update by ID
|
2024-12-12 16:48:51 +00:00
|
|
|
byIdOutput, stderr := testcli.RequireSuccessfulRun(t, "repos", "update", strconv.FormatInt(repoId, 10), "--branch", "ide")
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Update by path
|
2024-12-12 16:48:51 +00:00
|
|
|
byPathOutput, stderr := testcli.RequireSuccessfulRun(t, "repos", "update", repoPath, "--branch", "ide")
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Output should be the same
|
|
|
|
assert.Equal(t, byIdOutput.String(), byPathOutput.String())
|
|
|
|
}
|
|
|
|
|
2024-03-14 12:56:21 +00:00
|
|
|
func TestAccReposDeleteByID(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-06-26 23:37:05 +00:00
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
repoId, _ := createTemporaryRepo(t, w, ctx)
|
|
|
|
|
|
|
|
// Delete by ID
|
2024-12-12 16:48:51 +00:00
|
|
|
stdout, stderr := testcli.RequireSuccessfulRun(t, "repos", "delete", strconv.FormatInt(repoId, 10))
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.Equal(t, "", stdout.String())
|
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Check it was actually deleted
|
|
|
|
_, err = w.Repos.GetByRepoId(ctx, repoId)
|
|
|
|
assert.True(t, apierr.IsMissing(err), err)
|
|
|
|
}
|
|
|
|
|
2024-03-14 12:56:21 +00:00
|
|
|
func TestAccReposDeleteByPath(t *testing.T) {
|
2024-12-12 12:35:38 +00:00
|
|
|
t.Log(testutil.GetEnvOrSkipTest(t, "CLOUD_ENV"))
|
2023-06-26 23:37:05 +00:00
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
w, err := databricks.NewWorkspaceClient()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
repoId, repoPath := createTemporaryRepo(t, w, ctx)
|
|
|
|
|
|
|
|
// Delete by path
|
2024-12-12 16:48:51 +00:00
|
|
|
stdout, stderr := testcli.RequireSuccessfulRun(t, "repos", "delete", repoPath)
|
2023-06-26 23:37:05 +00:00
|
|
|
assert.Equal(t, "", stdout.String())
|
|
|
|
assert.Equal(t, "", stderr.String())
|
|
|
|
|
|
|
|
// Check it was actually deleted
|
|
|
|
_, err = w.Repos.GetByRepoId(ctx, repoId)
|
|
|
|
assert.True(t, apierr.IsMissing(err), err)
|
|
|
|
}
|