mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-26 16:36:26 -06:00
84214437b3
This replaces this plugin system with the extracted hashicorp/go-plugin library. This doesn't introduce any new features such as binary flattening but opens us up to that a lot more easily and removes a lot of code from TF in favor of the upstream lib. This will introduce a protocol change that will cause all existing plugins to have to be recompiled to work properly. There is no actual API changes so they just have to recompile, but it is technically backwards incompatible.
194 lines
4.7 KiB
Go
194 lines
4.7 KiB
Go
package plugin
|
|
|
|
import (
|
|
"errors"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/go-plugin"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
func TestResourceProvisioner_impl(t *testing.T) {
|
|
var _ plugin.Plugin = new(ResourceProvisionerPlugin)
|
|
var _ terraform.ResourceProvisioner = new(ResourceProvisioner)
|
|
}
|
|
|
|
func TestResourceProvisioner_apply(t *testing.T) {
|
|
// Create a mock provider
|
|
p := new(terraform.MockResourceProvisioner)
|
|
client, _ := plugin.TestPluginRPCConn(t, pluginMap(&ServeOpts{
|
|
ProvisionerFunc: testProvisionerFixed(p),
|
|
}))
|
|
defer client.Close()
|
|
|
|
// Request the provider
|
|
raw, err := client.Dispense(ProvisionerPluginName)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
provisioner := raw.(terraform.ResourceProvisioner)
|
|
|
|
// Apply
|
|
output := &terraform.MockUIOutput{}
|
|
state := &terraform.InstanceState{}
|
|
conf := &terraform.ResourceConfig{}
|
|
err = provisioner.Apply(output, state, conf)
|
|
if !p.ApplyCalled {
|
|
t.Fatal("apply should be called")
|
|
}
|
|
if !reflect.DeepEqual(p.ApplyConfig, conf) {
|
|
t.Fatalf("bad: %#v", p.ApplyConfig)
|
|
}
|
|
if err != nil {
|
|
t.Fatalf("bad: %#v", err)
|
|
}
|
|
}
|
|
|
|
func TestResourceProvisioner_validate(t *testing.T) {
|
|
// Create a mock provider
|
|
p := new(terraform.MockResourceProvisioner)
|
|
client, _ := plugin.TestPluginRPCConn(t, pluginMap(&ServeOpts{
|
|
ProvisionerFunc: testProvisionerFixed(p),
|
|
}))
|
|
defer client.Close()
|
|
|
|
// Request the provider
|
|
raw, err := client.Dispense(ProvisionerPluginName)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
provisioner := raw.(terraform.ResourceProvisioner)
|
|
|
|
// Configure
|
|
config := &terraform.ResourceConfig{
|
|
Raw: map[string]interface{}{"foo": "bar"},
|
|
}
|
|
w, e := provisioner.Validate(config)
|
|
if !p.ValidateCalled {
|
|
t.Fatal("configure should be called")
|
|
}
|
|
if !reflect.DeepEqual(p.ValidateConfig, config) {
|
|
t.Fatalf("bad: %#v", p.ValidateConfig)
|
|
}
|
|
if w != nil {
|
|
t.Fatalf("bad: %#v", w)
|
|
}
|
|
if e != nil {
|
|
t.Fatalf("bad: %#v", e)
|
|
}
|
|
}
|
|
|
|
func TestResourceProvisioner_validate_errors(t *testing.T) {
|
|
// Create a mock provider
|
|
p := new(terraform.MockResourceProvisioner)
|
|
client, _ := plugin.TestPluginRPCConn(t, pluginMap(&ServeOpts{
|
|
ProvisionerFunc: testProvisionerFixed(p),
|
|
}))
|
|
defer client.Close()
|
|
|
|
// Request the provider
|
|
raw, err := client.Dispense(ProvisionerPluginName)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
provisioner := raw.(terraform.ResourceProvisioner)
|
|
|
|
p.ValidateReturnErrors = []error{errors.New("foo")}
|
|
|
|
// Configure
|
|
config := &terraform.ResourceConfig{
|
|
Raw: map[string]interface{}{"foo": "bar"},
|
|
}
|
|
w, e := provisioner.Validate(config)
|
|
if !p.ValidateCalled {
|
|
t.Fatal("configure should be called")
|
|
}
|
|
if !reflect.DeepEqual(p.ValidateConfig, config) {
|
|
t.Fatalf("bad: %#v", p.ValidateConfig)
|
|
}
|
|
if w != nil {
|
|
t.Fatalf("bad: %#v", w)
|
|
}
|
|
|
|
if len(e) != 1 {
|
|
t.Fatalf("bad: %#v", e)
|
|
}
|
|
if e[0].Error() != "foo" {
|
|
t.Fatalf("bad: %#v", e)
|
|
}
|
|
}
|
|
|
|
func TestResourceProvisioner_validate_warns(t *testing.T) {
|
|
// Create a mock provider
|
|
p := new(terraform.MockResourceProvisioner)
|
|
client, _ := plugin.TestPluginRPCConn(t, pluginMap(&ServeOpts{
|
|
ProvisionerFunc: testProvisionerFixed(p),
|
|
}))
|
|
defer client.Close()
|
|
|
|
// Request the provider
|
|
raw, err := client.Dispense(ProvisionerPluginName)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
provisioner := raw.(terraform.ResourceProvisioner)
|
|
|
|
p.ValidateReturnWarns = []string{"foo"}
|
|
|
|
// Configure
|
|
config := &terraform.ResourceConfig{
|
|
Raw: map[string]interface{}{"foo": "bar"},
|
|
}
|
|
w, e := provisioner.Validate(config)
|
|
if !p.ValidateCalled {
|
|
t.Fatal("configure should be called")
|
|
}
|
|
if !reflect.DeepEqual(p.ValidateConfig, config) {
|
|
t.Fatalf("bad: %#v", p.ValidateConfig)
|
|
}
|
|
if e != nil {
|
|
t.Fatalf("bad: %#v", e)
|
|
}
|
|
|
|
expected := []string{"foo"}
|
|
if !reflect.DeepEqual(w, expected) {
|
|
t.Fatalf("bad: %#v", w)
|
|
}
|
|
}
|
|
|
|
func TestResourceProvisioner_close(t *testing.T) {
|
|
// Create a mock provider
|
|
p := new(terraform.MockResourceProvisioner)
|
|
client, _ := plugin.TestPluginRPCConn(t, pluginMap(&ServeOpts{
|
|
ProvisionerFunc: testProvisionerFixed(p),
|
|
}))
|
|
defer client.Close()
|
|
|
|
// Request the provider
|
|
raw, err := client.Dispense(ProvisionerPluginName)
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
provisioner := raw.(terraform.ResourceProvisioner)
|
|
|
|
pCloser, ok := raw.(terraform.ResourceProvisionerCloser)
|
|
if !ok {
|
|
t.Fatal("should be a ResourceProvisionerCloser")
|
|
}
|
|
|
|
if err := pCloser.Close(); err != nil {
|
|
t.Fatalf("failed to close provisioner: %s", err)
|
|
}
|
|
|
|
// The connection should be closed now, so if we to make a
|
|
// new call we should get an error.
|
|
o := &terraform.MockUIOutput{}
|
|
s := &terraform.InstanceState{}
|
|
c := &terraform.ResourceConfig{}
|
|
err = provisioner.Apply(o, s, c)
|
|
if err == nil {
|
|
t.Fatal("should have error")
|
|
}
|
|
}
|