diff --git a/docs/data-sources/cluster_policy.md b/docs/data-sources/cluster_policy.md index c3f044c7a6..ecd5ddb495 100644 --- a/docs/data-sources/cluster_policy.md +++ b/docs/data-sources/cluster_policy.md @@ -35,4 +35,8 @@ Data source exposes the following attributes: - `id` - The id of the cluster policy. - `definition` - Policy definition: JSON document expressed in [Databricks Policy Definition Language](https://docs.databricks.com/administration-guide/clusters/policies.html#cluster-policy-definition). -- `max_clusters_per_user` - Max number of clusters per user that can be active using this policy +- `description` - Additional human-readable description of the cluster policy. +- `policy_family_id` - ID of the policy family. +- `policy_family_definition_overrides` - Policy definition JSON document expressed in Databricks [Policy Definition Language](https://docs.databricks.com/administration-guide/clusters/policies.html#cluster-policy-definitions). +- `is_default` - If true, policy is a default policy created and managed by Databricks. +- `max_clusters_per_user` - Max number of clusters per user that can be active using this policy. diff --git a/policies/data_cluster_policy.go b/policies/data_cluster_policy.go index 6915a22555..7924c672cb 100644 --- a/policies/data_cluster_policy.go +++ b/policies/data_cluster_policy.go @@ -11,10 +11,14 @@ import ( // DataSourceClusterPolicy returns information about cluster policy specified by name func DataSourceClusterPolicy() *schema.Resource { return common.WorkspaceData(func(ctx context.Context, data *struct { - Id string `json:"id,omitempty" tf:"computed"` - Name string `json:"name,omitempty" tf:"computed"` - Definition string `json:"definition,omitempty" tf:"computed"` - MaxClustersPerUser int `json:"max_clusters_per_user,omitempty" tf:"computed"` + Id string `json:"id,omitempty" tf:"computed"` + Name string `json:"name,omitempty" tf:"computed"` + Definition string `json:"definition,omitempty" tf:"computed"` + Description string `json:"description,omitempty" tf:"computed"` + PolicyFamilyId string `json:"policy_family_id,omitempty" tf:"computed"` + PolicyFamilyDefinitionOverrides string `json:"policy_family_definition_overrides,omitempty" tf:"computed"` + IsDefault bool `json:"is_default,omitempty" tf:"computed"` + MaxClustersPerUser int `json:"max_clusters_per_user,omitempty" tf:"computed"` }, w *databricks.WorkspaceClient) error { policy, err := w.ClusterPolicies.GetByName(ctx, data.Name) if err != nil { @@ -22,6 +26,10 @@ func DataSourceClusterPolicy() *schema.Resource { } data.Id = policy.PolicyId data.Definition = policy.Definition + data.Description = policy.Description + data.PolicyFamilyId = policy.PolicyFamilyId + data.PolicyFamilyDefinitionOverrides = policy.PolicyFamilyDefinitionOverrides + data.IsDefault = policy.IsDefault data.MaxClustersPerUser = int(policy.MaxClustersPerUser) return nil }) diff --git a/policies/data_cluster_policy_test.go b/policies/data_cluster_policy_test.go index beff0a07ae..1016b6c190 100644 --- a/policies/data_cluster_policy_test.go +++ b/policies/data_cluster_policy_test.go @@ -17,9 +17,14 @@ func TestDataSourceClusterPolicy(t *testing.T) { Response: compute.ListPoliciesResponse{ Policies: []compute.Policy{ { - PolicyId: "abc", - Name: "policy", - Definition: `{"abc":"123"}`, + PolicyId: "abc", + Name: "policy", + Definition: `{"abc":"123"}`, + Description: "A description", + PolicyFamilyId: "def", + PolicyFamilyDefinitionOverrides: `{"def":"456"}`, + IsDefault: true, + MaxClustersPerUser: 42, }, }, }, @@ -31,8 +36,13 @@ func TestDataSourceClusterPolicy(t *testing.T) { ID: ".", HCL: `name = "policy"`, }.ApplyAndExpectData(t, map[string]any{ - "id": "abc", - "definition": `{"abc":"123"}`, + "id": "abc", + "definition": `{"abc":"123"}`, + "description": "A description", + "policy_family_id": "def", + "policy_family_definition_overrides": `{"def":"456"}`, + "is_default": true, + "max_clusters_per_user": 42, }) }