pulumi/tests/testdata/codegen/unions-inside-arrays/go/example/exampleServer.go

126 lines
3.7 KiB
Go
Raw Permalink Normal View History

[sdk-gen/go] Generate non-plain type variants for types used as inputs inside unions (#14679) # Description When using types in union cases (using `oneOf` in the schema) then Go SDK-gen doesn't detect these types as being used as inputs and only emits the plain version of a type. That is unless `generateExtraInputTypes: true` is specified in which case Go SDK-gen will emit the non-plain types as well. In the case of azure-native modules, `generateExtraInputTypes` is currently set to `false` (default) as of latest v2.19.0 and is missing a few non-plain type variants (for example `FirewallPolicyFilterRuleCollection` from [this file](https://raw.githubusercontent.com/pulumi/pulumi-azure-native-sdk/master/network/pulumiTypes.go)). There no single plain type in azure-native and yet it is missing these non-plain variants. This PR fixes that by also traversing the element types of schema union definitions when determining plain-ness of types and how they are used. I added an example schema with an array of unions (common case in azure-native) and confirmed that the change actually results in the non-plain types being generated when `generateExtraInputTypes` is set to `false` Fixes https://github.com/pulumi/pulumi-azure-native/issues/1922 ## Checklist - [ ] I have run `make tidy` to update any new dependencies - [x] I have run `make lint` to verify my code passes the lint check - [x] I have formatted my code using `gofumpt` <!--- Please provide details if the checkbox below is to be left unchecked. --> - [x] I have added tests that prove my fix is effective or that my feature works <!--- User-facing changes require a CHANGELOG entry. --> - [x] I have run `make changelog` and committed the `changelog/pending/<file>` documenting my change <!-- If the change(s) in this PR is a modification of an existing call to the Pulumi Cloud, then the service should honor older versions of the CLI where this change would not exist. You must then bump the API version in /pkg/backend/httpstate/client/api.go, as well as add it to the service. --> - [ ] Yes, there are changes in this PR that warrants bumping the Pulumi Cloud API version <!-- @Pulumi employees: If yes, you must submit corresponding changes in the service repo. -->
2023-11-29 12:37:53 +00:00
// Code generated by test DO NOT EDIT.
// *** WARNING: Do not edit by hand unless you're certain you know what you are doing! ***
package example
import (
"context"
"reflect"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
"github.com/pulumi/pulumi/sdk/v3/go/pulumix"
"unions-inside-arrays/example/internal"
)
type ExampleServer struct {
pulumi.CustomResourceState
Name pulumi.StringPtrOutput `pulumi:"name"`
}
// NewExampleServer registers a new resource with the given unique name, arguments, and options.
func NewExampleServer(ctx *pulumi.Context,
name string, args *ExampleServerArgs, opts ...pulumi.ResourceOption) (*ExampleServer, error) {
if args == nil {
args = &ExampleServerArgs{}
}
opts = internal.PkgResourceDefaultOpts(opts)
var resource ExampleServer
err := ctx.RegisterResource("example:index:ExampleServer", name, args, &resource, opts...)
if err != nil {
return nil, err
}
return &resource, nil
}
// GetExampleServer gets an existing ExampleServer resource's state with the given name, ID, and optional
// state properties that are used to uniquely qualify the lookup (nil if not required).
func GetExampleServer(ctx *pulumi.Context,
name string, id pulumi.IDInput, state *ExampleServerState, opts ...pulumi.ResourceOption) (*ExampleServer, error) {
var resource ExampleServer
err := ctx.ReadResource("example:index:ExampleServer", name, id, state, &resource, opts...)
if err != nil {
return nil, err
}
return &resource, nil
}
// Input properties used for looking up and filtering ExampleServer resources.
type exampleServerState struct {
}
type ExampleServerState struct {
}
func (ExampleServerState) ElementType() reflect.Type {
return reflect.TypeOf((*exampleServerState)(nil)).Elem()
}
type exampleServerArgs struct {
PropertiesCollection []interface{} `pulumi:"propertiesCollection"`
}
// The set of arguments for constructing a ExampleServer resource.
type ExampleServerArgs struct {
PropertiesCollection pulumi.ArrayInput
}
func (ExampleServerArgs) ElementType() reflect.Type {
return reflect.TypeOf((*exampleServerArgs)(nil)).Elem()
}
type ExampleServerInput interface {
pulumi.Input
ToExampleServerOutput() ExampleServerOutput
ToExampleServerOutputWithContext(ctx context.Context) ExampleServerOutput
}
func (*ExampleServer) ElementType() reflect.Type {
return reflect.TypeOf((**ExampleServer)(nil)).Elem()
}
func (i *ExampleServer) ToExampleServerOutput() ExampleServerOutput {
return i.ToExampleServerOutputWithContext(context.Background())
}
func (i *ExampleServer) ToExampleServerOutputWithContext(ctx context.Context) ExampleServerOutput {
return pulumi.ToOutputWithContext(ctx, i).(ExampleServerOutput)
}
func (i *ExampleServer) ToOutput(ctx context.Context) pulumix.Output[*ExampleServer] {
return pulumix.Output[*ExampleServer]{
OutputState: i.ToExampleServerOutputWithContext(ctx).OutputState,
}
}
type ExampleServerOutput struct{ *pulumi.OutputState }
func (ExampleServerOutput) ElementType() reflect.Type {
return reflect.TypeOf((**ExampleServer)(nil)).Elem()
}
func (o ExampleServerOutput) ToExampleServerOutput() ExampleServerOutput {
return o
}
func (o ExampleServerOutput) ToExampleServerOutputWithContext(ctx context.Context) ExampleServerOutput {
return o
}
func (o ExampleServerOutput) ToOutput(ctx context.Context) pulumix.Output[*ExampleServer] {
return pulumix.Output[*ExampleServer]{
OutputState: o.OutputState,
}
}
func (o ExampleServerOutput) Name() pulumi.StringPtrOutput {
return o.ApplyT(func(v *ExampleServer) pulumi.StringPtrOutput { return v.Name }).(pulumi.StringPtrOutput)
}
func init() {
pulumi.RegisterInputType(reflect.TypeOf((*ExampleServerInput)(nil)).Elem(), &ExampleServer{})
pulumi.RegisterOutputType(ExampleServerOutput{})
}