pulumi/tests/integration/double_pending_delete/double_pending_delete_test.go
Sean Gillespie a35aba137b
Retire pending deletions at start of plan (#1886)
* Retire pending deletions at start of plan

Instead of letting pending deletions pile up to be retired at the end of
a plan, this commit eagerly disposes of any pending deletions that were
pending at the end of the previous plan. This is a nice usability win
and also reclaims an invariant that at most one resource with a given
URN is live and at most one is pending deletion at any point in time.

* Rebase against master

* Fix a test issue arising from shared snapshots

* CR feedback

* plan -> replacement

* Use ephemeral statuses to communicate deletions
2018-09-10 16:48:14 -07:00

100 lines
3.4 KiB
Go

// Copyright 2016-2018, Pulumi Corporation. All rights reserved.
package ints
import (
"testing"
"github.com/pulumi/pulumi/pkg/resource"
"github.com/pulumi/pulumi/pkg/resource/deploy/providers"
"github.com/pulumi/pulumi/pkg/testing/integration"
"github.com/stretchr/testify/assert"
)
// Test that the engine tolerates two deletions of the same URN in the same plan.
func TestDoublePendingDelete(t *testing.T) {
integration.ProgramTest(t, &integration.ProgramTestOptions{
Dir: "step1",
Dependencies: []string{"@pulumi/pulumi"},
Quick: true,
EditDirs: []integration.EditDir{
{
Dir: "step2",
Additive: true,
ExpectFailure: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
// Four resources in this deployment: the root resource, A, B, and A (pending delete)
assert.Equal(t, 5, len(stackInfo.Deployment.Resources))
stackRes := stackInfo.Deployment.Resources[0]
assert.Equal(t, resource.RootStackType, stackRes.URN.Type())
providerRes := stackInfo.Deployment.Resources[1]
assert.True(t, providers.IsProviderType(providerRes.URN.Type()))
a := stackInfo.Deployment.Resources[2]
assert.Equal(t, "a", string(a.URN.Name()))
assert.False(t, a.Delete)
aCondemned := stackInfo.Deployment.Resources[3]
assert.Equal(t, "a", string(aCondemned.URN.Name()))
assert.True(t, aCondemned.Delete)
b := stackInfo.Deployment.Resources[4]
assert.Equal(t, "b", string(b.URN.Name()))
assert.False(t, b.Delete)
},
},
{
Dir: "step3",
Additive: true,
ExpectFailure: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
// There is still only one pending delete resource in this snapshot.
assert.NotNil(t, stackInfo.Deployment)
assert.Equal(t, 5, len(stackInfo.Deployment.Resources))
stackRes := stackInfo.Deployment.Resources[0]
assert.Equal(t, resource.RootStackType, stackRes.URN.Type())
providerRes := stackInfo.Deployment.Resources[1]
assert.True(t, providers.IsProviderType(providerRes.URN.Type()))
a := stackInfo.Deployment.Resources[2]
assert.Equal(t, "a", string(a.URN.Name()))
assert.False(t, a.Delete)
aCondemned := stackInfo.Deployment.Resources[3]
assert.Equal(t, "a", string(aCondemned.URN.Name()))
assert.True(t, aCondemned.Delete)
b := stackInfo.Deployment.Resources[4]
assert.Equal(t, "b", string(b.URN.Name()))
assert.False(t, b.Delete)
},
},
{
Dir: "step4",
Additive: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
// We should have cleared out all of the pending deletes now.
assert.NotNil(t, stackInfo.Deployment)
assert.Equal(t, 4, len(stackInfo.Deployment.Resources))
stackRes := stackInfo.Deployment.Resources[0]
assert.Equal(t, resource.RootStackType, stackRes.URN.Type())
providerRes := stackInfo.Deployment.Resources[1]
assert.True(t, providers.IsProviderType(providerRes.URN.Type()))
a := stackInfo.Deployment.Resources[2]
assert.Equal(t, "a", string(a.URN.Name()))
assert.False(t, a.Delete)
b := stackInfo.Deployment.Resources[3]
assert.Equal(t, "b", string(b.URN.Name()))
assert.False(t, b.Delete)
},
},
},
})
}