Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

release chart #1646

Merged
merged 9 commits into from
Oct 19, 2023
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion charts/controller/Chart.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
apiVersion: v2
name: controller
version: 0.18.1
version: 0.18.2
description: Iter8 controller controller
type: application
keywords:
Expand Down
2 changes: 1 addition & 1 deletion charts/controller/templates/roles.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ rules:
{{- end }}
- apiGroups: ["{{- $type.Group -}}"]
resources: ["{{- $type.Resource -}}"]
verbs: ["get", "list", "watch", "patch", "update"]
verbs: ["get", "list", "watch", "patch", "update", "create"]
{{- end }}
- apiGroups: [""]
resources: ["events"]
Expand Down
26 changes: 26 additions & 0 deletions charts/release/.helmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
# Patterns to ignore when building packages.
# This supports shell glob matching, relative path matching, and
# negation (prefixed with !). Only one pattern per line.
.DS_Store
# Common VCS dirs
.git/
.gitignore
.bzr/
.bzrignore
.hg/
.hgignore
.svn/
# Common backup files
*.swp
*.bak
*.tmp
*.orig
*~
# Various IDEs
.project
.idea/
*.tmproj
.vscode/

# generated files need to be ignored
experiment.yaml
21 changes: 21 additions & 0 deletions charts/release/Chart.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
apiVersion: v2
name: release
version: 0.18.1
description: Iter8 supported application release
type: application
keywords:
- Iter8
- traffic
- blue-green
- canary
- mirroring
home: https://iter8.tools
sources:
- https://github.com/iter8-tools/iter8
maintainers:
- name: Michael Kalantar
email: [email protected]
- name: Iter8
email: [email protected]
icon: https://github.com/iter8-tools/iter8/raw/master/mkdocs/docs/images/favicon.png
appVersion: v0.18
12 changes: 12 additions & 0 deletions charts/release/templates/_configmap.weight-config.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{{- define "configmap.weight-config" }}
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ .VERSION_NAME }}-weight-config
labels:
iter8.tools/watch: "true"
{{- if .weight }}
annotations:
iter8.tools/weight: "{{ .weight }}"
{{- end }} {{- /* if .weight */}}
{{- end }} {{- /* define "configmap.weight-config" */}}
77 changes: 77 additions & 0 deletions charts/release/templates/_deployment-istio.blue-green.routemap.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
{{- define "env.deployment-istio.blue-green.routemap" }}

{{- $APP_NAME := (include "application.name" .) }}
{{- $APP_NAMESPACE := (include "application.namespace" .) }}
{{- $versions := include "normalize.versions.deployment" . | mustFromJson }}

apiVersion: v1
kind: ConfigMap
{{- template "routemap.metadata" . }}
data:
strSpec: |
versions:
{{- range $i, $v := $versions }}
- resources:
- gvrShort: svc
name: {{ template "svc.name" $v}}
namespace: {{ template "svc.namespace" $v}}
- gvrShort: deploy
name: {{ template "deploy.name" $v}}
namespace: {{ template "deploy.namespace" $v}}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
- gvrShort: cm
name: {{ $v.VERSION_NAME }}-weight-config
namespace: {{ $v.VERSION_NAMESPACE }}
weight: {{ $v.weight }}
{{- end }} {{- /* range $i, $v := $versions */}}
routingTemplates:
{{ .Values.application.strategy }}:
gvrShort: vs
template: |
apiVersion: networking.istio.io/v1beta1
kind: VirtualService
metadata:
name: {{ $APP_NAME }}
namespace: {{ $APP_NAMESPACE }}
spec:
gateways:
{{- if .Values.gateway }}
- {{ .Values.gateway }}
{{- end }}
- mesh
hosts:
- {{ $APP_NAME }}.{{ $APP_NAMESPACE }}
- {{ $APP_NAME }}.{{ $APP_NAMESPACE }}.svc
- {{ $APP_NAME }}.{{ $APP_NAMESPACE }}.svc.cluster.local
http:
- name: {{ $APP_NAME }}
route:
# primary version
{{- $v := (index $versions 0) }}
- destination:
host: {{ template "svc.name" $v}}.{{ $APP_NAMESPACE }}.svc.cluster.local
kalantar marked this conversation as resolved.
Show resolved Hide resolved
port:
number: {{ $v.port }}
{{- if gt (len $versions) 1 }}
{{ `{{- if gt (index .Weights 1) 0 }}` }}
weight: {{ `{{ index .Weights 0 }}` }}
{{ `{{- end }}`}}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
{{- end }}
headers:
response:
add:
app-version: {{ template "svc.name" $v}}
# other versions
{{- range $i, $v := (rest $versions) }}
{{ `{{- if gt (index .Weights ` }}{{ print (add1 $i) }}{{ `) 0 }}`}}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
- destination:
host: {{ template "svc.name" $v}}.{{ $APP_NAMESPACE }}.svc.cluster.local
port:
number: {{ $v.port }}
weight: {{ `{{ index .Weights `}}{{ print (add1 $i) }}{{` }}`}}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
headers:
response:
add:
app-version: {{ template "svc.name" $v}}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
{{ `{{- end }}`}}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
{{- end }}
{{- end }} {{- /* define "env.deployment-istio.blue-green.routemap" */}}
15 changes: 15 additions & 0 deletions charts/release/templates/_deployment-istio.blue-green.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{{- define "env.deployment-istio.blue-green" }}

