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:
parent
085caaf927
commit
c57dc78119
@ -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(`
|
||||||
|
@ -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 {
|
||||||
|
Loading…
Reference in New Issue
Block a user