From 42bee9268b913a125e1b49e0d31c744b807d7438 Mon Sep 17 00:00:00 2001 From: Ethan <39577870+ethanndickson@users.noreply.github.com> Date: Tue, 30 Jul 2024 16:56:35 +1000 Subject: [PATCH] chore: add template resource trace logging (#44) --- docs/data-sources/template.md | 8 +++--- internal/provider/template_resource.go | 30 +++++++++++++++++++++ internal/provider/template_resource_test.go | 5 +++- 3 files changed, 38 insertions(+), 5 deletions(-) diff --git a/docs/data-sources/template.md b/docs/data-sources/template.md index 986f359..23f5794 100644 --- a/docs/data-sources/template.md +++ b/docs/data-sources/template.md @@ -3,12 +3,12 @@ page_title: "coderd_template Data Source - coderd" subcategory: "" description: |- - An existing template on the coder deployment + An existing template on the Coder deployment. --- # coderd_template (Data Source) -An existing template on the coder deployment +An existing template on the Coder deployment. @@ -19,7 +19,7 @@ An existing template on the coder deployment - `id` (String) The ID of the template to retrieve. This field will be populated if a template name is supplied. - `name` (String) The name of the template to retrieve. This field will be populated if an ID is supplied. -- `organization_id` (String) ID of the organization the template is associated with. +- `organization_id` (String) ID of the organization the template is associated with. This field will be populated if an ID is supplied. Defaults to the provider default organization ID. ### Read-Only @@ -38,7 +38,7 @@ An existing template on the coder deployment - `display_name` (String) Display name of the template. - `failure_ttl_ms` (Number) Automatic cleanup TTL for failed workspace builds. - `icon` (String) URL of the template's icon. -- `require_active_version` (Boolean) Whether workspaces created from the template must be up-to-datae on the latest active version. +- `require_active_version` (Boolean) Whether workspaces created from the template must be up-to-date on the latest active version. - `time_til_dormant_autodelete_ms` (Number) Duration of inactivity after the workspace becomes dormant before a workspace is automatically deleted. - `time_til_dormant_ms` (Number) Duration of inactivity before a workspace is considered dormant. - `updated_at` (Number) Unix timestamp of when the template was last updated. diff --git a/internal/provider/template_resource.go b/internal/provider/template_resource.go index 5ab55a7..4b62fe2 100644 --- a/internal/provider/template_resource.go +++ b/internal/provider/template_resource.go @@ -352,6 +352,7 @@ func (r *TemplateResource) Create(ctx context.Context, req resource.CreateReques return } if idx == 0 { + tflog.Trace(ctx, "creating template") templateResp, err = client.CreateTemplate(ctx, orgID, codersdk.CreateTemplateRequest{ Name: data.Name.ValueString(), DisplayName: data.DisplayName.ValueString(), @@ -366,14 +367,23 @@ func (r *TemplateResource) Create(ctx context.Context, req resource.CreateReques resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to create template: %s", err)) return } + tflog.Trace(ctx, "successfully created template", map[string]any{ + "id": templateResp.ID, + }) + tflog.Trace(ctx, "updating template ACL") err = client.UpdateTemplateACL(ctx, templateResp.ID, convertACLToRequest(data.ACL)) if err != nil { resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to update template ACL: %s", err)) return } + tflog.Trace(ctx, "successfully updated template ACL") } if version.Active.ValueBool() { + tflog.Trace(ctx, "marking template version as active", map[string]any{ + "version_id": versionResp.ID, + "template_id": templateResp.ID, + }) err := client.UpdateActiveTemplateVersion(ctx, templateResp.ID, codersdk.UpdateActiveTemplateVersion{ ID: versionResp.ID, }) @@ -381,6 +391,7 @@ func (r *TemplateResource) Create(ctx context.Context, req resource.CreateReques resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to set active template version: %s", err)) return } + tflog.Trace(ctx, "marked template version as active") } data.Versions[idx].ID = UUIDValue(versionResp.ID) data.Versions[idx].Name = types.StringValue(versionResp.Name) @@ -478,6 +489,7 @@ func (r *TemplateResource) Update(ctx context.Context, req resource.UpdateReques client := r.data.Client if !planState.EqualTemplateMetadata(curState) { + tflog.Trace(ctx, "change in template metadata detected, updating.") _, err := client.UpdateTemplateMeta(ctx, templateID, codersdk.UpdateTemplateMeta{ Name: planState.Name.ValueString(), DisplayName: planState.DisplayName.ValueString(), @@ -491,11 +503,13 @@ func (r *TemplateResource) Update(ctx context.Context, req resource.UpdateReques resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to update template: %s", err)) return } + tflog.Trace(ctx, "successfully updated template metadata") err = client.UpdateTemplateACL(ctx, templateID, convertACLToRequest(planState.ACL)) if err != nil { resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to update template ACL: %s", err)) return } + tflog.Trace(ctx, "successfully updated template ACL") } for idx, plannedVersion := range planState.Versions { @@ -504,6 +518,7 @@ func (r *TemplateResource) Update(ctx context.Context, req resource.UpdateReques foundVersion := curState.Versions.ByID(plannedVersion.ID) // If the version is new, or if the directory hash has changed, create a new version if foundVersion == nil || foundVersion.DirectoryHash != plannedVersion.DirectoryHash { + tflog.Trace(ctx, "discovered a new or modified template version") versionResp, err := newVersion(ctx, client, newVersionRequest{ Version: &plannedVersion, OrganizationID: orgID, @@ -524,6 +539,10 @@ func (r *TemplateResource) Update(ctx context.Context, req resource.UpdateReques return } if plannedVersion.Active.ValueBool() { + tflog.Trace(ctx, "marking template version as active", map[string]any{ + "version_id": versionResp.ID, + "template_id": templateID, + }) err := client.UpdateActiveTemplateVersion(ctx, templateID, codersdk.UpdateActiveTemplateVersion{ ID: versionResp.ID, }) @@ -531,6 +550,7 @@ func (r *TemplateResource) Update(ctx context.Context, req resource.UpdateReques resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to update active template version: %s", err)) return } + tflog.Trace(ctx, "marked template version as active") } planState.Versions[idx].ID = UUIDValue(versionResp.ID) } @@ -553,6 +573,7 @@ func (r *TemplateResource) Delete(ctx context.Context, req resource.DeleteReques templateID := data.ID.ValueUUID() + tflog.Trace(ctx, "deleting template") err := client.DeleteTemplate(ctx, templateID) if err != nil { resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Failed to delete template: %s", err)) @@ -712,11 +733,14 @@ type newVersionRequest struct { func newVersion(ctx context.Context, client *codersdk.Client, req newVersionRequest) (*codersdk.TemplateVersion, error) { directory := req.Version.Directory.ValueString() + tflog.Trace(ctx, "uploading directory") uploadResp, err := uploadDirectory(ctx, client, slog.Make(newTFLogSink(ctx)), directory) if err != nil { return nil, fmt.Errorf("failed to upload directory: %s", err) } + tflog.Trace(ctx, "successfully uploaded directory") // TODO(ethanndickson): Uncomment when a released `codersdk` exports template variable parsing + // tflog.Trace(ctx,"discovering and parsing vars files") // varFiles, err := codersdk.DiscoverVarsFiles(directory) // if err != nil { // return nil, fmt.Errorf("failed to discover vars files: %s", err) @@ -725,6 +749,9 @@ func newVersion(ctx context.Context, client *codersdk.Client, req newVersionRequ // if err != nil { // return nil, fmt.Errorf("failed to parse user variable values: %s", err) // } + // tflog.Trace(ctx,"discovered and parsed vars files", map[string]any{ + // "vars": vars, + // }) vars := make([]codersdk.VariableValue, 0, len(req.Version.TerraformVariables)) for _, variable := range req.Version.TerraformVariables { vars = append(vars, codersdk.VariableValue{ @@ -743,14 +770,17 @@ func newVersion(ctx context.Context, client *codersdk.Client, req newVersionRequ if req.TemplateID != nil { tmplVerReq.TemplateID = *req.TemplateID } + tflog.Trace(ctx, "creating template version") versionResp, err := client.CreateTemplateVersion(ctx, req.OrganizationID, tmplVerReq) if err != nil { return nil, fmt.Errorf("failed to create template version: %s", err) } + tflog.Trace(ctx, "waiting for template version import job.") err = waitForJob(ctx, client, &versionResp) if err != nil { return nil, fmt.Errorf("failed to wait for job: %s", err) } + tflog.Trace(ctx, "successfully created template version") return &versionResp, nil } diff --git a/internal/provider/template_resource_test.go b/internal/provider/template_resource_test.go index 50b0e24..29307b1 100644 --- a/internal/provider/template_resource_test.go +++ b/internal/provider/template_resource_test.go @@ -2,6 +2,7 @@ package provider import ( "context" + "os" "regexp" "slices" "strings" @@ -15,6 +16,9 @@ import ( ) func TestAccTemplateResource(t *testing.T) { + if os.Getenv("TF_ACC") == "" { + t.Skip("Acceptance tests are disabled.") + } ctx := context.Background() client := integration.StartCoder(ctx, t, "template_acc", true) firstUser, err := client.User(ctx, codersdk.Me) @@ -84,7 +88,6 @@ func TestAccTemplateResource(t *testing.T) { cfg6.Versions = slices.Clone(cfg6.Versions[1:]) resource.Test(t, resource.TestCase{ - IsUnitTest: true, PreCheck: func() { testAccPreCheck(t) }, ProtoV6ProviderFactories: testAccProtoV6ProviderFactories, Steps: []resource.TestStep{