pulumi/tests/integration/steps/steps_test.go
CyrusNajmabadi 66bd3f4aa8
Breaking changes due to Feature 2.0 work
* Make `async:true` the default for `invoke` calls (#3750)

* Switch away from native grpc impl. (#3728)

* Remove usage of the 'deasync' library from @pulumi/pulumi. (#3752)

* Only retry as long as we get unavailable back.  Anything else continues. (#3769)

* Handle all errors for now. (#3781)


* Do not assume --yes was present when using pulumi in non-interactive mode (#3793)

* Upgrade all paths for sdk and pkg to v2

* Backport C# invoke classes and other recent gen changes (#4288)

Adjust C# generation

* Replace IDeployment with a sealed class (#4318)

Replace IDeployment with a sealed class

* .NET: default to args subtype rather than Args.Empty (#4320)

* Adding system namespace for Dotnet code gen

This is required for using Obsolute attributes for deprecations

```
Iam/InstanceProfile.cs(142,10): error CS0246: The type or namespace name 'ObsoleteAttribute' could not be found (are you missing a using directive or an assembly reference?) [/Users/stack72/code/go/src/github.com/pulumi/pulumi-aws/sdk/dotnet/Pulumi.Aws.csproj]
Iam/InstanceProfile.cs(142,10): error CS0246: The type or namespace name 'Obsolete' could not be found (are you missing a using directive or an assembly reference?) [/Users/stack72/code/go/src/github.com/pulumi/pulumi-aws/sdk/dotnet/Pulumi.Aws.csproj]
```

* Fix the nullability of config type properties in C# codegen (#4379)
2020-04-14 09:30:25 +01:00

100 lines
3.4 KiB
Go

// Copyright 2016-2018, Pulumi Corporation. All rights reserved.
package ints
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/pulumi/pulumi/pkg/v2/resource/deploy/providers"
"github.com/pulumi/pulumi/pkg/v2/testing/integration"
"github.com/pulumi/pulumi/sdk/v2/go/common/apitype"
"github.com/pulumi/pulumi/sdk/v2/go/common/resource"
)
func validateResources(t *testing.T, resources []apitype.ResourceV3, expectedNames ...string) {
// Build the lookup table of expected resource names.
expectedNamesTable := make(map[string]struct{})
for _, n := range expectedNames {
expectedNamesTable[n] = struct{}{}
}
// Pull out the stack resource, which must be the first resource in the checkpoint.
stackRes, resources := resources[0], resources[1:]
assert.Equal(t, resource.RootStackType, stackRes.URN.Type())
// If there are more resources than just the stack, the second resource will be the default provider.
if len(resources) > 0 {
// Pull out the single provider resource, which should be the second resource in the checkpoint.
providerRes := resources[0]
resources = resources[1:]
assert.True(t, providers.IsProviderType(providerRes.URN.Type()))
}
// Ensure that the resource count is correct.
assert.Equal(t, len(resources), len(expectedNames))
// Ensure that exactly the provided resources are in the array.
for _, res := range resources {
name := string(res.URN.Name())
_, ok := expectedNamesTable[name]
assert.True(t, ok)
delete(expectedNamesTable, name)
}
}
// TestSteps tests many combinations of creates, updates, deletes, replacements, and so on.
func TestSteps(t *testing.T) {
integration.ProgramTest(t, &integration.ProgramTestOptions{
Dir: "step1",
Dependencies: []string{"@pulumi/pulumi"},
Quick: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
validateResources(t, stackInfo.Deployment.Resources, "a", "b", "c", "d")
},
EditDirs: []integration.EditDir{
{
Dir: "step2",
Additive: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
validateResources(t, stackInfo.Deployment.Resources, "a", "b", "c", "e")
},
},
{
Dir: "step3",
Additive: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
validateResources(t, stackInfo.Deployment.Resources, "a", "c", "e")
},
},
{
Dir: "step4",
Additive: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
validateResources(t, stackInfo.Deployment.Resources, "a", "c", "e")
},
},
{
Dir: "step5",
Additive: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
validateResources(t, stackInfo.Deployment.Resources, "a", "c", "e")
},
},
{
Dir: "step6",
Additive: true,
ExtraRuntimeValidation: func(t *testing.T, stackInfo integration.RuntimeValidationStackInfo) {
assert.NotNil(t, stackInfo.Deployment)
validateResources(t, stackInfo.Deployment.Resources)
},
},
},
})
}