summaryrefslogtreecommitdiff
path: root/app/models/clusters/kubernetes_namespace.rb
diff options
context:
space:
mode:
authorDylan Griffith <dyl.griffith@gmail.com>2018-11-28 13:29:01 +0100
committerDylan Griffith <dyl.griffith@gmail.com>2018-11-30 11:03:42 +0100
commite7f2be49d812079e1521dd7479ce4e8007afbf43 (patch)
tree6c1b2f78eaf1903d403166d83f72bb48a4f166f2 /app/models/clusters/kubernetes_namespace.rb
parent817bb1905703f0ae63c3a877348b7b4bcc1136c6 (diff)
downloadgitlab-ce-e7f2be49d812079e1521dd7479ce4e8007afbf43.tar.gz
Make KUBECONFIG nil if KUBE_TOKEN is nil
Having an invalid KUBECONFIG without a token in it is not helpful. This only became possible recently now that we are creating a separate namespace and service account (and hence token) to send to the runners. This led to somewhat surprising results when troubleshooting https://gitlab.com/gitlab-org/gitlab-ce/issues/53879 as I found that the KUBECONFIG was still being passed but KUBE_TOKEN was not. These things really should have been linked. Furthermore now that we are also using the [presence of KUBECONFIG to decide whether or not to run build steps in Auto DevOps](https://gitlab.com/gitlab-org/gitlab-ce/blob/294d15be3e9497e7b67e1f9131ce9d5c0d68406c/lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml#L164) I think it makes even more sense to ensure that KUBECONFIG is a complete config if passed to a job.
Diffstat (limited to 'app/models/clusters/kubernetes_namespace.rb')
-rw-r--r--app/models/clusters/kubernetes_namespace.rb4
1 files changed, 1 insertions, 3 deletions
diff --git a/app/models/clusters/kubernetes_namespace.rb b/app/models/clusters/kubernetes_namespace.rb
index 34f5e38ff79..73da6cb37d7 100644
--- a/app/models/clusters/kubernetes_namespace.rb
+++ b/app/models/clusters/kubernetes_namespace.rb
@@ -33,14 +33,12 @@ module Clusters
end
def predefined_variables
- config = YAML.dump(kubeconfig)
-
Gitlab::Ci::Variables::Collection.new.tap do |variables|
variables
.append(key: 'KUBE_SERVICE_ACCOUNT', value: service_account_name.to_s)
.append(key: 'KUBE_NAMESPACE', value: namespace.to_s)
.append(key: 'KUBE_TOKEN', value: service_account_token.to_s, public: false)
- .append(key: 'KUBECONFIG', value: config, public: false, file: true)
+ .append(key: 'KUBECONFIG', value: kubeconfig, public: false, file: true)
end
end