2024-02-16 20:54:38 +00:00
|
|
|
package tfdyn
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/databricks/cli/bundle/config/resources"
|
|
|
|
"github.com/databricks/cli/bundle/internal/tf/schema"
|
|
|
|
"github.com/databricks/cli/libs/dyn"
|
|
|
|
"github.com/databricks/cli/libs/dyn/convert"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/compute"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/jobs"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestConvertJob(t *testing.T) {
|
2024-12-12 09:28:42 +00:00
|
|
|
src := resources.Job{
|
2024-02-16 20:54:38 +00:00
|
|
|
JobSettings: &jobs.JobSettings{
|
|
|
|
Name: "my job",
|
|
|
|
JobClusters: []jobs.JobCluster{
|
|
|
|
{
|
|
|
|
JobClusterKey: "key",
|
2024-04-03 10:39:53 +00:00
|
|
|
NewCluster: compute.ClusterSpec{
|
2024-02-16 20:54:38 +00:00
|
|
|
SparkVersion: "10.4.x-scala2.12",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
GitSource: &jobs.GitSource{
|
|
|
|
GitProvider: jobs.GitProviderGitHub,
|
|
|
|
GitUrl: "https://github.com/foo/bar",
|
|
|
|
},
|
|
|
|
Parameters: []jobs.JobParameterDefinition{
|
|
|
|
{
|
|
|
|
Name: "param1",
|
|
|
|
Default: "default1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "param2",
|
|
|
|
Default: "default2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Tasks: []jobs.Task{
|
|
|
|
{
|
2024-09-26 13:22:22 +00:00
|
|
|
TaskKey: "task_key_b",
|
|
|
|
JobClusterKey: "job_cluster_key_b",
|
2024-02-16 20:54:38 +00:00
|
|
|
Libraries: []compute.Library{
|
|
|
|
{
|
|
|
|
Pypi: &compute.PythonPyPiLibrary{
|
|
|
|
Package: "package",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Whl: "/path/to/my.whl",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-09-26 13:22:22 +00:00
|
|
|
{
|
|
|
|
TaskKey: "task_key_a",
|
|
|
|
JobClusterKey: "job_cluster_key_a",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
TaskKey: "task_key_c",
|
|
|
|
JobClusterKey: "job_cluster_key_c",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Description: "missing task key 😱",
|
|
|
|
},
|
2024-02-16 20:54:38 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
Permissions: []resources.Permission{
|
|
|
|
{
|
|
|
|
Level: "CAN_VIEW",
|
|
|
|
UserName: "jane@doe.com",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
vin, err := convert.FromTyped(src, dyn.NilValue)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
out := schema.NewResources()
|
|
|
|
err = jobConverter{}.Convert(ctx, "my_job", vin, out)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// Assert equality on the job
|
|
|
|
assert.Equal(t, map[string]any{
|
|
|
|
"name": "my job",
|
|
|
|
"job_cluster": []any{
|
|
|
|
map[string]any{
|
|
|
|
"job_cluster_key": "key",
|
|
|
|
"new_cluster": map[string]any{
|
|
|
|
"spark_version": "10.4.x-scala2.12",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"git_source": map[string]any{
|
|
|
|
"provider": "gitHub",
|
|
|
|
"url": "https://github.com/foo/bar",
|
|
|
|
},
|
|
|
|
"parameter": []any{
|
|
|
|
map[string]any{
|
|
|
|
"name": "param1",
|
|
|
|
"default": "default1",
|
|
|
|
},
|
|
|
|
map[string]any{
|
|
|
|
"name": "param2",
|
|
|
|
"default": "default2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"task": []any{
|
|
|
|
map[string]any{
|
2024-09-26 13:22:22 +00:00
|
|
|
"description": "missing task key 😱",
|
|
|
|
},
|
|
|
|
map[string]any{
|
|
|
|
"task_key": "task_key_a",
|
|
|
|
"job_cluster_key": "job_cluster_key_a",
|
|
|
|
},
|
|
|
|
map[string]any{
|
|
|
|
"task_key": "task_key_b",
|
|
|
|
"job_cluster_key": "job_cluster_key_b",
|
2024-02-16 20:54:38 +00:00
|
|
|
"library": []any{
|
|
|
|
map[string]any{
|
|
|
|
"pypi": map[string]any{
|
|
|
|
"package": "package",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
map[string]any{
|
|
|
|
"whl": "/path/to/my.whl",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-09-26 13:22:22 +00:00
|
|
|
map[string]any{
|
|
|
|
"task_key": "task_key_c",
|
|
|
|
"job_cluster_key": "job_cluster_key_c",
|
|
|
|
},
|
2024-02-16 20:54:38 +00:00
|
|
|
},
|
|
|
|
}, out.Job["my_job"])
|
|
|
|
|
|
|
|
// Assert equality on the permissions
|
|
|
|
assert.Equal(t, &schema.ResourcePermissions{
|
|
|
|
JobId: "${databricks_job.my_job.id}",
|
|
|
|
AccessControl: []schema.ResourcePermissionsAccessControl{
|
|
|
|
{
|
|
|
|
PermissionLevel: "CAN_VIEW",
|
|
|
|
UserName: "jane@doe.com",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}, out.Permissions["job_my_job"])
|
|
|
|
}
|