2021-07-08 00:28:21 +00:00
|
|
|
// Copyright 2016-2021, Pulumi Corporation. All rights reserved.
|
2022-09-14 03:02:19 +00:00
|
|
|
//go:build !all
|
|
|
|
// +build !all
|
2021-07-08 00:28:21 +00:00
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
|
[sdk/go] Track rehydrated components as dependencies
When expanding dependencies, local component resources act as aggregations of their descendants; rather than adding the component resource itself, each child resource is added as a dependency. Remote component resources, on the other hand, are added directly to the set, as they naturally act as aggregations of their children with respect to dependencies: the construction of a remote component always waits on the construction of its children.
https://github.com/pulumi/pulumi/blob/46ccb5a22caaece6895d828cd019f3886eb7902a/sdk/go/pulumi/rpc.go#L65-L91
However, rehydrated components (i.e. instances of a component resource that have been recreated from a URN, typically via deserialization of a resource reference) won't have any children from the SDK's perspective. And because of that, they aren't currently kept as a dependency.
This change fixes rehydrated components to be marked as remote components, in the same way as "dependency resources" are marked as remote components, so that they are kept as a dependency.
2023-03-24 18:29:42 +00:00
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/pulumi/internals"
|
2021-07-08 00:28:21 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type componentArgs struct {
|
|
|
|
First string `pulumi:"first"`
|
|
|
|
Second string `pulumi:"second"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ComponentArgs struct {
|
|
|
|
First pulumi.StringInput
|
|
|
|
Second pulumi.StringInput
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ComponentArgs) ElementType() reflect.Type {
|
|
|
|
return reflect.TypeOf((*componentArgs)(nil)).Elem()
|
|
|
|
}
|
|
|
|
|
|
|
|
type Component struct {
|
|
|
|
pulumi.ResourceState
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewComponent(
|
2023-03-03 16:36:39 +00:00
|
|
|
ctx *pulumi.Context, name string, args *ComponentArgs, opts ...pulumi.ResourceOption,
|
|
|
|
) (*Component, error) {
|
2021-07-08 00:28:21 +00:00
|
|
|
var resource Component
|
|
|
|
err := ctx.RegisterRemoteComponentResource("testcomponent:index:Component", name, args, &resource, opts...)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &resource, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Component) GetMessage(ctx *pulumi.Context, args *ComponentGetMessageArgs) (ComponentGetMessageResultOutput, error) {
|
|
|
|
out, err := ctx.Call("testcomponent:index:Component/getMessage", args, ComponentGetMessageResultOutput{}, c)
|
|
|
|
if err != nil {
|
|
|
|
return ComponentGetMessageResultOutput{}, err
|
|
|
|
}
|
|
|
|
return out.(ComponentGetMessageResultOutput), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type componentGetMessageArgs struct {
|
|
|
|
Name string `pulumi:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ComponentGetMessageArgs struct {
|
|
|
|
Name pulumi.StringInput
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ComponentGetMessageArgs) ElementType() reflect.Type {
|
|
|
|
return reflect.TypeOf((*componentGetMessageArgs)(nil)).Elem()
|
|
|
|
}
|
|
|
|
|
|
|
|
type ComponentGetMessageResult struct {
|
|
|
|
Message string `pulumi:"message"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ComponentGetMessageResultOutput struct{ *pulumi.OutputState }
|
|
|
|
|
|
|
|
func (ComponentGetMessageResultOutput) ElementType() reflect.Type {
|
|
|
|
return reflect.TypeOf((*ComponentGetMessageResult)(nil)).Elem()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (o ComponentGetMessageResultOutput) Message() pulumi.StringOutput {
|
|
|
|
return o.ApplyT(func(v ComponentGetMessageResult) string { return v.Message }).(pulumi.StringOutput)
|
|
|
|
}
|
|
|
|
|
2021-07-22 12:28:46 +00:00
|
|
|
func (*Component) ElementType() reflect.Type {
|
|
|
|
return reflect.TypeOf((*Component)(nil))
|
|
|
|
}
|
|
|
|
|
2021-07-08 00:28:21 +00:00
|
|
|
func init() {
|
|
|
|
pulumi.RegisterOutputType(ComponentGetMessageResultOutput{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
pulumi.Run(func(ctx *pulumi.Context) error {
|
|
|
|
component, err := NewComponent(ctx, "component", &ComponentArgs{
|
|
|
|
First: pulumi.String("Hello"),
|
|
|
|
Second: pulumi.String("World"),
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
result, err := component.GetMessage(ctx, &ComponentGetMessageArgs{
|
|
|
|
Name: pulumi.String("Alice"),
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
[sdk/go] Track rehydrated components as dependencies
When expanding dependencies, local component resources act as aggregations of their descendants; rather than adding the component resource itself, each child resource is added as a dependency. Remote component resources, on the other hand, are added directly to the set, as they naturally act as aggregations of their children with respect to dependencies: the construction of a remote component always waits on the construction of its children.
https://github.com/pulumi/pulumi/blob/46ccb5a22caaece6895d828cd019f3886eb7902a/sdk/go/pulumi/rpc.go#L65-L91
However, rehydrated components (i.e. instances of a component resource that have been recreated from a URN, typically via deserialization of a resource reference) won't have any children from the SDK's perspective. And because of that, they aren't currently kept as a dependency.
This change fixes rehydrated components to be marked as remote components, in the same way as "dependency resources" are marked as remote components, so that they are kept as a dependency.
2023-03-24 18:29:42 +00:00
|
|
|
message := result.Message()
|
|
|
|
ctx.Export("message", message)
|
|
|
|
ctx.Export("messagedeps", awaitDependencies(ctx, message))
|
|
|
|
|
2021-07-08 00:28:21 +00:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
}
|
[sdk/go] Track rehydrated components as dependencies
When expanding dependencies, local component resources act as aggregations of their descendants; rather than adding the component resource itself, each child resource is added as a dependency. Remote component resources, on the other hand, are added directly to the set, as they naturally act as aggregations of their children with respect to dependencies: the construction of a remote component always waits on the construction of its children.
https://github.com/pulumi/pulumi/blob/46ccb5a22caaece6895d828cd019f3886eb7902a/sdk/go/pulumi/rpc.go#L65-L91
However, rehydrated components (i.e. instances of a component resource that have been recreated from a URN, typically via deserialization of a resource reference) won't have any children from the SDK's perspective. And because of that, they aren't currently kept as a dependency.
This change fixes rehydrated components to be marked as remote components, in the same way as "dependency resources" are marked as remote components, so that they are kept as a dependency.
2023-03-24 18:29:42 +00:00
|
|
|
|
|
|
|
func awaitDependencies(ctx *pulumi.Context, o pulumi.Output) pulumi.URNArray {
|
|
|
|
r, err := internals.UnsafeAwaitOutput(ctx.Context(), o)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
var deps pulumi.URNArray
|
|
|
|
for _, dep := range r.Dependencies {
|
|
|
|
deps = append(deps, dep.URN())
|
|
|
|
}
|
|
|
|
return deps
|
|
|
|
}
|