2840259fb8
This adds support for executing helm tests via the armada test directive. It enables theses tests for all services, except for nova and neutron as executing tests with armada force a chart to wait. Forcing nova and neutron to wait effectively sequences the charts, which will result in a failure to deploy past those services Depends-On: https://review.openstack.org/#/c/581148 Change-Id: I6ac845c82d744e2f5fd79c3e2ff3c1479dd1ddab
102 lines
3.9 KiB
YAML
102 lines
3.9 KiB
YAML
{{/*
|
|
Copyright 2017 The Openstack-Helm Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/}}
|
|
|
|
{{- if .Values.manifests.pod_rally_test }}
|
|
{{- $envAll := . }}
|
|
|
|
{{- $mounts_tests := .Values.pod.mounts.glance_tests.glance_tests }}
|
|
{{- $mounts_tests_init := .Values.pod.mounts.glance_tests.init_container }}
|
|
|
|
{{- $serviceAccountName := print $envAll.Release.Name "-test" }}
|
|
{{ tuple $envAll "tests" $serviceAccountName | include "helm-toolkit.snippets.kubernetes_pod_rbac_serviceaccount" }}
|
|
---
|
|
apiVersion: v1
|
|
kind: Pod
|
|
metadata:
|
|
name: {{ print $envAll.Release.Name "-test" }}
|
|
labels:
|
|
{{ tuple $envAll "glance" "test" | include "helm-toolkit.snippets.kubernetes_metadata_labels" | indent 4 }}
|
|
annotations:
|
|
"helm.sh/hook": test-success
|
|
spec:
|
|
nodeSelector:
|
|
{{ .Values.labels.test.node_selector_key }}: {{ .Values.labels.test.node_selector_value }}
|
|
restartPolicy: Never
|
|
serviceAccountName: {{ $serviceAccountName }}
|
|
initContainers:
|
|
{{ tuple $envAll "tests" $mounts_tests_init | include "helm-toolkit.snippets.kubernetes_entrypoint_init_container" | indent 4 }}
|
|
- name: {{ .Release.Name }}-test-ks-user
|
|
{{ tuple $envAll "ks_user" | include "helm-toolkit.snippets.image" | indent 6 }}
|
|
{{ tuple $envAll $envAll.Values.pod.resources.jobs.ks_user | include "helm-toolkit.snippets.kubernetes_resources" | indent 6 }}
|
|
command:
|
|
- /tmp/ks-user.sh
|
|
volumeMounts:
|
|
- name: glance-bin
|
|
mountPath: /tmp/ks-user.sh
|
|
subPath: ks-user.sh
|
|
readOnly: true
|
|
env:
|
|
{{- with $env := dict "ksUserSecret" .Values.secrets.identity.admin }}
|
|
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 8 }}
|
|
{{- end }}
|
|
- name: SERVICE_OS_SERVICE_NAME
|
|
value: "test"
|
|
{{- with $env := dict "ksUserSecret" .Values.secrets.identity.test }}
|
|
{{- include "helm-toolkit.snippets.keystone_user_create_env_vars" $env | indent 8 }}
|
|
{{- end }}
|
|
- name: SERVICE_OS_ROLE
|
|
value: {{ .Values.endpoints.identity.auth.test.role | quote }}
|
|
containers:
|
|
- name: {{ .Release.Name }}-test
|
|
{{ tuple $envAll "test" | include "helm-toolkit.snippets.image" | indent 6 }}
|
|
{{ tuple $envAll $envAll.Values.pod.resources.jobs.tests | include "helm-toolkit.snippets.kubernetes_resources" | indent 6 }}
|
|
env:
|
|
{{- with $env := dict "ksUserSecret" .Values.secrets.identity.admin }}
|
|
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 8 }}
|
|
{{- end }}
|
|
{{- with $env := dict "ksUserSecret" .Values.secrets.identity.test }}
|
|
{{- include "helm-toolkit.snippets.keystone_user_create_env_vars" $env | indent 8 }}
|
|
{{- end }}
|
|
- name: RALLY_ENV_NAME
|
|
value: {{.Release.Name}}
|
|
command:
|
|
- /tmp/rally-test.sh
|
|
volumeMounts:
|
|
- name: glance-etc
|
|
mountPath: /etc/rally/rally_tests.yaml
|
|
subPath: rally_tests.yaml
|
|
readOnly: true
|
|
- name: glance-bin
|
|
mountPath: /tmp/rally-test.sh
|
|
subPath: rally-test.sh
|
|
readOnly: true
|
|
- name: rally-db
|
|
mountPath: /var/lib/rally
|
|
{{ if $mounts_tests.volumeMounts }}{{ toYaml $mounts_tests.volumeMounts | indent 8 }}{{ end }}
|
|
volumes:
|
|
- name: glance-etc
|
|
configMap:
|
|
name: glance-etc
|
|
defaultMode: 0444
|
|
- name: glance-bin
|
|
configMap:
|
|
name: glance-bin
|
|
defaultMode: 0555
|
|
- name: rally-db
|
|
emptyDir: {}
|
|
{{ if $mounts_tests.volumes }}{{ toYaml $mounts_tests.volumes | indent 4 }}{{ end }}
|
|
{{- end }}
|