-
Notifications
You must be signed in to change notification settings - Fork 1k
Description
With the release of Kubernetes Provider 2.0, we began requiring explicit provider configuration with the intention of preventing the wrong clusters from being targeted during apply. However, in our implementation of this, we have introduced a new bug scenario where the provider silently chooses an authentication method when more than one is supplied in the provider config. This issue was already present to some extent, but in the past it could be partially mitigated with load_config_file = false
. Now that load_config_file
is no longer an option, the issue has become more prominent.
We can solve this in the provider code by adding ConflictsWith
to mutually-exclusive configuation options, to give users complete control over which options are being chosen to authenticate to their Kubernetetes cluster. This will throw an error when two or more conflicting options are used together.
NOTE: This change will result in configuration errors when mutually-exclusive configuration options are specified.
The configuration errors have been silent since the 2.0 release, but with this proposed change, the error will become explicit, notifying the user of the conflicting options, and failing to run the provider until a single valid configuration is chosen.
Terraform Version, Provider Version and Kubernetes Version
Terraform version:
0.14.4
Kubernetes provider version:
2.0.2
Affected Resource(s)
Provider config block.
Terraform Configuration Files
The provider currently chooses KUBE_CONFIG_PATH
over the explicit configuration. This is one of the bug scenarios that will be corrected.
export KUBE_CONFIG_PATH="~/.kube/config"
provider "kubernetes" {
host = data.aws_eks_cluster.default.endpoint
cluster_ca_certificate = base64decode(data.aws_eks_cluster.default.certificate_authority[0].data)
token = data.aws_eks_cluster_auth.default.token
Debug Output
Panic Output
Steps to Reproduce
terraform plan
using the configuration options above (though you'll have to specify a resource too, to initialize the provider).
Expected Behavior
I think we should throw an error instead, and let the user choose which configuration they would like to use.
Actual Behavior
The provider silently chooses one of the given configurations. Sometimes this leads to the wrong cluster being targeted, which is what we were aiming to fix with issue #909.
Important Factoids
References
Adding more explicit configuration settings (ConflictsWith) should help solve the following issues, which have arisen since the 2.0 release.
Community Note
- Please vote on this issue by adding a 👍 reaction to the original issue to help the community and maintainers prioritize this request
- If you are interested in working on this issue or have submitted a pull request, please leave a comment