FEATURES
- Relaxed validation in
InternalValidate
for explicitly setid
attributes [GH-613] - Ported TypeSet test check funcs essential for migrating to V2 of the SDK [GH-614]
- Improved debug output for how to manually invoke the Terraform CLI [GH-615]
BUG FIXES
- Fix a bug that would pass the post-destroy state to
helper/resource.TestCase.CheckDestroy
instead of the documented pre-destroy state (#591) - Clean up the final remaining places where test numbers or dangling resources warnings could be omitted from errors (#578)
- Stop considering plans empty when they include data source changes (#594)
BUG FIXES
- Fixed a bug that would incorrectly mark tests using TestStep.ImportStateVerify as failed if they tested a resource with custom timeouts (#576)
- Fixed a bug where errors destroying infrastructure after tests wouldn't be reported (#581)
- Fixed a bug where test steps that expected a non-empty plan would fail because they had an empty plan, erroneously (#580)
- Fixed a bug where the plan output shown when an unexpected diff was encountered during testing would be shown in JSON instead of a human-readable format (#584)
BUG FIXES
- Fixed bug where state is read from the wrong workspace during import tests. (#552)
- Fixed bug where the resource could belong to another provider when finding the resource state to check during import tests (#522)
- Removed excessive logging when ExpectNonEmptyPlan was successfully matched (#556)
- Fixed bug where state from data sources, which can't be imported, would be surfaced during ImportStateVerify (#555)
- Fixed bug that ignored ExpectError when testing state imports (#550)
- Fixed bug that sometimes prevented TestStep numbers from appearing in error output (#557)
- Fixed bug that would ignore
TestStep.Destroy
when running tests. (#563)
BUG FIXES
- Restored reporting of failed test step number (#524)
- Restored output of a test that failed with unexpected diff to V1 style output (#526)
FEATURES
- Provide deprecated method for receiving a global context that receives stop cancellation. (#502)
- Support multiple providers in reattach mode (#512)
- Allow setting
ExternalProviders
inresource.TestCase
to control what providers are downloaded withterraform init
for a test. (#516) - Restore
resource.TestEnvVar
(#519)
BUG FIXES
- Remove deprecation warnings which cause spam and crashes in provider acceptance tests. (#503)
- Fixed a bug in the test driver that caused errors for Windows users on versions of Terraform below 0.13.0-beta2. (#499)
- Fixed a bug in the test driver that caused timeouts when using the
IDRefreshName
onresource.TestCase
s. (#501) - Fixed a bug where data sources would not always reflect changes in their configs in the same
resource.TestStep
that the config changed. (#515) - Fixed a bug that would prevent errors from being handled by ExpectError handlers during testing. (#518)
FEATURES
- The test driver was reworked to allow for test coverage, race detection, and debugger support. (#471)
- A new
plugin.Debug
function allows starting the provider in a standalone mode that's compatible with debuggers, and outputs information on how to drive the standalone provider with Terraform. (#471)
BREAKING CHANGES
- Removed the
helper/mutexkv
,helper/pathorcontents
,httpclient
, andhelper/hashcode
packages. These packages can be easily replicated in plugin code if necessary or the v1 versions can be used side-by-side (#438) - Removed
schema.PanicOnErr/TF_SCHEMA_PANIC_ON_ERR
environment variable.d.Set()
errors are now logged in production and panic during acceptance tests (TF_ACC=1
). (#462) - Running provider tests now requires Terraform 0.12.26 or higher. (#471)
- Removed
acctest
package, as it is no longer needed. The calls toacctest.UseBinaryDriver
can be deleted; they're no longer necessary. (#471) - The
resource.TestCase.Providers
andresource.TestCaseProviderFactories
maps must now have exactly one entry set between both of them, meaning one or the other should be used. Only the provider under test should be present in these maps. Providers that tests rely upon can be used by setting provider blocks in the test case, whereterraform init
will pick them up automatically. (#471) - The
TF_LOG_PATH_MASK
used to filter provider logs by test name when running tests has been removed. (#473)
ENHANCEMENTS
- Added a
schema.Provider.UserAgent
method to generate a User-Agent string (#474) - Convenience methods were added to the
diag
package to simplify common error cases (#449)
BUG FIXES
- Restored
d.Partial
and noted the edgecase it covers and odd Terraform behavior. (#472) - Provider log output now respects the
TF_LOG
andTF_LOG_PATH
environment variables when running tests. (#473)
BREAKING CHANGES
-
The SDK no longer supports protocol 4 (Terraform 0.11 and below). Providers built on the SDK after v2 will need Terraform 0.12 to be used.
-
The new, previously optional binary acceptance testing framework is now the default and only available mode for testing. Test code and provider code will no longer reside in the same process. Providers also will have their processes stopped and restarted multiple times during a test. This more accurately mirrors the behavior of providers in production.
-
Updated type signatures for some functions to include context.Context support. These include helpers in the helper/customdiff package, the CustomizeDiffFunc type, and the StateUpgradeFunc type. (#276)
-
The Partial and SetPartial methods on schema.ResourceData have been removed, as they were rarely necessary and poorly understood. (#318)
-
The terraform.ResourceProvider interface has been removed. The *schema.Provider type should be used directly, instead. (#316)
-
Deprecated helper/validation functions have been removed. (#333)
-
PromoteSingle’s use is discouraged, and so it has been removed from helper/schema.Schema. (#337)
-
schema.UnsafeSetFieldRaw’s use is discouraged, and so it has been removed. (#339)
-
Calls to schema.ResourceData.Set that would return an error now panic by default. TF_SCHEMA_PANIC_ON_ERROR can be set to a falsey value to disable this behavior.
-
schema.Resource.Refresh has been removed, as it is unused in protocol 5. (#370)
-
The Removed field has been removed from helper/schema.Schema, which means providers can no longer specify error messages when a recently removed field is used. This functionality had a lot of bugs and corner cases that worked in unexpected ways, and so was removed. (#414)
-
The helper/encryption package has been removed, following our published guidance. (#436)
-
In scenarios where the Go testing package was used, the github.com/mitchellh/go-testing-interface package may be required instead. (#406)
-
A number of exported variables, functions, types, and interfaces that were not meant to be part of the SDK’s interface have been removed. Most plugins should not notice they are gone.
The removals include:
- helper/acctest.RemoteTestPrecheck
- helper/acctest.SkipRemoteTestsEnvVar
- helper/resource.EnvLogPathMask
- helper/resource.GRPCTestProvider
- helper/resource.LogOutput
- helper/resource.Map
- helper/resource.TestEnvVar
- helper/resource.TestProvider
- helper/schema.MultiMapReader
- helper/schema.Provider.Input
- plugin.Client
- plugin.ClientConfig
- plugin.DefaultProtocolVersion
- plugin.GRPCProvider
- plugin.GRPCProviderPlugin
- plugin.GRPCProvisioner
- plugin.GRPCProvisionerPlugin
- plugin.HandShake.ProtocolVersion
- plugin.ResourceProvider
- plugin.ResourceProviderApplyArgs
- plugin.ResourceProviderApplyResponse
- plugin.ResourceProviderConfigureResponse
- plugin.ResourceProviderDiffArgs
- plugin.ResourceProviderDiffResponse
- plugin.ResourceProviderGetSchemaArgs
- plugin.ResourceProviderGetSchemaResponse
- plugin.ResourceProviderImportStateArgs
- plugin.ResourceProviderImportStateResponse
- plugin.ResourceProviderInputArgs
- plugin.ResourceProviderInputResponse
- plugin.ResourceProviderPlugin
- plugin.ResourceProviderReadDataApplyArgs
- plugin.ResourceProviderReadDataApplyResponse
- plugin.ResourceProviderReadDataDiffArgs
- plugin.ResourceProviderReadDataDiffResponse
- plugin.ResourceProviderRefreshArgs
- plugin.ResourceProviderRefreshResponse
- plugin.ResourceProviderServer
- plugin.ResourceProviderStopResponse
- plugin.ResourceProviderValidateArgs
- plugin.ResourceProviderValidateResourceArgs
- plugin.ResourceProviderValidateResourceResponse
- plugin.ResourceProviderValidateResponse
- plugin.UIInput
- plugin.UIInputInputResponse
- plugin.UIInputServer
- plugin.UIOutput
- plugin.UIOutputServer
- plugin.VersionedPlugins no longer has a "provisioner" key
- resource.RunNewTest
- schema.Backend
- schema.FromContextBackendConfig
- schema.SetProto5
- terraform.ApplyGraphBuilder
- terraform.AttachResourceConfigTransformer
- terraform.AttachSchemaTransformer
- terraform.AttachStateTransformer
- terraform.BackendState.Config
- terraform.BackendState.Empty
- terraform.BackendState.ForPlan
- terraform.BackendState.SetConfig
- terraform.BasicGraphBuilder
- terraform.BuiltinEvalContext
- terraform.CallbackUIOutput
- terraform.CBDEdgeTransformer
- terraform.CheckCoreVersionRequirements
- terraform.CloseProviderEvalTree
- terraform.CloseProviderTransformer
- terraform.CloseProvisionerTransformer
- terraform.ConcreteProviderNodeFunc
- terraform.ConcreteResourceInstanceDeposedNodeFunc
- terraform.ConcreteResourceInstanceNodeFunc
- terraform.ConcreteResourceNodeFunc
- terraform.ConfigTransformer
- terraform.ConfigTreeDependencies
- terraform.ConnectionBlockSupersetSchema
- terraform.Context
- terraform.ContextGraphOpts
- terraform.ContextGraphWalker
- terraform.ContextMeta
- terraform.ContextOpts
- terraform.CountBoundaryTransformer
- terraform.DefaultVariableValues
- terraform.DestroyEdge
- terraform.DestroyEdgeTransformer
- terraform.DestroyOutputTransformer
- terraform.DestroyPlanGraphBuilder
- terraform.DestroyValueReferenceTransformer
- terraform.Diff (this was eventually cut)
- terraform.Diff.ModuleByPath
- terraform.Diff.RootModule
- terraform.DiffAttrInput
- terraform.DiffAttrOutput
- terraform.DiffAttrType
- terraform.DiffAttrUnknown
- terraform.DiffChangeType
- terraform.DiffCreate
- terraform.DiffDestroy
- terraform.DiffDestroyCreate
- terraform.DiffInvalid
- terraform.DiffNone
- terraform.DiffRefresh
- terraform.DiffTransformer
- terraform.DiffUpdate
- terraform.EphemeralState.DeepCopy
- terraform.ErrNoState
- terraform.Eval
- terraform.EvalApply
- terraform.EvalApplyPost
- terraform.EvalApplyPre
- terraform.EvalApplyProvisioners
- terraform.EvalCheckModuleRemoved
- terraform.EvalCheckPlannedChange
- terraform.EvalCheckPreventDestroy
- terraform.EvalCloseProvider
- terraform.EvalCloseProvisioner
- terraform.EvalConfigBlock
- terraform.EvalConfigExpr
- terraform.EvalConfigProvider
- terraform.EvalContext
- terraform.EvalCountFixZeroOneBoundaryGlobal
- terraform.EvalDataForInstanceKey
- terraform.EvalDataForNoInstanceKey
- terraform.EvalDeleteLocal
- terraform.EvalDeleteOutput
- terraform.EvalDeposeState
- terraform.EvalDiff
- terraform.EvalDiffDestroy
- terraform.EvalEarlyExitError
- terraform.EvalFilter
- terraform.EvalForgetResourceState
- terraform.EvalGetProvider
- terraform.EvalGetProvisioner
- terraform.EvalGraphBuilder
- terraform.EvalIf
- terraform.EvalImportState
- terraform.EvalImportStateVerify
- terraform.EvalInitProvider
- terraform.EvalInitProvisioner
- terraform.EvalLocal
- terraform.EvalMaybeRestoreDeposedObject
- terraform.EvalMaybeTainted
- terraform.EvalModuleCallArgument
- terraform.EvalNode
- terraform.EvalNodeFilterable
- terraform.EvalNodeFilterFunc
- terraform.EvalNodeFilterOp
- terraform.EvalNodeOpFilterable
- terraform.EvalNoop
- terraform.EvalOpFilter
- terraform.EvalRaw
- terraform.EvalReadData
- terraform.EvalReadDataApply
- terraform.EvalReadDiff
- terraform.EvalReadState
- terraform.EvalReadStateDeposed
- terraform.EvalReduceDiff
- terraform.EvalRefresh
- terraform.EvalRequireState
- terraform.EvalReturnError
- terraform.EvalSequence
- terraform.EvalSetModuleCallArguments
- terraform.Evaluator
- terraform.EvalUpdateStateHook
- terraform.EvalValidateCount
- terraform.EvalValidateProvider
- terraform.EvalValidateProvisioner
- terraform.EvalValidateResource
- terraform.EvalValidateSelfRef
- terraform.EvalWriteDiff
- terraform.EvalWriteOutput
- terraform.EvalWriteResourceState
- terraform.EvalWriteState
- terraform.EvalWriteStateDeposed
- terraform.ExpandTransform
- terraform.ForcedCBDTransformer
- terraform.Graph
- terraform.GraphBuilder
- terraform.GraphDot
- terraform.GraphNodeAttachDestroyer
- terraform.GraphNodeAttachProvider
- terraform.GraphNodeAttachProviderConfigSchema
- terraform.GraphNodeAttachProvisionerSchema
- terraform.GraphNodeAttachResourceConfig
- terraform.GraphNodeAttachResourceSchema
- terraform.GraphNodeAttachResourceState
- terraform.GraphNodeCloseProvider
- terraform.GraphNodeCloseProvisioner
- terraform.GraphNodeCreator
- terraform.GraphNodeDeposedResourceInstanceObject
- terraform.GraphNodeDeposer
- terraform.GraphNodeDestroyer
- terraform.GraphNodeDestroyerCBD
- terraform.GraphNodeDynamicExpandable
- terraform.GraphNodeEvalable
- terraform.GraphNodeExpandable
- terraform.GraphNodeProvider
- terraform.GraphNodeProviderConsumer
- terraform.GraphNodeProvisioner
- terraform.GraphNodeProvisionerConsumer
- terraform.GraphNodeReferenceable
- terraform.GraphNodeReferenceOutside
- terraform.GraphNodeReferencer
- terraform.GraphNodeResource
- terraform.GraphNodeResourceInstance
- terraform.GraphNodeSubgraph
- terraform.GraphNodeSubPath
- terraform.GraphNodeTargetable
- terraform.GraphNodeTargetDownstream
- terraform.GraphTransformer
- terraform.GraphTransformIf
- terraform.GraphTransformMulti
- terraform.GraphType
- terraform.GraphTypeApply
- terraform.GraphTypeEval
- terraform.GraphTypeInvalid
- terraform.GraphTypeLegacy
- terraform.GraphTypeMap
- terraform.GraphTypePlan
- terraform.GraphTypePlanDestroy
- terraform.GraphTypeRefresh
- terraform.GraphTypeValidate
- terraform.GraphVertexTransformer
- terraform.GraphWalker
- terraform.Hook
- terraform.HookAction
- terraform.HookActionContinue
- terraform.HookActionHalt
- terraform.ImportGraphBuilder
- terraform.ImportOpts
- terraform.ImportProviderValidateTransformer
- terraform.ImportStateTransformer
- terraform.ImportTarget
- terraform.InputMode
- terraform.InputModeProvider
- terraform.InputModeStd
- terraform.InputModeVar
- terraform.InputModeVarUnset
- terraform.InputOpts
- terraform.InputValue
- terraform.InputValues
- terraform.InputValuesFromCaller
- terraform.InstanceDiff.Copy
- terraform.InstanceDiff.DelAttribute
- terraform.InstanceDiff.GetAttributesLen
- terraform.InstanceDiff.SetAttribute
- terraform.InstanceDiff.SetDestroy
- terraform.InstanceDiff.SetDestroyDeposed
- terraform.InstanceDiff.SetTainted
- terraform.InstanceInfo.ResourceAddress
- terraform.InstanceKeyEvalData
- terraform.InstanceType
- terraform.LoadSchemas
- terraform.LocalTransformer
- terraform.MissingProviderTransformer
- terraform.MissingProvisionerTransformer
- terraform.MockEvalContext
- terraform.MockHook
- terraform.MockProvider
- terraform.MockProvisioner
- terraform.MockResourceProvider (this was removed)
- terraform.MockResourceProvider.Input
- terraform.MockResourceProvider.InputCalled
- terraform.MockResourceProvider.InputConfig
- terraform.MockResourceProvider.InputFn
- terraform.MockResourceProvider.InputInput
- terraform.MockResourceProvider.InputReturnConfig
- terraform.MockResourceProvider.InputReturnError
- terraform.MockResourceProvisioner
- terraform.MockUIInput
- terraform.MockUIOutput
- terraform.ModuleDiff (this was eventually cut)
- terraform.ModuleDiff.IsRoot
- terraform.ModuleState.Empty
- terraform.ModuleState.IsDescendent
- terraform.ModuleState.IsRoot
- terraform.ModuleState.Orphans
- terraform.ModuleState.RemovedOutputs
- terraform.ModuleState.View
- terraform.ModuleVariableTransformer
- terraform.MustShimLegacyState
- terraform.NewContext
- terraform.NewInstanceInfo
- terraform.NewLegacyResourceAddress
- terraform.NewLegacyResourceInstanceAddress
- terraform.NewNodeAbstractResource
- terraform.NewNodeAbstractResourceInstance
- terraform.NewReferenceMap
- terraform.NewResource
- terraform.NewSemaphore
- terraform.NilHook
- terraform.NodeAbstractProvider
- terraform.NodeAbstractResource
- terraform.NodeAbstractResourceInstance
- terraform.NodeApplyableModuleVariable
- terraform.NodeApplyableOutput
- terraform.NodeApplyableProvider
- terraform.NodeApplyableResource
- terraform.NodeApplyableResourceInstance
- terraform.NodeCountBoundary
- terraform.NodeDestroyableDataResourceInstance
- terraform.NodeDestroyableOutput
- terraform.NodeDestroyDeposedResourceInstanceObject
- terraform.NodeDestroyResource
- terraform.NodeDestroyResourceInstance
- terraform.NodeDisabledProvider
- terraform.NodeEvalableProvider
- terraform.NodeLocal
- terraform.NodeModuleRemoved
- terraform.NodeOutputOrphan
- terraform.NodePlanDeposedResourceInstanceObject
- terraform.NodePlanDestroyableResourceInstance
- terraform.NodePlannableResource
- terraform.NodePlannableResourceInstance
- terraform.NodePlannableResourceInstanceOrphan
- terraform.NodeProvisioner
- terraform.NodeRefreshableDataResource
- terraform.NodeRefreshableDataResourceInstance
- terraform.NodeRefreshableManagedResource
- terraform.NodeRefreshableManagedResourceInstance
- terraform.NodeRootVariable
- terraform.NodeValidatableResource
- terraform.NullGraphWalker
- terraform.OrphanOutputTransformer
- terraform.OrphanResourceCountTransformer
- terraform.OrphanResourceInstanceTransformer
- terraform.OrphanResourceTransformer
- terraform.OutputTransformer
- terraform.ParentProviderTransformer
- terraform.ParseInstanceType
- terraform.ParseResourceAddress
- terraform.ParseResourceAddressForInstanceDiff
- terraform.ParseResourceIndex
- terraform.ParseResourcePath
- terraform.ParseResourceStateKey
- terraform.PathObjectCacheKey
- terraform.Plan
- terraform.PlanGraphBuilder
- terraform.PrefixUIInput
- terraform.ProviderConfigTransformer
- terraform.ProviderEvalTree
- terraform.ProviderHasDataSource
- terraform.ProviderHasResource
- terraform.ProviderSchema.SchemaForResourceAddr
- terraform.ProviderSchema.SchemaForResourceType
- terraform.ProviderTransformer
- terraform.ProvisionerFactory
- terraform.ProvisionerTransformer
- terraform.ProvisionerUIOutput
- terraform.PruneProviderTransformer
- terraform.PruneUnusedValuesTransformer
- terraform.ReadPlan
- terraform.ReadState
- terraform.ReadStateV1
- terraform.ReadStateV2
- terraform.ReadStateV3
- terraform.ReferenceMap
- terraform.ReferencesFromConfig
- terraform.ReferenceTransformer
- terraform.RefreshGraphBuilder
- terraform.RemoteState.Equals
- terraform.RemovableIfNotTargeted
- terraform.RemovedModuleTransformer
- terraform.Resource
- terraform.ResourceAddress
- terraform.ResourceAttrDiff.Empty
- terraform.ResourceConfig.CheckSet
- terraform.ResourceConfig.IsSet
- terraform.ResourceCountTransformer
- terraform.ResourceFlag
- terraform.ResourceProviderCloser (this was removed)
- terraform.ResourceProviderFactoryFixed (this was removed)
- terraform.ResourceProviderResolver
- terraform.ResourceProviderResolverFixed
- terraform.ResourceProviderResolverFunc
- terraform.ResourceProvisioner
- terraform.ResourceProvisionerCloser
- terraform.ResourceProvisionerFactory
- terraform.RootTransformer
- terraform.RootVariableTransformer
- terraform.Schemas
- terraform.Semaphore
- terraform.ShimLegacyState
- terraform.State.FromFutureTerraform
- terraform.State.MarshalEqual
- terraform.StateFilter
- terraform.StateFilterResult
- terraform.StateFilterResultSlice
- terraform.StateTransformer
- terraform.StateVersion
- terraform.TargetsTransformer
- terraform.TestStateFile
- terraform.TransformProviders
- terraform.TransitiveReductionTransformer
- terraform.TypeDeposed
- terraform.TypeInvalid
- terraform.TypePrimary
- terraform.TypeTainted
- terraform.UIInput
- terraform.UIOutput
- terraform.UpgradeResourceState
- terraform.ValidateGraphBuilder
- terraform.ValueFromAutoFile
- terraform.ValueFromCaller
- terraform.ValueFromCLIArg
- terraform.ValueFromConfig
- terraform.ValueFromEnvVar
- terraform.ValueFromInput
- terraform.ValueFromNamedFile
- terraform.ValueFromPlan
- terraform.ValueFromUnknown
- terraform.ValueSourceType
- terraform.VertexTransformer
- terraform.WritePlan
- terraform.WriteState
FEATURES
- Many functions in the SDK now have support for context.Context, including CreateContextFunc, ReadContextFunc, UpdateContextFunc, and DeleteContextFunc, analogs to the existing CreateFunc, ReadFunc, UpdateFunc, and DeleteFuncs. This offers more accurate cancellation and timeouts. (#276)
- Many functions in the SDK now return a new diag.Diagnostics type, like the new CreateContextFunc, ReadContextFunc, UpdateContextFunc, DeleteContextFunc, and a new ValidateDiagFunc. When using these Diagnostics, Terraform will now indicate more precisely-scoped errors, and providers now have the ability to display warnings.
- A new feature, provider metadata, is shipping as part of Terraform 0.13. This feature allows module authors to give information to providers without the information being persisted to state, which is useful for indicating metadata about modules. This is experimental new functionality and its usage should be closely coordinated with the Terraform core team to ensure that limitations are understood. See the PR in Terraform core for more information. (#405)
DEPRECATIONS
- The ExistsFunc defined on a schema.Resource is now deprecated. This logic can be achieved in the ReadFunc for that schema.Resource instead, and often was duplicated unnecessarily.
- Functions that got context- or diagnostics-aware counterparts--like CreateFunc, ReadFunc, UpdateFunc, DeleteFunc, and ValidateFunc--are now deprecated in favor of their context- and/or diagnostics-aware counterparts.
ENHANCEMENTS
- A number of new map validators that take advantage of the Diagnostics support have been added. (#304)
- schema.Resource and schema.Schema now have optional Description fields, which will surface information for user-facing interfaces for the provider. These fields can hold plain text or markdown, depending on the global DescriptionKind setting. (#349)
BUG FIXES
- helper/acctest.RandIntRange will now correctly return an integer between min and max; previously, it would return an integer between 0 and max-min. (#300)
- NonRetryableError and RetryableError will now throw an explicit error if they’re given a nil error. Before unspecified and confusing behavior would arise. (#199)
- TypeSet hash values are no longer collapsed into a single value when they consist only of Computed attributes. (#197)
- Computed attributes now have stronger validation around what properties can be set on their schema.Schema. (#336)
- Using a schema.Resource as the Elem on a TypeMap now returns an error; previously, unspecified and confusing behavior was exhibited. (#338)
- Using TestCheckResourceAttrPair to compare the same attribute on the same resource will now throw an error. (#335)
- Test sweeping will now error if a dependency sweeper is specified but doesn’t exist. (#398)
For information on v1.x releases, please see the v1 branch changelog.