pulumi/tests/testdata/codegen/unions-inside-arrays/nodejs/exampleServer.ts

65 lines
2.6 KiB
TypeScript
Raw 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
// *** WARNING: this file was generated by test. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
import * as pulumi from "@pulumi/pulumi";
import * as inputs from "./types/input";
import * as outputs from "./types/output";
import * as utilities from "./utilities";
export class ExampleServer extends pulumi.CustomResource {
/**
* Get an existing ExampleServer resource's state with the given name, ID, and optional extra
* properties used to qualify the lookup.
*
* @param name The _unique_ name of the resulting resource.
* @param id The _unique_ provider ID of the resource to lookup.
* @param opts Optional settings to control the behavior of the CustomResource.
*/
public static get(name: string, id: pulumi.Input<pulumi.ID>, opts?: pulumi.CustomResourceOptions): ExampleServer {
return new ExampleServer(name, undefined as any, { ...opts, id: id });
}
/** @internal */
public static readonly __pulumiType = 'example:index:ExampleServer';
/**
* Returns true if the given object is an instance of ExampleServer. This is designed to work even
* when multiple copies of the Pulumi SDK have been loaded into the same process.
*/
public static isInstance(obj: any): obj is ExampleServer {
if (obj === undefined || obj === null) {
return false;
}
return obj['__pulumiType'] === ExampleServer.__pulumiType;
}
public /*out*/ readonly name!: pulumi.Output<string | undefined>;
/**
* Create a ExampleServer resource with the given unique name, arguments, and options.
*
* @param name The _unique_ name of the resource.
* @param args The arguments to use to populate this resource's properties.
* @param opts A bag of options that control this resource's behavior.
*/
constructor(name: string, args?: ExampleServerArgs, opts?: pulumi.CustomResourceOptions) {
let resourceInputs: pulumi.Inputs = {};
opts = opts || {};
if (!opts.id) {
resourceInputs["propertiesCollection"] = args ? args.propertiesCollection : undefined;
resourceInputs["name"] = undefined /*out*/;
} else {
resourceInputs["name"] = undefined /*out*/;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
super(ExampleServer.__pulumiType, name, resourceInputs, opts);
}
}
/**
* The set of arguments for constructing a ExampleServer resource.
*/
export interface ExampleServerArgs {
propertiesCollection?: pulumi.Input<pulumi.Input<inputs.ServerPropertiesForReplicaArgs | inputs.ServerPropertiesForRestoreArgs>[]>;
}