{{- /* prepare versions for simpler processing */}}
{{- $versions := include "normalize.versions.deployment" . | mustFromJson }}

{{- /* weight-config ConfigMaps */}}
{{- range $i, $v := $versions }}
{{ include "configmap.weight-config" $v }}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
---
{{- end }} {{- /* range $i, $v := $versions */}}

{{- /* routemap */}}
{{ include "env.deployment-istio.blue-green.routemap" . }}

{{- end }} {{- /* define "env.deployment-istio.blue-green" */}}
25 changes: 25 additions & 0 deletions charts/release/templates/_deployment-istio.canary.routemap.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
{{- define "env.deployment-istio.canary.routemap" }}

{{- $APP_NAME := (include "application.name" .) }}
{{- $APP_NAMESPACE := (include "application.namespace" .) }}
{{- $versions := include "normalize.versions.deployment" . | mustFromJson }}

apiVersion: v1
kind: ConfigMap
{{- template "routemap.metadata" . }}
data:
strSpec: |
versions:
{{- range $i, $v := $versions }}
- resources:
- gvrShort: svc
name: {{ template "svc.name" $v}}
namespace: {{ template "svc.namespace" $v}}
- gvrShort: deploy
name: {{ template "deploy.name" $v}}
namespace: {{ template "deploy.namespace" $v}}
{{- end }}

TBD: _deployment-istio.canary.routemap.tpl
kalantar marked this conversation as resolved.
Show resolved Hide resolved

{{- end }} {{- /* define "env.deployment-istio.canary.routemap" */}}
6 changes: 6 additions & 0 deletions charts/release/templates/_deployment-istio.canary.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
{{- define "env.deployment-istio.canary" }}

{{- /* routemap */}}
{{ include "env.deployment-istio.canary.routemap" . }}

{{- end }} {{- /* define "env.deployment-istio.canary" */}}
21 changes: 21 additions & 0 deletions charts/release/templates/_deployment-istio.none.routemap.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{{- define "env.deployment-istio.none.routemap" }}

{{- $versions := include "normalize.versions.deployment" . | mustFromJson }}

apiVersion: v1
kind: ConfigMap
{{- template "routemap.metadata" . }}
data:
strSpec: |
versions:
{{- range $i, $v := $versions }}
- resources:
- gvrShort: svc
name: {{ template "svc.name" $v}}
namespace: {{ template "svc.namespace" $v}}
- gvrShort: deploy
name: {{ template "deploy.name" $v}}
namespace: {{ template "deploy.namespace" $v}}
{{- end }}

{{- end }} {{- /* define "env.deployment-istio.none.routemap" */}}
6 changes: 6 additions & 0 deletions charts/release/templates/_deployment-istio.none.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
{{- define "env.deployment-istio.none" }}

{{- /* routemap */}}
{{ include "env.deployment-istio.none.routemap" . }}

{{- end }} {{- /* define "env.deployment-istio.none" */}}
15 changes: 15 additions & 0 deletions charts/release/templates/_deployment-istio.service.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{{- define "env.deployment-istio.service" }}

{{- $APP_NAME := (include "application.name" .) }}
{{- $APP_NAMESPACE := (include "application.namespace" .) }}

apiVersion: v1
kind: Service
metadata:
name: {{ $APP_NAME }}
namespace: {{ $APP_NAMESPACE }}
spec:
externalName: istio-ingressgateway.istio-system.svc.cluster.local
sessionAffinity: None
type: ExternalName
{{- end }} {{- /* define "env.deployment-istio.service" */}}
30 changes: 30 additions & 0 deletions charts/release/templates/_deployment-istio.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
{{- define "env.deployment-istio" }}

{{- /* Prepare versions for simpler processing */}}
{{- $versions := include "normalize.versions.deployment" . | mustFromJson }}

{{- range $i, $v := $versions }}
{{- /* Deployment */}}
{{ include "env.deployment.version.deployment" $v }}
---
{{- /* Service */}}
{{ include "env.deployment.version.service" $v }}
---
{{- end }} {{- /* range $i, $v := $versions */}}

