2018-05-09 18:08:10 -05:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/zclconf/go-cty/cty"
|
|
|
|
|
2021-05-17 14:00:50 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/addrs"
|
2021-05-17 14:17:09 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/configs/configschema"
|
2021-05-17 12:40:40 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/providers"
|
2021-05-17 12:51:48 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/provisioners"
|
2018-05-09 18:08:10 -05:00
|
|
|
)
|
|
|
|
|
2021-08-31 12:58:05 -05:00
|
|
|
// simpleMockPluginLibrary returns a plugin library pre-configured with
|
2018-05-09 18:08:10 -05:00
|
|
|
// one provider and one provisioner, both called "test".
|
|
|
|
//
|
|
|
|
// The provider is built with simpleMockProvider and the provisioner with
|
|
|
|
// simpleMockProvisioner, and all schemas used in both are as built by
|
|
|
|
// function simpleTestSchema.
|
|
|
|
//
|
|
|
|
// Each call to this function produces an entirely-separate set of objects,
|
|
|
|
// so the caller can feel free to modify the returned value to further
|
|
|
|
// customize the mocks contained within.
|
2021-08-31 12:58:05 -05:00
|
|
|
func simpleMockPluginLibrary() *contextPlugins {
|
2018-05-09 18:08:10 -05:00
|
|
|
// We create these out here, rather than in the factory functions below,
|
|
|
|
// because we want each call to the factory to return the _same_ instance,
|
|
|
|
// so that test code can customize it before passing this component
|
|
|
|
// factory into real code under test.
|
|
|
|
provider := simpleMockProvider()
|
|
|
|
provisioner := simpleMockProvisioner()
|
2021-08-31 12:58:05 -05:00
|
|
|
ret := &contextPlugins{
|
|
|
|
providerFactories: map[addrs.Provider]providers.Factory{
|
2020-04-01 12:13:40 -05:00
|
|
|
addrs.NewDefaultProvider("test"): func() (providers.Interface, error) {
|
2018-05-09 18:08:10 -05:00
|
|
|
return provider, nil
|
|
|
|
},
|
|
|
|
},
|
2021-08-31 12:58:05 -05:00
|
|
|
provisionerFactories: map[string]provisioners.Factory{
|
2018-08-17 14:32:35 -05:00
|
|
|
"test": func() (provisioners.Interface, error) {
|
2018-05-09 18:08:10 -05:00
|
|
|
return provisioner, nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2021-08-31 12:58:05 -05:00
|
|
|
ret.init() // prepare the internal cache data structures
|
|
|
|
return ret
|
2018-05-09 18:08:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// simpleTestSchema returns a block schema that contains a few optional
|
|
|
|
// attributes for use in tests.
|
|
|
|
//
|
|
|
|
// The returned schema contains the following optional attributes:
|
|
|
|
//
|
|
|
|
// test_string, of type string
|
|
|
|
// test_number, of type number
|
|
|
|
// test_bool, of type bool
|
|
|
|
// test_list, of type list(string)
|
|
|
|
// test_map, of type map(string)
|
|
|
|
//
|
|
|
|
// Each call to this function produces an entirely new schema instance, so
|
|
|
|
// callers can feel free to modify it once returned.
|
|
|
|
func simpleTestSchema() *configschema.Block {
|
|
|
|
return &configschema.Block{
|
|
|
|
Attributes: map[string]*configschema.Attribute{
|
|
|
|
"test_string": {
|
|
|
|
Type: cty.String,
|
|
|
|
Optional: true,
|
|
|
|
},
|
|
|
|
"test_number": {
|
2020-11-19 16:24:55 -06:00
|
|
|
Type: cty.Number,
|
2018-05-09 18:08:10 -05:00
|
|
|
Optional: true,
|
|
|
|
},
|
|
|
|
"test_bool": {
|
2020-11-20 09:44:37 -06:00
|
|
|
Type: cty.Bool,
|
2018-05-09 18:08:10 -05:00
|
|
|
Optional: true,
|
|
|
|
},
|
|
|
|
"test_list": {
|
2020-11-20 09:44:37 -06:00
|
|
|
Type: cty.List(cty.String),
|
2018-05-09 18:08:10 -05:00
|
|
|
Optional: true,
|
|
|
|
},
|
|
|
|
"test_map": {
|
2020-11-20 09:44:37 -06:00
|
|
|
Type: cty.Map(cty.String),
|
2018-05-09 18:08:10 -05:00
|
|
|
Optional: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|