From 38e41e12c9f696667acf1ec5c560283205c99ff7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Reinhard=20N=C3=A4gele?= Date: Wed, 18 Sep 2019 13:24:03 +0200 Subject: [PATCH] ref(*): Improve and fix scaffold chart and API versions (#6426) * Use `apps/v1` for Deployment * Reformat comments * Consistently use `nindent` and indent properly * Introduce named template for selector labels * Fix label selector in `NOTES.txt` Signed-off-by: Reinhard Naegele --- ...te-chart-with-template-lib-archive-dep.txt | 2 +- .../template-chart-with-template-lib-dep.txt | 2 +- .../templates/deployment.yaml | 2 +- .../templates/deployment.yaml | 2 +- .../templates/deployment.yaml | 2 +- pkg/chartutil/create.go | 62 ++++++++++--------- 6 files changed, 38 insertions(+), 34 deletions(-) diff --git a/cmd/helm/testdata/output/template-chart-with-template-lib-archive-dep.txt b/cmd/helm/testdata/output/template-chart-with-template-lib-archive-dep.txt index 23a0b984c..dc1aa2907 100644 --- a/cmd/helm/testdata/output/template-chart-with-template-lib-archive-dep.txt +++ b/cmd/helm/testdata/output/template-chart-with-template-lib-archive-dep.txt @@ -20,7 +20,7 @@ spec: type: ClusterIP --- # Source: chart-with-template-lib-archive-dep/templates/deployment.yaml -apiVersion: apps/v1beta2 +apiVersion: apps/v1 kind: Deployment metadata: name: RELEASE-NAME-chart-with-template-lib-archive-dep diff --git a/cmd/helm/testdata/output/template-chart-with-template-lib-dep.txt b/cmd/helm/testdata/output/template-chart-with-template-lib-dep.txt index 33147a73e..12adeb28b 100644 --- a/cmd/helm/testdata/output/template-chart-with-template-lib-dep.txt +++ b/cmd/helm/testdata/output/template-chart-with-template-lib-dep.txt @@ -20,7 +20,7 @@ spec: type: ClusterIP --- # Source: chart-with-template-lib-dep/templates/deployment.yaml -apiVersion: apps/v1beta2 +apiVersion: apps/v1 kind: Deployment metadata: name: RELEASE-NAME-chart-with-template-lib-dep diff --git a/cmd/helm/testdata/testcharts/chart-with-lib-dep/templates/deployment.yaml b/cmd/helm/testdata/testcharts/chart-with-lib-dep/templates/deployment.yaml index 18b4f8718..521fa5972 100644 --- a/cmd/helm/testdata/testcharts/chart-with-lib-dep/templates/deployment.yaml +++ b/cmd/helm/testdata/testcharts/chart-with-lib-dep/templates/deployment.yaml @@ -1,4 +1,4 @@ -apiVersion: apps/v1beta2 +apiVersion: apps/v1 kind: Deployment metadata: name: {{ template "chart-with-lib-dep.fullname" . }} diff --git a/cmd/helm/testdata/testcharts/chart-with-template-lib-archive-dep/templates/deployment.yaml b/cmd/helm/testdata/testcharts/chart-with-template-lib-archive-dep/templates/deployment.yaml index 6120e7def..a49572f4a 100644 --- a/cmd/helm/testdata/testcharts/chart-with-template-lib-archive-dep/templates/deployment.yaml +++ b/cmd/helm/testdata/testcharts/chart-with-template-lib-archive-dep/templates/deployment.yaml @@ -1,4 +1,4 @@ -apiVersion: apps/v1beta2 +apiVersion: apps/v1 kind: Deployment metadata: name: {{ template "chart-with-template-lib-archive-dep.fullname" . }} diff --git a/cmd/helm/testdata/testcharts/chart-with-template-lib-dep/templates/deployment.yaml b/cmd/helm/testdata/testcharts/chart-with-template-lib-dep/templates/deployment.yaml index c447579d0..6b950d139 100644 --- a/cmd/helm/testdata/testcharts/chart-with-template-lib-dep/templates/deployment.yaml +++ b/cmd/helm/testdata/testcharts/chart-with-template-lib-dep/templates/deployment.yaml @@ -1,4 +1,4 @@ -apiVersion: apps/v1beta2 +apiVersion: apps/v1 kind: Deployment metadata: name: {{ template "chart-with-template-lib-dep.fullname" . }} diff --git a/pkg/chartutil/create.go b/pkg/chartutil/create.go index ed4da83d4..3afc3cc63 100644 --- a/pkg/chartutil/create.go +++ b/pkg/chartutil/create.go @@ -105,9 +105,9 @@ ingress: paths: [] tls: [] - # - secretName: chart-example-tls - # hosts: - # - chart-example.local + # - secretName: chart-example-tls + # hosts: + # - chart-example.local resources: {} # We usually recommend not to specify default resources and to leave this as a conscious @@ -115,11 +115,11 @@ resources: {} # resources, such as Minikube. If you do want to specify resources, uncomment the following # lines, adjust them as necessary, and remove the curly braces after 'resources:'. # limits: - # cpu: 100m - # memory: 128Mi + # cpu: 100m + # memory: 128Mi # requests: - # cpu: 100m - # memory: 128Mi + # cpu: 100m + # memory: 128Mi nodeSelector: {} @@ -159,7 +159,7 @@ kind: Ingress metadata: name: {{ $fullName }} labels: -{{ include ".labels" . | indent 4 }} + {{- include ".labels" . | nindent 4 }} {{- with .Values.ingress.annotations }} annotations: {{- toYaml . | nindent 4 }} @@ -190,23 +190,21 @@ spec: {{- end }} ` -const defaultDeployment = `apiVersion: apps/v1beta2 +const defaultDeployment = `apiVersion: apps/v1 kind: Deployment metadata: - name: {{ template ".fullname" . }} + name: {{ include ".fullname" . }} labels: -{{ include ".labels" . | indent 4 }} + {{- include ".labels" . | nindent 4 }} spec: replicas: {{ .Values.replicaCount }} selector: matchLabels: - app.kubernetes.io/name: {{ include ".name" . }} - app.kubernetes.io/instance: {{ .Release.Name }} + {{- include ".selectorLabels" . | nindent 6 }} template: metadata: labels: - app.kubernetes.io/name: {{ include ".name" . }} - app.kubernetes.io/instance: {{ .Release.Name }} + {{- include ".selectorLabels" . | nindent 8 }} spec: containers: - name: {{ .Chart.Name }} @@ -225,27 +223,27 @@ spec: path: / port: http resources: -{{ toYaml .Values.resources | indent 12 }} + {{- toYaml .Values.resources | nindent 12 }} {{- with .Values.nodeSelector }} nodeSelector: -{{ toYaml . | indent 8 }} + {{- toYaml . | nindent 8 }} {{- end }} {{- with .Values.affinity }} affinity: -{{ toYaml . | indent 8 }} + {{- toYaml . | nindent 8 }} {{- end }} {{- with .Values.tolerations }} tolerations: -{{ toYaml . | indent 8 }} + {{- toYaml . | nindent 8 }} {{- end }} ` const defaultService = `apiVersion: v1 kind: Service metadata: - name: {{ template ".fullname" . }} + name: {{ include ".fullname" . }} labels: -{{ include ".labels" . | indent 4 }} + {{- include ".labels" . | nindent 4 }} spec: type: {{ .Values.service.type }} ports: @@ -254,8 +252,7 @@ spec: protocol: TCP name: http selector: - app.kubernetes.io/name: {{ include ".name" . }} - app.kubernetes.io/instance: {{ .Release.Name }} + {{- include ".selectorLabels" . | nindent 4 }} ` const defaultNotes = `1. Get the application URL by running these commands: @@ -266,16 +263,16 @@ const defaultNotes = `1. Get the application URL by running these commands: {{- end }} {{- end }} {{- else if contains "NodePort" .Values.service.type }} - export NODE_PORT=$(kubectl get -o jsonpath="{.spec.ports[0].nodePort}" services {{ template ".fullname" . }}) + export NODE_PORT=$(kubectl get -o jsonpath="{.spec.ports[0].nodePort}" services {{ include ".fullname" . }}) export NODE_IP=$(kubectl get nodes -o jsonpath="{.items[0].status.addresses[0].address}") echo http://$NODE_IP:$NODE_PORT {{- else if contains "LoadBalancer" .Values.service.type }} NOTE: It may take a few minutes for the LoadBalancer IP to be available. - You can watch the status of by running 'kubectl get svc -w {{ template ".fullname" . }}' - export SERVICE_IP=$(kubectl get svc {{ template ".fullname" . }} -o jsonpath='{.status.loadBalancer.ingress[0].ip}') + You can watch the status of by running 'kubectl get svc -w {{ include ".fullname" . }}' + export SERVICE_IP=$(kubectl get svc {{ include ".fullname" . }} -o jsonpath='{.status.loadBalancer.ingress[0].ip}') echo http://$SERVICE_IP:{{ .Values.service.port }} {{- else if contains "ClusterIP" .Values.service.type }} - export POD_NAME=$(kubectl get pods -l "app={{ template ".name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") + export POD_NAME=$(kubectl get pods -l "app.kubernetes.io/name={{ include ".name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") echo "Visit http://127.0.0.1:8080 to use your application" kubectl port-forward $POD_NAME 8080:80 {{- end }} @@ -318,14 +315,21 @@ Create chart name and version as used by the chart label. Common labels */}} {{- define ".labels" -}} -app.kubernetes.io/name: {{ include ".name" . }} helm.sh/chart: {{ include ".chart" . }} -app.kubernetes.io/instance: {{ .Release.Name }} +{{ include ".selectorLabels" . }} {{- if .Chart.AppVersion }} app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} {{- end }} app.kubernetes.io/managed-by: {{ .Release.Service }} {{- end -}} + +{{/* +Selector labels +*/}} +{{- define ".selectorLabels" -}} +app.kubernetes.io/name: {{ include ".name" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end -}} ` // CreateFrom creates a new chart, but scaffolds it from the src chart.