{{- /* Service */}}
{{ include "env.deployment-istio.service" . }}
---

{{- /* routemap (and other strategy specific objects) */}}
{{- if not .Values.application.strategy }}
{{ include "env.deployment-istio.none" . }}
{{- else if eq "none" .Values.application.strategy }}
{{ include "env.deployment-istio.none" . }}
{{- else if eq "blue-green" .Values.application.strategy }}
{{ include "env.deployment-istio.blue-green" . }}
{{- else if eq "canary" .Values.application.strategy }}
{{ include "env.deployment-istio.canary" . }}
{{- end }} {{- /* if eq ... .Values.application.strategy */}}

{{- end }} {{- /* define "env.deployment-istio" */}}
25 changes: 25 additions & 0 deletions charts/release/templates/_deployment.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
{{- define "env.deployment" }}

{{- /* Prepare versions for simpler processing */}}
{{- $versions := include "normalize.versions.deployment" . | mustFromJson }}

{{- range $i, $v := $versions }}

{{- /* Deployment */}}
{{ include "env.deployment.version.deployment" $v }}
---
{{- /* Service */}}
{{ include "env.deployment.version.service" $v }}
---
{{- end }} {{- /* range $i, $v := $versions */}}

{{- /* routemap (and other strategy specific objects) */}}
{{- if not .Values.application.strategy }}
{{ include "env.deployment-istio.none" . }}
{{- else if eq "none" .Values.application.strategy }}
{{ include "env.deployment-istio.none" . }}
{{- else }}
{{- printf "unknown or invalid application strategy (%s) for environment (%s)" .Values.application.strategy .Values.environment | fail }}
kalantar marked this conversation as resolved.
Show resolved Hide resolved
{{- end }} {{- /* if eq ... .Values.application.strategy */}}

{{- end }} {{- /* define "env.deployment" */}}
42 changes: 42 additions & 0 deletions charts/release/templates/_deployment.version.deployment.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
{{- define "env.deployment.version.deployment" }}

{{- /* compute basic metadata */}}
{{- $metadata := include "application.version.metadata" . | mustFromJson }}

apiVersion: apps/v1
kind: Deployment
{{- if .deploymentSpecification }}
metadata:
{{- if .deploymentSpecification.metadata }}
{{ toYaml (merge .deploymentSpecification.metadata $metadata) | nindent 2 | trim }}
{{- else }}
{{ toYaml $metadata | nindent 2 | trim }}
{{- end }} {{- /* if .deploymentSpecification.metadata */}}
spec:
{{ toYaml .deploymentSpecification.spec | nindent 2 | trim }}
{{- else }}
{{- if not .image }} {{- /* require .image */}}
{{- print "missing field: image required when deploymentSpecification absent" | fail }}
{{- end }} {{- /* if not .image */}}
{{- if not .port }} {{- /* require .port */}}
{{- print "missing field: port required when deploymentSpecification absent" | fail }}
{{- end }} {{- /* if not .port */}}
metadata:
{{ toYaml $metadata | nindent 2 | trim }}
spec:
selector:
matchLabels:
app: {{ .VERSION_NAME }}
template:
metadata:
labels:
app: {{ .VERSION_NAME }}
spec:
containers:
- name: {{ .VERSION_NAME }}
image: {{ .image }}
ports:
- containerPort: {{ .port }}
{{- end }} {{- /* if .deploymentSpecification */}}

{{- end }} {{- /* define "env.deployment.version.deployment" */}}
29 changes: 29 additions & 0 deletions charts/release/templates/_deployment.version.service.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
{{- define "env.deployment.version.service" }}

{{- /* compute basic metadata */}}
{{- $metadata := include "application.version.metadata" . | mustFromJson }}

apiVersion: v1
kind: Service
{{- if .serviceSpecification }}
metadata:
{{- if .serviceSpecification.metadata }}
{{ toYaml (merge .serviceSpecification.metadata $metadata) | nindent 2 | trim }}
{{- else }}
{{ toYaml $metadata | nindent 2 | trim }}
{{- end }} {{- /* if .serviceSpecification.metadata */}}
spec:
{{ toYaml .serviceSpecification.spec | nindent 2 | trim }}
{{- else }}
{{- if not .port }} {{- /* require .port */}}
{{- print "missing field: port required when serviceSpecification absent" | fail }}
{{- end }} {{- /* if not .port */}}
metadata:
{{ toYaml $metadata | nindent 2 | trim }}
spec:
selector:
app: {{ .VERSION_NAME }}
ports:
- port: {{ .port }}
{{- end }} {{- /* if .serviceSpecification */}}
{{- end }} {{- /* define "env.deployment.version.service" */}}
Loading