-
Notifications
You must be signed in to change notification settings - Fork 12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Test and fix support for local plugins #619
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
name: local | ||
scription: An integration test showing the use of a a local plugin | ||
runtime: yaml | ||
resources: | ||
res1: | ||
type: testprovider:index:Random | ||
properties: | ||
length: 10 | ||
res2: | ||
type: testprovider:index:Echo |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
pulumi-resource-testprovider | ||
schema-testprovider.json |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
runtime: go |
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,101 @@ | ||||||
// Copyright 2016-2021, Pulumi Corporation. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nit, I think these are copied from pu/pu, since the provider needs to be available at a relative path. Not sure if we need to update the copyright dates here and in the other files.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. They are directly copied, just as the fastest way to get something to test this with. |
||||||
// | ||||||
// Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
// you may not use this file except in compliance with the License. | ||||||
// You may obtain a copy of the License at | ||||||
// | ||||||
// http://www.apache.org/licenses/LICENSE-2.0 | ||||||
// | ||||||
// Unless required by applicable law or agreed to in writing, software | ||||||
// distributed under the License is distributed on an "AS IS" BASIS, | ||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
// See the License for the specific language governing permissions and | ||||||
// limitations under the License. | ||||||
//go:build !all | ||||||
// +build !all | ||||||
|
||||||
package main | ||||||
|
||||||
import ( | ||||||
"errors" | ||||||
"fmt" | ||||||
"reflect" | ||||||
|
||||||
"github.com/pulumi/pulumi/sdk/v3/go/pulumi" | ||||||
) | ||||||
|
||||||
type Random struct { | ||||||
pulumi.CustomResourceState | ||||||
|
||||||
Length pulumi.IntOutput `pulumi:"length"` | ||||||
Result pulumi.StringOutput `pulumi:"result"` | ||||||
} | ||||||
|
||||||
func NewRandom(ctx *pulumi.Context, | ||||||
name string, args *RandomArgs, opts ...pulumi.ResourceOption, | ||||||
) (*Random, error) { | ||||||
if args == nil || args.Length == nil { | ||||||
return nil, errors.New("missing required argument 'Length'") | ||||||
} | ||||||
var resource Random | ||||||
err := ctx.RegisterResource("testprovider:index:Random", name, args, &resource, opts...) | ||||||
if err != nil { | ||||||
return nil, err | ||||||
} | ||||||
return &resource, nil | ||||||
} | ||||||
|
||||||
type randomArgs struct { | ||||||
Length int `pulumi:"length"` | ||||||
Prefix string `pulumi:"prefix"` | ||||||
} | ||||||
|
||||||
type RandomArgs struct { | ||||||
Length pulumi.IntInput | ||||||
Prefix pulumi.StringInput | ||||||
} | ||||||
|
||||||
func (RandomArgs) ElementType() reflect.Type { | ||||||
return reflect.TypeOf((*randomArgs)(nil)).Elem() | ||||||
} | ||||||
|
||||||
type Component struct { | ||||||
pulumi.ResourceState | ||||||
|
||||||
ChildID pulumi.IDOutput `pulumi:"childId"` | ||||||
} | ||||||
|
||||||
type ComponentArgs struct { | ||||||
Length int `pulumi:"length"` | ||||||
} | ||||||
|
||||||
func NewComponent(ctx *pulumi.Context, name string, args *ComponentArgs, | ||||||
opts ...pulumi.ResourceOption, | ||||||
) (*Component, error) { | ||||||
if args == nil { | ||||||
return nil, errors.New("args is required") | ||||||
} | ||||||
|
||||||
component := &Component{} | ||||||
err := ctx.RegisterComponentResource("testprovider:index:Component", name, component, opts...) | ||||||
if err != nil { | ||||||
return nil, err | ||||||
} | ||||||
|
||||||
res, err := NewRandom(ctx, fmt.Sprintf("child-%s", name), &RandomArgs{ | ||||||
Length: pulumi.Int(args.Length), | ||||||
}, pulumi.Parent(component)) | ||||||
if err != nil { | ||||||
return nil, err | ||||||
} | ||||||
|
||||||
component.ChildID = res.ID() | ||||||
|
||||||
if err := ctx.RegisterResourceOutputs(component, pulumi.Map{ | ||||||
"childId": component.ChildID, | ||||||
}); err != nil { | ||||||
return nil, err | ||||||
} | ||||||
|
||||||
return component, nil | ||||||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should test provider be listed as a plugin here? Does program test add the plugins to the project for us?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeh program test adds it for us. We can't add it directly here because program test also copies the test code to a temp dir so a plain relative path doesn't work.