Skip to content

Commit

Permalink
Revamped Helm chart (#29)
Browse files Browse the repository at this point in the history
Added:
Ingress for the configmanager
DB migration init container
README and helm chart values generated from values.yaml

Fixes:
Some labeling and annotations
Spurious use of configMap
  • Loading branch information
dblane-digicatapult authored Oct 9, 2023
1 parent 2f76d05 commit f8f68bb
Show file tree
Hide file tree
Showing 7 changed files with 262 additions and 72 deletions.
4 changes: 2 additions & 2 deletions charts/configmanager/Chart.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,5 @@ dependencies:
- name: postgresql
repository: https://charts.bitnami.com/bitnami
version: 12.12.10
digest: sha256:4db62ecf2a15647b9902b5b4267a12aed89733f98b071bbc3c4219f464bb8479
generated: "2023-09-27T13:40:07.430218+01:00"
digest: sha256:940cb5e45876deacafa82af06c585ece1cd95764c9507ef32d64c535ada13018
generated: "2023-10-06T17:48:06.36022+01:00"
6 changes: 3 additions & 3 deletions charts/configmanager/Chart.yaml
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
apiVersion: v2
name: configmanager
appVersion: 0.1.1
appVersion: 1.1.0
description: A generated Helm Chart for Soniclabs T&M configmanager
version: 0.0.6
version: 1.0.0
type: application
maintainers:
- name: cdecatapult
url: cdecatapult.github.io/soniclabs-helmcharts
dependencies:
- name: postgresql
version: '^12.1.14'
version: '^12.x.x'
repository: https://charts.bitnami.com/bitnami
condition: postgresql.enabled
66 changes: 66 additions & 0 deletions charts/configmanager/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
# ConfigManager

## Parameters

### ConfigManager Parameters

| Name | Description | Value |
| -------------------------- | ----------------------------------------------------------------------- | ---------------- |
| `config.replicaCount` | The amount of containers to run | `1` |
| `config.type` | The type of service to create | `LoadBalancer` |
| `config.appPort` | The port to expose the service and application on | `8000` |
| `config.nodePort` | The nodePort to use if the the service type is LoadBalancer or NodePort | `30342` |
| `config.commonAnnotations` | The annotations to set on the Config Manager application | `{}` |
| `config.debug` | Whether or not to enable debug mode for the application | `False` |
| `config.logLevel` | The log level to use for the application | `DEBUG` |
| `config.gui.host` | The hostname of the GUI service | `portal` |
| `config.gui.port` | The port of the GUI service | `8000` |
| `config.sma.host` | The hostname of the Suite Manager service | `suitemanager` |
| `config.sma.port` | The port of the Suite Manager service | `8000` |
| `config.tma.host` | The hostname of the Test Manager service | `testmanager` |
| `config.tma.port` | The port of the Test Manager service | `8000` |
| `config.rma.host` | The hostname of the Results Manager service | `resultsmanager` |
| `config.rma.port` | The port of the Results Manager service | `8000` |
| `config.apg.host` | The hostname of the API Gateway service | `apigateway` |
| `config.apg.port` | The port of the API Gateway service | `8000` |
| `config.dma.host` | The hostname of the Deploy Manager service | `deploymanager` |
| `config.dma.port` | The port of the Deploy Manager service | `8000` |

### ConfigManager Image Parameters

| Name | Description | Value |
| ------------------- | ---------------------------------------------------- | --------------------------------------------- |
| `image.repository` | The repository to use for the Config Manager image | `ghcr.io/cdecatapult/soniclabs-configmanager` |
| `image.pullPolicy` | The pull policy to use for the Config Manager image | `Always` |
| `image.tag` | The tag to use for the Config Manager image | `v1.1.0` |
| `image.pullSecrets` | The pull secrets to use for the Config Manager image | `["soniclabs"]` |

### ConfigManager Ingress parameters

| Name | Description | Value |
| --------------------------- | ------------------------------------------------------------------------ | --------------------- |
| `ingress.enabled` | Whether or not to enable the ingress for the Config Manager application | `true` |
| `ingress.annotations` | The annotations to set on the ingress for the Config Manager application | `{}` |
| `ingress.ingressClassName` | The ingress class to use for the Config Manager application | `""` |
| `ingress.hostname` | The hostname to use for the Config Manager application | `configmanager.local` |
| `ingress.paths` | The paths to use for the Config Manager application | |
| `ingress.paths[0].path` | The path to use for the Config Manager application | `/api/cma` |
| `ingress.paths[0].pathType` | The path type to use for the Config Manager application | `Prefix` |

### ConfigManager ServiceAccount parameters

| Name | Description | Value |
| ---------------------------- | ------------------------------------------------------------------------- | ------- |
| `serviceAccount.create` | Whether or not to create a service account for the Config Manager service | `false` |
| `serviceAccount.annotations` | The annotations to use for the Config Manager service account | `{}` |
| `serviceAccount.name` | The name of the service account to use for the Config Manager service | `""` |

### ConfigManager PostgreSQL parameters

| Name | Description | Value |
| --------------------------------------------- | ------------------------------------------------------------------------------- | --------------- |
| `postgresql.enabled` | Whether or not to enable the PostgreSQL SubChart for the Config Manager service | `true` |
| `postgresql.primary.service.ports.postgresql` | The port to expose the PostgreSQL database service on | `5432` |
| `postgresql.auth.username` | The username to use for the PostgreSQL database | `tamuser` |
| `postgresql.auth.password` | The password to use for the PostgreSQL database | `tampassword` |
| `postgresql.auth.database` | The name of the database to use for the PostgreSQL database | `configmanager` |
23 changes: 0 additions & 23 deletions charts/configmanager/templates/configmap.yaml

This file was deleted.

87 changes: 70 additions & 17 deletions charts/configmanager/templates/deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,35 @@ spec:
template:
metadata:
annotations:
checksum/config: {{ include (print $.Template.BasePath "/configmap.yaml") . | sha256sum }}
checksum/secret: {{ include (print $.Template.BasePath "/secrets.yaml") . | sha256sum }}
{{- if .Values.config.commonAnnotations }}
{{- toYaml .Values.config.commonAnnotations | nindent 6 }}
{{- end }}
labels:
{{- include "configmanager.labels" . | nindent 8 }}
spec:
{{- include "configmanager.imagePullSecrets" . | indent 6 }}
initContainers:
- name: {{ include "configmanager.fullname" . }}-init
- name: {{ include "configmanager.fullname" . }}-db-init
image: {{ template "configmanager.image" .Values.image }}
command: ['sleep', '60']
command: ['alembic', 'upgrade', 'head']
env:
- name: POSTGRES_HOST
value: {{ include "configmanager.postgresql.fullname" . }}
- name: POSTGRES_PORT
value: {{ .Values.postgresql.primary.service.ports.postgresql | quote }}
- name: POSTGRES_DB
value: {{ .Values.postgresql.auth.database | quote }}
- name: POSTGRES_USER
valueFrom:
secretKeyRef:
name: {{ include "configmanager.fullname" . }}-secret
key: POSTGRES_USER
- name: POSTGRES_PASSWORD
valueFrom:
secretKeyRef:
name: {{ include "configmanager.fullname" . }}-secret
key: POSTGRES_PASSWORD
containers:
- name: {{ include "configmanager.fullname" . }}-app
image: {{ template "configmanager.image" .Values.image }}
Expand All @@ -32,20 +51,54 @@ spec:
httpGet:
path: /api/cma/healthchecks/readiness
port: {{ .Values.config.appPort }}
initialDelaySeconds: 15
timeoutSeconds: 15
periodSeconds: 15
envFrom:
- configMapRef:
name: {{ include "configmanager.fullname" . }}-config
- secretRef:
name: {{ include "configmanager.fullname" . }}-secret
timeoutSeconds: 3
periodSeconds: 10
failureThreshold: 3
readinessProbe:
httpGet:
path: /api/cma/healthchecks/readiness
port: {{ .Values.config.appPort }}
timeoutSeconds: 3
periodSeconds: 10
failureThreshold: 3
env:
- name: HOST_IP
- name: APP_DEBUG
value: {{ .Values.config.debug | quote }}
- name: APP_LOG_LEVEL
value: {{ .Values.config.logLevel | quote }}
- name: POSTGRES_HOST
value: {{ include "configmanager.postgresql.fullname" . }}
- name: POSTGRES_PORT
value: {{ .Values.postgresql.primary.service.ports.postgresql | quote }}
- name: POSTGRES_DB
value: {{ .Values.postgresql.auth.database | quote }}
- name: TAM_GUI_HOST
value: {{ .Values.config.gui.host | quote }}
- name: TAM_GUI_PORT
value: {{ .Values.config.gui.port | quote }}
- name: TAM_SUITE_MANAGER_HOST
value: {{ .Values.config.sma.host | quote }}
- name: TAM_SUITE_MANAGER_PORT
value: {{ .Values.config.sma.port | quote }}
- name: TAM_TEST_MANAGER_HOST
value: {{ .Values.config.tma.host | quote }}
- name: TAM_TEST_MANAGER_PORT
value: {{ .Values.config.tma.port | quote }}
- name: TAM_RESULTS_MANAGER_HOST
value: {{ .Values.config.rma.host | quote }}
- name: TAM_RESULTS_MANAGER_PORT
value: {{ .Values.config.rma.port | quote }}
- name: TAM_DEPLOY_MANAGER_HOST
value: {{ .Values.config.dma.host | quote }}
- name: TAM_DEPLOY_MANAGER_PORT
value: {{ .Values.config.dma.port | quote }}
- name: POSTGRES_USER
valueFrom:
fieldRef:
fieldPath: status.hostIP
- name: POD_IP
secretKeyRef:
name: {{ include "configmanager.fullname" . }}-secret
key: POSTGRES_USER
- name: POSTGRES_PASSWORD
valueFrom:
fieldRef:
fieldPath: status.podIP
secretKeyRef:
name: {{ include "configmanager.fullname" . }}-secret
key: POSTGRES_PASSWORD
35 changes: 35 additions & 0 deletions charts/configmanager/templates/ingress.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
{{- if .Values.ingress.enabled }}
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: {{ include "configmanager.fullname" . }}-app
labels:
{{- include "configmanager.labels" . | nindent 4 }}
{{- if or .Values.ingress.annotations .Values.config.commonAnnotations }}
annotations:
{{- if .Values.ingress.annotations }}
{{- toYaml .Values.ingress.annotations | nindent 4 }}
{{- end }}
{{- if .Values.config.commonAnnotations }}
{{- toYaml .Values.config.commonAnnotations | nindent 4 }}
{{- end }}
{{- end }}
spec:
{{ if .Values.ingress.ingressClassName }}
ingressClassName: {{ .Values.ingress.ingressClassName | quote }}
{{ end }}
rules:
- host: {{ .Values.ingress.hostname }}
http:
paths:
{{- range .Values.ingress.paths }}
- path: {{ .path }}
pathType: {{ .pathType }}
{{- end }}
backend:
service:
name: {{ include "configmanager.fullname" . }}
port:
number: {{ $.Values.config.appPort }}
{{- end }}
113 changes: 86 additions & 27 deletions charts/configmanager/values.yaml
Original file line number Diff line number Diff line change
@@ -1,43 +1,102 @@
postgresql:
enabled: true
auth:
username: tamuser
password: tampassword
database: configmanager

## @section ConfigManager Parameters
##
config:
## @param config.replicaCount The amount of containers to run
replicaCount: 1
appPort: 8000
## @param config.type The type of service to create
type: LoadBalancer
## @param config.appPort The port to expose the service and application on
appPort: 8000
## @param config.nodePort The nodePort to use if the the service type is LoadBalancer or NodePort
nodePort: 30342
debug: "True"
## @param config.commonAnnotations The annotations to set on the Config Manager application
commonAnnotations: {}
## @param config.debug Whether or not to enable debug mode for the application
debug: "False"
## @param config.logLevel The log level to use for the application
logLevel: DEBUG
guiHost: portal
guiPort: 8000
smaHost: suitemanager
smaPort: 8000
tmaHost: testmanager
tmaPort: 8000
rmaHost: resultsmanager
rmaPort: 8000
apgHost: apigateway
apgPort: 8000
dmaHost: deploymanager
dmaPort: 8000
gui:
## @param config.gui.host The hostname of the GUI service
host: portal
## @param config.gui.port The port of the GUI service
port: 8000
sma:
## @param config.sma.host The hostname of the Suite Manager service
host: suitemanager
## @param config.sma.port The port of the Suite Manager service
port: 8000
tma:
## @param config.tma.host The hostname of the Test Manager service
host: testmanager
## @param config.tma.port The port of the Test Manager service
port: 8000
rma:
## @param config.rma.host The hostname of the Results Manager service
host: resultsmanager
## @param config.rma.port The port of the Results Manager service
port: 8000
apg:
## @param config.apg.host The hostname of the API Gateway service
host: apigateway
## @param config.apg.port The port of the API Gateway service
port: 8000
dma:
## @param config.dma.host The hostname of the Deploy Manager service
host: deploymanager
## @param config.dma.port The port of the Deploy Manager service
port: 8000

## @section ConfigManager Image Parameters
image:
## @param image.repository The repository to use for the Config Manager image
repository: ghcr.io/cdecatapult/soniclabs-configmanager
## @param image.pullPolicy The pull policy to use for the Config Manager image
pullPolicy: Always
tag: sha256:ee67c1d87d9f0c9b4438cf6d10d025f9995200c36cdccb7544cb77bf99f225b3
## @param image.tag The tag to use for the Config Manager image
tag: v1.1.0
## @param image.pullSecrets The pull secrets to use for the Config Manager image
pullSecrets: ['soniclabs']

autoscaling:
enabled: false
minReplicas: 1
maxReplicas: 100
targetCPUUtilizationPercentage: 80
## @section ConfigManager Ingress parameters
##
ingress:
## @param ingress.enabled Whether or not to enable the ingress for the Config Manager application
enabled: true
## @param ingress.annotations The annotations to set on the ingress for the Config Manager application
annotations: {}
## @param ingress.ingressClassName The ingress class to use for the Config Manager application
ingressClassName: ""
## @param ingress.hostname The hostname to use for the Config Manager application
hostname: configmanager.local
## @extra ingress.paths The paths to use for the Config Manager application
paths:
## @param ingress.paths[0].path The path to use for the Config Manager application
## @param ingress.paths[0].pathType The path type to use for the Config Manager application
- path: /api/cma
pathType: Prefix

## @section ConfigManager ServiceAccount parameters
serviceAccount:
## @param serviceAccount.create Whether or not to create a service account for the Config Manager service
create: false
## @param serviceAccount.annotations The annotations to use for the Config Manager service account
annotations: {}
## @param serviceAccount.name The name of the service account to use for the Config Manager service
name: ""

## @section ConfigManager PostgreSQL parameters
postgresql:
## @param postgresql.enabled Whether or not to enable the PostgreSQL SubChart for the Config Manager service
enabled: true
## @param postgresql.primary.service.ports.postgresql The port to expose the PostgreSQL database service on
primary:
service:
ports:
postgresql: 5432
auth:
## @param postgresql.auth.username The username to use for the PostgreSQL database
username: tamuser
## @param postgresql.auth.password The password to use for the PostgreSQL database
password: tampassword
## @param postgresql.auth.database The name of the database to use for the PostgreSQL database
database: configmanager

0 comments on commit f8f68bb

Please sign in to comment.