2023-09-07 14:08:16 +00:00
|
|
|
package bundle
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2024-02-07 11:18:56 +00:00
|
|
|
"github.com/databricks/cli/internal/acc"
|
2024-11-01 14:22:47 +00:00
|
|
|
"github.com/databricks/cli/internal/testutil"
|
2024-02-07 11:18:56 +00:00
|
|
|
"github.com/databricks/cli/libs/env"
|
2023-09-07 20:02:26 +00:00
|
|
|
"github.com/google/uuid"
|
2023-09-07 14:08:16 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
2024-11-01 14:22:47 +00:00
|
|
|
func runPythonWheelTest(t *testing.T, templateName, sparkVersion string, pythonWheelWrapper bool) {
|
2024-02-07 11:18:56 +00:00
|
|
|
ctx, _ := acc.WorkspaceTest(t)
|
|
|
|
|
2024-12-12 21:28:04 +00:00
|
|
|
nodeTypeId := testutil.GetCloud(t).NodeTypeID()
|
2024-08-01 13:55:22 +00:00
|
|
|
instancePoolId := env.Get(ctx, "TEST_INSTANCE_POOL_ID")
|
2024-11-01 14:22:47 +00:00
|
|
|
bundleRoot, err := initTestTemplate(t, ctx, templateName, map[string]any{
|
2023-09-26 14:32:20 +00:00
|
|
|
"node_type_id": nodeTypeId,
|
|
|
|
"unique_id": uuid.New().String(),
|
2023-10-20 15:03:29 +00:00
|
|
|
"spark_version": sparkVersion,
|
2023-09-26 14:32:20 +00:00
|
|
|
"python_wheel_wrapper": pythonWheelWrapper,
|
2024-08-01 13:55:22 +00:00
|
|
|
"instance_pool_id": instancePoolId,
|
2023-09-07 14:08:16 +00:00
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2024-02-07 11:18:56 +00:00
|
|
|
err = deployBundle(t, ctx, bundleRoot)
|
2023-09-07 14:08:16 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
t.Cleanup(func() {
|
2024-02-07 11:18:56 +00:00
|
|
|
err := destroyBundle(t, ctx, bundleRoot)
|
2023-09-07 14:08:16 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
|
2024-02-07 11:18:56 +00:00
|
|
|
out, err := runResource(t, ctx, bundleRoot, "some_other_job")
|
2023-09-07 14:08:16 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Contains(t, out, "Hello from my func")
|
|
|
|
require.Contains(t, out, "Got arguments:")
|
2023-09-26 14:32:20 +00:00
|
|
|
require.Contains(t, out, "['my_test_code', 'one', 'two']")
|
2023-12-01 10:35:20 +00:00
|
|
|
|
2024-02-07 11:18:56 +00:00
|
|
|
out, err = runResourceWithParams(t, ctx, bundleRoot, "some_other_job", "--python-params=param1,param2")
|
2023-12-01 10:35:20 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Contains(t, out, "Hello from my func")
|
|
|
|
require.Contains(t, out, "Got arguments:")
|
|
|
|
require.Contains(t, out, "['my_test_code', 'param1', 'param2']")
|
2023-09-26 14:32:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestAccPythonWheelTaskDeployAndRunWithoutWrapper(t *testing.T) {
|
2024-11-01 14:22:47 +00:00
|
|
|
runPythonWheelTest(t, "python_wheel_task", "13.3.x-snapshot-scala2.12", false)
|
2023-09-26 14:32:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestAccPythonWheelTaskDeployAndRunWithWrapper(t *testing.T) {
|
2024-11-01 14:22:47 +00:00
|
|
|
runPythonWheelTest(t, "python_wheel_task", "12.2.x-scala2.12", true)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestAccPythonWheelTaskDeployAndRunOnInteractiveCluster(t *testing.T) {
|
|
|
|
_, wt := acc.WorkspaceTest(t)
|
|
|
|
|
2024-12-12 14:42:15 +00:00
|
|
|
if testutil.IsAWSCloud(wt) {
|
2024-11-01 14:22:47 +00:00
|
|
|
t.Skip("Skipping test for AWS cloud because it is not permitted to create clusters")
|
|
|
|
}
|
|
|
|
|
|
|
|
runPythonWheelTest(t, "python_wheel_task_with_cluster", defaultSparkVersion, false)
|
2023-09-07 14:08:16 +00:00
|
|
|
}
|