mirror of https://github.com/databricks/cli.git
86 lines
1.9 KiB
Go
86 lines
1.9 KiB
Go
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/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestConvertPermissions(t *testing.T) {
|
|
src := resources.Job{
|
|
Permissions: []resources.Permission{
|
|
{
|
|
Level: "CAN_VIEW",
|
|
UserName: "jane@doe.com",
|
|
},
|
|
{
|
|
Level: "CAN_MANAGE",
|
|
GroupName: "special admins",
|
|
},
|
|
{
|
|
Level: "CAN_RUN",
|
|
ServicePrincipalName: "spn",
|
|
},
|
|
},
|
|
}
|
|
|
|
vin, err := convert.FromTyped(src, dyn.NilValue)
|
|
require.NoError(t, err)
|
|
|
|
ctx := context.Background()
|
|
resource := convertPermissionsResource(ctx, vin)
|
|
require.NotNil(t, resource)
|
|
assert.Equal(t, []schema.ResourcePermissionsAccessControl{
|
|
{
|
|
PermissionLevel: "CAN_VIEW",
|
|
UserName: "jane@doe.com",
|
|
GroupName: "",
|
|
ServicePrincipalName: "",
|
|
},
|
|
{
|
|
PermissionLevel: "CAN_MANAGE",
|
|
UserName: "",
|
|
GroupName: "special admins",
|
|
ServicePrincipalName: "",
|
|
},
|
|
{
|
|
PermissionLevel: "CAN_RUN",
|
|
UserName: "",
|
|
GroupName: "",
|
|
ServicePrincipalName: "spn",
|
|
},
|
|
}, resource.AccessControl)
|
|
}
|
|
|
|
func TestConvertPermissionsNil(t *testing.T) {
|
|
src := resources.Job{
|
|
Permissions: nil,
|
|
}
|
|
|
|
vin, err := convert.FromTyped(src, dyn.NilValue)
|
|
require.NoError(t, err)
|
|
|
|
ctx := context.Background()
|
|
resource := convertPermissionsResource(ctx, vin)
|
|
assert.Nil(t, resource)
|
|
}
|
|
|
|
func TestConvertPermissionsEmpty(t *testing.T) {
|
|
src := resources.Job{
|
|
Permissions: []resources.Permission{},
|
|
}
|
|
|
|
vin, err := convert.FromTyped(src, dyn.NilValue)
|
|
require.NoError(t, err)
|
|
|
|
ctx := context.Background()
|
|
resource := convertPermissionsResource(ctx, vin)
|
|
assert.Nil(t, resource)
|
|
}
|