2022-02-01 20:11:38 +00:00
|
|
|
package deploy
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func createSnapshot() Snapshot {
|
|
|
|
resourceUrns := []resource.URN{
|
|
|
|
resource.NewURN("stack", "test", "typ", "aws:resource", "bar"),
|
|
|
|
resource.NewURN("stack", "test", "typ", "aws:resource", "aname"),
|
|
|
|
resource.NewURN("stack", "test", "typ", "azure:resource", "bar"),
|
|
|
|
}
|
|
|
|
resources := []*resource.State{}
|
|
|
|
for _, u := range resourceUrns {
|
|
|
|
resources = append(resources, &resource.State{URN: u})
|
|
|
|
}
|
|
|
|
return Snapshot{Resources: resources}
|
|
|
|
}
|
|
|
|
|
2022-07-18 18:04:19 +00:00
|
|
|
func createSnapshotPtr() *Snapshot {
|
|
|
|
s := createSnapshot()
|
|
|
|
return &s
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSnapshotNormalizeURNReferences(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
s1 := createSnapshotPtr()
|
|
|
|
s1n, err := s1.NormalizeURNReferences()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Same(t, s1, s1n)
|
|
|
|
|
|
|
|
s2 := createSnapshotPtr()
|
|
|
|
r0 := s2.Resources[0]
|
|
|
|
r0.Aliases = []resource.URN{r0.URN}
|
|
|
|
s2.Resources[2].Parent = r0.URN
|
|
|
|
r0.URN += "!"
|
|
|
|
s2n, err := s2.NormalizeURNReferences()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.NotSame(t, s2, s2n)
|
|
|
|
// before normalize in s2, Parent link uses outdated URL
|
|
|
|
assert.Equal(t, s2.Resources[2].Parent+"!", s2.Resources[0].URN)
|
|
|
|
// after normalize in s2n, Parent link uses the real URL rewritten via aliases
|
|
|
|
assert.Equal(t, s2n.Resources[2].Parent, s2n.Resources[0].URN)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSnapshotWithUpdatedResources(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
s1 := createSnapshotPtr()
|
|
|
|
|
|
|
|
s := s1.withUpdatedResources(func(r *resource.State) *resource.State {
|
|
|
|
return r
|
|
|
|
})
|
|
|
|
assert.Same(t, s, s1)
|
|
|
|
|
|
|
|
s = s1.withUpdatedResources(func(r *resource.State) *resource.State {
|
2024-05-09 16:15:41 +00:00
|
|
|
out := r.Copy()
|
all: Fix revive issues
Fixes the following issues found by revive
included in the latest release of golangci-lint.
Full list of issues:
**pkg**
```
backend/display/object_diff.go:47:10: superfluous-else: if block ends with a break statement, so drop this else and outdent its block (move short variable declaration to its own line if necessary) (revive)
backend/display/object_diff.go:716:12: redefines-builtin-id: redefinition of the built-in function delete (revive)
backend/display/object_diff.go:742:14: redefines-builtin-id: redefinition of the built-in function delete (revive)
backend/display/object_diff.go:983:10: superfluous-else: if block ends with a continue statement, so drop this else and outdent its block (revive)
backend/httpstate/backend.go:1814:4: redefines-builtin-id: redefinition of the built-in function cap (revive)
backend/httpstate/backend.go:1824:5: redefines-builtin-id: redefinition of the built-in function cap (revive)
backend/httpstate/client/client.go:444:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
backend/httpstate/client/client.go:455:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
cmd/pulumi/org.go:113:4: if-return: redundant if ...; err != nil check, just return error instead. (revive)
cmd/pulumi/util.go:216:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
codegen/docs/gen.go:428:2: redefines-builtin-id: redefinition of the built-in function copy (revive)
codegen/hcl2/model/expression.go:2151:5: redefines-builtin-id: redefinition of the built-in function close (revive)
codegen/hcl2/syntax/comments.go:151:2: redefines-builtin-id: redefinition of the built-in function close (revive)
codegen/hcl2/syntax/comments.go:329:3: redefines-builtin-id: redefinition of the built-in function close (revive)
codegen/hcl2/syntax/comments.go:381:5: redefines-builtin-id: redefinition of the built-in function close (revive)
codegen/nodejs/gen.go:1367:5: redefines-builtin-id: redefinition of the built-in function copy (revive)
codegen/python/gen_program_expressions.go:136:2: redefines-builtin-id: redefinition of the built-in function close (revive)
codegen/python/gen_program_expressions.go:142:3: redefines-builtin-id: redefinition of the built-in function close (revive)
codegen/report/report.go:126:6: redefines-builtin-id: redefinition of the built-in function panic (revive)
codegen/schema/docs_test.go:210:10: superfluous-else: if block ends with a continue statement, so drop this else and outdent its block (move short variable declaration to its own line if necessary) (revive)
codegen/schema/schema.go:790:2: redefines-builtin-id: redefinition of the built-in type any (revive)
codegen/schema/schema.go:793:4: redefines-builtin-id: redefinition of the built-in type any (revive)
resource/deploy/plan.go:506:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
resource/deploy/snapshot_test.go:59:3: redefines-builtin-id: redefinition of the built-in function copy (revive)
resource/deploy/state_builder.go:108:2: redefines-builtin-id: redefinition of the built-in function copy (revive)
```
**sdk**
```
go/common/resource/plugin/context.go:142:2: redefines-builtin-id: redefinition of the built-in function copy (revive)
go/common/resource/plugin/plugin.go:142:12: superfluous-else: if block ends with a break statement, so drop this else and outdent its block (revive)
go/common/resource/properties_diff.go:114:2: redefines-builtin-id: redefinition of the built-in function len (revive)
go/common/resource/properties_diff.go:117:4: redefines-builtin-id: redefinition of the built-in function len (revive)
go/common/resource/properties_diff.go:122:4: redefines-builtin-id: redefinition of the built-in function len (revive)
go/common/resource/properties_diff.go:127:4: redefines-builtin-id: redefinition of the built-in function len (revive)
go/common/resource/properties_diff.go:132:4: redefines-builtin-id: redefinition of the built-in function len (revive)
go/common/util/deepcopy/copy.go:30:1: redefines-builtin-id: redefinition of the built-in function copy (revive)
go/common/workspace/creds.go:242:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
go/pulumi-language-go/main.go:569:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
go/pulumi-language-go/main.go:706:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
go/pulumi/run_test.go:925:2: redefines-builtin-id: redefinition of the built-in type any (revive)
go/pulumi/run_test.go:933:3: redefines-builtin-id: redefinition of the built-in type any (revive)
nodejs/cmd/pulumi-language-nodejs/main.go:778:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
python/cmd/pulumi-language-python/main.go:1011:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
python/cmd/pulumi-language-python/main.go:863:2: if-return: redundant if ...; err != nil check, just return error instead. (revive)
python/python.go:230:2: redefines-builtin-id: redefinition of the built-in function print (revive)
```
**tests**
```
integration/integration_util_test.go:282:11: superfluous-else: if block ends with a continue statement, so drop this else and outdent its block (move short variable declaration to its own line if necessary) (revive)
```
2023-03-20 23:48:02 +00:00
|
|
|
out.URN += "!"
|
2024-05-09 16:15:41 +00:00
|
|
|
return out
|
2022-07-18 18:04:19 +00:00
|
|
|
})
|
|
|
|
assert.NotSame(t, s, s1)
|
|
|
|
assert.Equal(t, s1.Resources[0].URN+"!", s.Resources[0].URN)
|
|
|
|
}
|