databricks-cli/bundle/deploy/terraform/tfdyn/convert_permissions_test.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)
}