From f8f68bb038a79e3b2474eebac6080ad8ee6561a9 Mon Sep 17 00:00:00 2001 From: David Blane <32327139+dblane-digicatapult@users.noreply.github.com> Date: Mon, 9 Oct 2023 17:03:25 +0100 Subject: [PATCH] Revamped Helm chart (#29) 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 --- charts/configmanager/Chart.lock | 4 +- charts/configmanager/Chart.yaml | 6 +- charts/configmanager/README.md | 66 ++++++++++ charts/configmanager/templates/configmap.yaml | 23 ---- .../configmanager/templates/deployment.yaml | 87 +++++++++++--- charts/configmanager/templates/ingress.yaml | 35 ++++++ charts/configmanager/values.yaml | 113 +++++++++++++----- 7 files changed, 262 insertions(+), 72 deletions(-) create mode 100644 charts/configmanager/README.md delete mode 100644 charts/configmanager/templates/configmap.yaml create mode 100644 charts/configmanager/templates/ingress.yaml diff --git a/charts/configmanager/Chart.lock b/charts/configmanager/Chart.lock index 19b888c..a25a2da 100644 --- a/charts/configmanager/Chart.lock +++ b/charts/configmanager/Chart.lock @@ -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" diff --git a/charts/configmanager/Chart.yaml b/charts/configmanager/Chart.yaml index 0d26e42..80fffa0 100644 --- a/charts/configmanager/Chart.yaml +++ b/charts/configmanager/Chart.yaml @@ -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 diff --git a/charts/configmanager/README.md b/charts/configmanager/README.md new file mode 100644 index 0000000..b2c9f82 --- /dev/null +++ b/charts/configmanager/README.md @@ -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` | diff --git a/charts/configmanager/templates/configmap.yaml b/charts/configmanager/templates/configmap.yaml deleted file mode 100644 index 22610e8..0000000 --- a/charts/configmanager/templates/configmap.yaml +++ /dev/null @@ -1,23 +0,0 @@ -apiVersion: v1 -kind: ConfigMap -metadata: - name: {{ include "configmanager.fullname" . }}-config - labels: - {{- include "configmanager.labels" . | nindent 4 }} -data: - APP_DEBUG: {{ .Values.config.debug | quote }} - APP_LOG_LEVEL: {{ .Values.config.logLevel | quote }} - POSTGRES_HOST: {{ include "configmanager.postgresql.fullname" . }} - POSTGRES_DB: {{ .Values.postgresql.auth.database | quote }} - TAM_GUI_HOST: {{ .Values.config.guiHost | quote }} - TAM_GUI_PORT: {{ .Values.config.guiPort | quote }} - TAM_SUITE_MANAGER_HOST: {{ .Values.config.smaHost | quote }} - TAM_SUITE_MANAGER_PORT: {{ .Values.config.smaPort | quote }} - TAM_TEST_MANAGER_HOST: {{ .Values.config.tmaHost | quote }} - TAM_TEST_MANAGER_PORT: {{ .Values.config.tmaPort | quote }} - TAM_RESULTS_MANAGER_HOST: {{ .Values.config.rmaHost | quote }} - TAM_RESULTS_MANAGER_PORT: {{ .Values.config.rmaPort | quote }} - TAM_API_GATEWAY_HOST: {{ .Values.config.apgHost | quote }} - TAM_API_GATEWAY_PORT: {{ .Values.config.apgPort | quote }} - TAM_DEPLOY_MANAGER_HOST: {{ .Values.config.dmaHost | quote }} - TAM_DEPLOY_MANAGER_PORT: {{ .Values.config.dmaPort | quote }} diff --git a/charts/configmanager/templates/deployment.yaml b/charts/configmanager/templates/deployment.yaml index f93f108..3dd2d44 100644 --- a/charts/configmanager/templates/deployment.yaml +++ b/charts/configmanager/templates/deployment.yaml @@ -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 }} @@ -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 diff --git a/charts/configmanager/templates/ingress.yaml b/charts/configmanager/templates/ingress.yaml new file mode 100644 index 0000000..8a14ac5 --- /dev/null +++ b/charts/configmanager/templates/ingress.yaml @@ -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 }} diff --git a/charts/configmanager/values.yaml b/charts/configmanager/values.yaml index 6605f0e..78a750f 100644 --- a/charts/configmanager/values.yaml +++ b/charts/configmanager/values.yaml @@ -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