0
0
mirror of https://github.com/bpg/terraform-provider-proxmox.git synced 2025-07-02 03:22:59 +00:00

fix(vm): do not delete a VM during retry on create (#1711)

Signed-off-by: Pavel Boldyrev <627562+bpg@users.noreply.github.com>
This commit is contained in:
Pavel Boldyrev 2025-01-13 20:40:16 -05:00 committed by GitHub
parent 085caaf927
commit c57dc78119
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 15 additions and 13 deletions

View File

@ -6,12 +6,6 @@
//go:build acceptance || all //go:build acceptance || all
/*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
*/
package test package test
import ( import (
@ -161,7 +155,7 @@ func TestAccResourceVM(t *testing.T) {
architecture = "x86_64" architecture = "x86_64"
} }
}`, WithAPIToken()), }`, WithAPIToken()),
ExpectError: regexp.MustCompile(`the CPU architecture can only be set by the root account`), ExpectError: regexp.MustCompile(`can only be set by the root account`),
}, },
{ {
Config: te.RenderConfig(` Config: te.RenderConfig(`

View File

@ -79,10 +79,19 @@ func (c *Client) CreateVM(ctx context.Context, d *CreateRequestBody) error {
// CreateVMAsync creates a virtual machine asynchronously. Returns ID of the started task. // CreateVMAsync creates a virtual machine asynchronously. Returns ID of the started task.
func (c *Client) CreateVMAsync(ctx context.Context, d *CreateRequestBody) (*string, error) { func (c *Client) CreateVMAsync(ctx context.Context, d *CreateRequestBody) (*string, error) {
resBody := &CreateResponseBody{} resBody := &CreateResponseBody{}
retrying := false
// retry the request if we get an error that the VM already exists
// but only if we're retrying. If this error is returned by the first
// request, we'll just return the error (i.e. can't "override" the VM).
err := retry.Do( err := retry.Do(
func() error { func() error {
return c.DoRequest(ctx, http.MethodPost, c.basePath(), d, resBody) err := c.DoRequest(ctx, http.MethodPost, c.basePath(), d, resBody)
if err != nil && retrying && strings.Contains(err.Error(), "already exists") {
return nil
}
return err
}, },
retry.Context(ctx), retry.Context(ctx),
retry.Attempts(3), retry.Attempts(3),
@ -94,11 +103,10 @@ func (c *Client) CreateVMAsync(ctx context.Context, d *CreateRequestBody) (*stri
"error": err.Error(), "error": err.Error(),
}) })
if e := c.DeleteVM(ctx); e != nil { retrying = true
tflog.Warn(ctx, "deleting VM after failed creation", map[string]interface{}{ }),
"error": e, retry.RetryIf(func(err error) bool {
}) return strings.Contains(err.Error(), "got no worker upid")
}
}), }),
) )
if err != nil { if err != nil {