2021-09-09 13:33:07 -05:00
|
|
|
# Releasing a New Version of the Protocol
|
|
|
|
|
2023-08-22 04:38:28 -05:00
|
|
|
OpenTF's plugin protocol is the contract between OpenTF's plugins and
|
|
|
|
OpenTF, and as such releasing a new version requires some coordination
|
2021-09-09 13:33:07 -05:00
|
|
|
between those pieces. This document is intended to be a checklist to consult
|
|
|
|
when adding a new major version of the protocol (X in X.Y) to ensure that
|
|
|
|
everything that needs to be is aware of it.
|
|
|
|
|
|
|
|
## New Protobuf File
|
|
|
|
|
2023-08-22 07:28:30 -05:00
|
|
|
The protocol is defined in protobuf files that live in the opentffoundation/opentf
|
2021-09-09 13:33:07 -05:00
|
|
|
repository. Adding a new version of the protocol involves creating a new
|
|
|
|
`.proto` file in that directory. It is recommended that you copy the latest
|
|
|
|
protocol file, and modify it accordingly.
|
|
|
|
|
|
|
|
## New terraform-plugin-go Package
|
|
|
|
|
|
|
|
The
|
|
|
|
[hashicorp/terraform-plugin-go](https://github.com/hashicorp/terraform-plugin-go)
|
2023-08-22 04:38:28 -05:00
|
|
|
repository serves as the foundation for OpenTF's plugin ecosystem. It needs
|
2021-09-09 13:33:07 -05:00
|
|
|
to know about the new major protocol version. Either open an issue in that repo
|
|
|
|
to have the Plugin SDK team add the new package, or if you would like to
|
|
|
|
contribute it yourself, open a PR. It is recommended that you copy the package
|
|
|
|
for the latest protocol version and modify it accordingly.
|
|
|
|
|
|
|
|
## Update the Registry's List of Allowed Versions
|
|
|
|
|
2023-08-22 04:38:28 -05:00
|
|
|
The OpenTF Registry validates the protocol versions a provider advertises
|
2021-09-09 13:33:07 -05:00
|
|
|
support for when ingesting providers. Providers will not be able to advertise
|
|
|
|
support for the new protocol version until it is added to that list.
|
|
|
|
|
2023-08-22 04:38:28 -05:00
|
|
|
## Update OpenTF's Version Constraints
|
2021-09-09 13:33:07 -05:00
|
|
|
|
2023-08-22 04:38:28 -05:00
|
|
|
OpenTF only downloads providers that speak protocol versions it is
|
2023-08-22 07:28:30 -05:00
|
|
|
compatible with from the Registry during `opentf init`. When adding support
|
2023-08-22 04:38:28 -05:00
|
|
|
for a new protocol, you need to tell OpenTF it knows that protocol version.
|
2023-08-22 07:28:30 -05:00
|
|
|
Modify the `SupportedPluginProtocols` variable in opentffoundation/opentf's
|
2021-09-09 13:33:07 -05:00
|
|
|
`internal/getproviders/registry_client.go` file to include the new protocol.
|
|
|
|
|
|
|
|
## Test Running a Provider With the Test Framework
|
|
|
|
|
|
|
|
Use the provider test framework to test a provider written with the new
|
|
|
|
protocol. This end-to-end test ensures that providers written with the new
|
2021-12-26 23:29:02 -06:00
|
|
|
protocol work correctly with the test framework, especially in communicating
|
2023-08-22 04:38:28 -05:00
|
|
|
the protocol version between the test framework and OpenTF.
|
2021-09-09 13:33:07 -05:00
|
|
|
|
|
|
|
## Test Retrieving and Running a Provider From the Registry
|
|
|
|
|
|
|
|
Publish a provider, either to the public registry or to the staging registry,
|
2023-08-22 07:28:30 -05:00
|
|
|
and test running `opentf init` and `opentf apply`, along with exercising
|
2021-09-09 13:33:07 -05:00
|
|
|
any of the new functionality the protocol version introduces. This end-to-end
|
|
|
|
test ensures that all the pieces needing to be updated before practitioners can
|
|
|
|
use providers built with the new protocol have been updated.
|