pulumi/pkg/codegen/internal/test/testdata/plain-schema-gh6957/nodejs/staticPage.ts
Ian Wahbe 3e2f36548e
[codegen/typescript] Call site defaults for plain Pulumi Object types (#8400)
* Add test case

* Fix tests

* Add test dependencies correctly

* Feed through error handling

* Include test output

* Get types to line up

* Add remaining test files

* Update changelog

* Correctly find type paths

* Handle transitive objects

* Handle required fields

* Add required+default test case

* Don't `<any>` cast known types.

* Add plain object to env-helper test

This test fails right now. My next problem is fixing it.

* Handle plain types

* Handle function inputs

* Fix the indentation

* Handle output types correctly

* Remove unnecessary `!`

* Add missing change to fix test

* Run tests with merge

* Merge in next _index.md diff

* Another attempt at _index.md

* Make module generation deterministic

* Fix docs generation

Credit to @praneetloke
2021-11-18 12:23:30 -08:00

73 lines
2.6 KiB
TypeScript

// *** 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 { input as inputs, output as outputs } from "./types";
import * as utilities from "./utilities";
import * as pulumiAws from "@pulumi/aws";
export class StaticPage extends pulumi.ComponentResource {
/** @internal */
public static readonly __pulumiType = 'xyz:index:StaticPage';
/**
* Returns true if the given object is an instance of StaticPage. 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 StaticPage {
if (obj === undefined || obj === null) {
return false;
}
return obj['__pulumiType'] === StaticPage.__pulumiType;
}
/**
* The bucket resource.
*/
public /*out*/ readonly bucket!: pulumi.Output<pulumiAws.s3.Bucket>;
/**
* The website URL.
*/
public /*out*/ readonly websiteUrl!: pulumi.Output<string>;
/**
* Create a StaticPage 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: StaticPageArgs, opts?: pulumi.ComponentResourceOptions) {
let resourceInputs: pulumi.Inputs = {};
opts = opts || {};
if (!opts.id) {
if ((!args || args.indexContent === undefined) && !opts.urn) {
throw new Error("Missing required property 'indexContent'");
}
resourceInputs["foo"] = args ? args.foo : undefined;
resourceInputs["indexContent"] = args ? args.indexContent : undefined;
resourceInputs["bucket"] = undefined /*out*/;
resourceInputs["websiteUrl"] = undefined /*out*/;
} else {
resourceInputs["bucket"] = undefined /*out*/;
resourceInputs["websiteUrl"] = undefined /*out*/;
}
if (!opts.version) {
opts = pulumi.mergeOptions(opts, { version: utilities.getVersion()});
}
super(StaticPage.__pulumiType, name, resourceInputs, opts, true /*remote*/);
}
}
/**
* The set of arguments for constructing a StaticPage resource.
*/
export interface StaticPageArgs {
foo?: inputs.FooArgs;
/**
* The HTML content for index.html.
*/
indexContent: pulumi.Input<string>;
}