2024-12-13 14:38:58 +00:00
|
|
|
package bundle_test
|
2024-03-18 14:41:58 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/databricks/cli/bundle/deploy"
|
2024-12-17 07:45:58 +00:00
|
|
|
"github.com/databricks/cli/integration/internal/acc"
|
2024-12-12 12:35:38 +00:00
|
|
|
"github.com/databricks/cli/internal/testutil"
|
2024-12-16 11:34:37 +00:00
|
|
|
"github.com/databricks/cli/libs/env"
|
2024-03-18 14:41:58 +00:00
|
|
|
"github.com/google/uuid"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
2024-12-13 14:47:50 +00:00
|
|
|
func TestFilesAreSyncedCorrectlyWhenNoSnapshot(t *testing.T) {
|
2024-03-18 14:41:58 +00:00
|
|
|
ctx, wt := acc.WorkspaceTest(t)
|
|
|
|
w := wt.W
|
|
|
|
|
2024-12-12 21:28:04 +00:00
|
|
|
nodeTypeId := testutil.GetCloud(t).NodeTypeID()
|
2024-03-18 14:41:58 +00:00
|
|
|
uniqueId := uuid.New().String()
|
2024-12-16 12:41:32 +00:00
|
|
|
bundleRoot := initTestTemplate(t, ctx, "basic", map[string]any{
|
2024-03-18 14:41:58 +00:00
|
|
|
"unique_id": uniqueId,
|
|
|
|
"spark_version": "13.3.x-scala2.12",
|
|
|
|
"node_type_id": nodeTypeId,
|
|
|
|
})
|
|
|
|
|
2024-12-16 11:34:37 +00:00
|
|
|
ctx = env.Set(ctx, "BUNDLE_ROOT", bundleRoot)
|
2024-03-18 14:41:58 +00:00
|
|
|
|
|
|
|
// Add some test file to the bundle
|
2024-12-16 12:41:32 +00:00
|
|
|
err := os.WriteFile(filepath.Join(bundleRoot, "test.py"), []byte("print('Hello, World!')"), 0o644)
|
2024-03-18 14:41:58 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
err = os.WriteFile(filepath.Join(bundleRoot, "test_to_modify.py"), []byte("print('Hello, World!')"), 0o644)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Add notebook to the bundle
|
|
|
|
err = os.WriteFile(filepath.Join(bundleRoot, "notebook.py"), []byte("# Databricks notebook source\nHello, World!"), 0o644)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2024-12-16 12:41:32 +00:00
|
|
|
deployBundle(t, ctx, bundleRoot)
|
2024-03-18 14:41:58 +00:00
|
|
|
|
|
|
|
t.Cleanup(func() {
|
2024-12-16 12:41:32 +00:00
|
|
|
destroyBundle(t, ctx, bundleRoot)
|
2024-03-18 14:41:58 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
remoteRoot := getBundleRemoteRootPath(w, t, uniqueId)
|
|
|
|
|
|
|
|
// Check that test file is in workspace
|
|
|
|
_, err = w.Workspace.GetStatusByPath(ctx, path.Join(remoteRoot, "files", "test.py"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
_, err = w.Workspace.GetStatusByPath(ctx, path.Join(remoteRoot, "files", "test_to_modify.py"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Check that notebook is in workspace
|
|
|
|
_, err = w.Workspace.GetStatusByPath(ctx, path.Join(remoteRoot, "files", "notebook"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Check that deployment.json is synced correctly
|
|
|
|
_, err = w.Workspace.GetStatusByPath(ctx, path.Join(remoteRoot, "state", deploy.DeploymentStateFileName))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Remove .databricks directory to simulate a fresh deployment like in CI/CD environment
|
|
|
|
err = os.RemoveAll(filepath.Join(bundleRoot, ".databricks"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Remove the file from the bundle
|
|
|
|
err = os.Remove(filepath.Join(bundleRoot, "test.py"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Remove the notebook from the bundle and deploy again
|
|
|
|
err = os.Remove(filepath.Join(bundleRoot, "notebook.py"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Modify the content of another file
|
|
|
|
err = os.WriteFile(filepath.Join(bundleRoot, "test_to_modify.py"), []byte("print('Modified!')"), 0o644)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2024-12-16 12:41:32 +00:00
|
|
|
deployBundle(t, ctx, bundleRoot)
|
2024-03-18 14:41:58 +00:00
|
|
|
|
|
|
|
// Check that removed file is not in workspace anymore
|
|
|
|
_, err = w.Workspace.GetStatusByPath(ctx, path.Join(remoteRoot, "files", "test.py"))
|
|
|
|
require.ErrorContains(t, err, "files/test.py")
|
|
|
|
require.ErrorContains(t, err, "doesn't exist")
|
|
|
|
|
|
|
|
// Check that removed notebook is not in workspace anymore
|
|
|
|
_, err = w.Workspace.GetStatusByPath(ctx, path.Join(remoteRoot, "files", "notebook"))
|
|
|
|
require.ErrorContains(t, err, "files/notebook")
|
|
|
|
require.ErrorContains(t, err, "doesn't exist")
|
|
|
|
|
|
|
|
// Check the content of modified file
|
|
|
|
content, err := w.Workspace.ReadFile(ctx, path.Join(remoteRoot, "files", "test_to_modify.py"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "print('Modified!')", string(content))
|
|
|
|
}
|