From fe07f98136b90897ca7e14ac7d7802592676c30d Mon Sep 17 00:00:00 2001 From: shi yuhang <52435083+shiyuhang0@users.noreply.github.com> Date: Sun, 28 Apr 2024 13:22:37 +0800 Subject: [PATCH] fix (#130) --- internal/provider/cluster_resource.go | 14 ++++---------- internal/provider/plan_modify.go | 11 ++++++++++- 2 files changed, 14 insertions(+), 11 deletions(-) diff --git a/internal/provider/cluster_resource.go b/internal/provider/cluster_resource.go index 9401c63..272d2da 100644 --- a/internal/provider/cluster_resource.go +++ b/internal/provider/cluster_resource.go @@ -236,7 +236,6 @@ func (r *clusterResource) Schema(_ context.Context, _ resource.SchemaRequest, re " - The cluster can be paused only when the cluster_status is \"AVAILABLE\"." + " - The cluster can be resumed only when the cluster_status is \"PAUSED\".", Optional: true, - Computed: true, }, "components": schema.SingleNestedAttribute{ MarkdownDescription: "The components of the cluster.\n" + @@ -420,7 +419,7 @@ func (r clusterResource) Create(ctx context.Context, req resource.CreateRequest, resp.Diagnostics.AddError("Create Error", fmt.Sprintf("Unable to call GetCluster, got error: %s", err)) return } - refreshClusterResourceData(getClusterResp.Payload, &data) + refreshClusterResourceData(ctx, getClusterResp.Payload, &data) // save into the Terraform state. diags = resp.State.Set(ctx, &data) @@ -518,14 +517,14 @@ func (r clusterResource) Read(ctx context.Context, req resource.ReadRequest, res data.Config.IPAccessList = iPAccessList data.Config.Paused = paused - refreshClusterResourceData(getClusterResp.Payload, &data) + refreshClusterResourceData(ctx, getClusterResp.Payload, &data) // save into the Terraform state diags := resp.State.Set(ctx, &data) resp.Diagnostics.Append(diags...) } -func refreshClusterResourceData(resp *clusterApi.GetClusterOKBody, data *clusterResourceData) { +func refreshClusterResourceData(ctx context.Context, resp *clusterApi.GetClusterOKBody, data *clusterResourceData) { // must return data.Name = resp.Name data.ClusterId = types.StringValue(*resp.ID) @@ -568,11 +567,6 @@ func refreshClusterResourceData(resp *clusterApi.GetClusterOKBody, data *cluster VpcPeering: &vpcPeering, }, } - paused := false - if resp.Status.ClusterStatus == "PAUSED" || resp.Status.ClusterStatus == "PAUSING" { - paused = true - } - data.Config.Paused = &paused // may return tiflash := resp.Config.Components.Tiflash if tiflash != nil { @@ -776,7 +770,7 @@ func (r clusterResource) Update(ctx context.Context, req resource.UpdateRequest, resp.Diagnostics.AddError("Update Error", fmt.Sprintf("Unable to call GetClusterById, got error: %s", err)) return } - refreshClusterResourceData(getClusterResp.Payload, &data) + refreshClusterResourceData(ctx, getClusterResp.Payload, &data) // save into the Terraform state. diags = resp.State.Set(ctx, &data) diff --git a/internal/provider/plan_modify.go b/internal/provider/plan_modify.go index 1220905..a307e33 100644 --- a/internal/provider/plan_modify.go +++ b/internal/provider/plan_modify.go @@ -36,7 +36,16 @@ func (m clusterResourceStatusModifier) PlanModifyObject(ctx context.Context, req if req.ConfigValue.IsUnknown() { return } - // Does not apply to cluster_status attribute + + // Apply state value if cluster is a serverless cluster + var data clusterResourceData + req.State.Get(ctx, &data) + if data.ClusterType == dev { + resp.PlanValue = req.StateValue + return + } + + // Does not apply to cluster_status attribute for dedicated attributes := req.StateValue.Attributes() attributes["cluster_status"] = types.StringUnknown() newStateValue, diag := basetypes.NewObjectValue(req.StateValue.AttributeTypes(ctx), attributes)