You've already forked helm-actions
							
							 5b19636034
			
		
	
	5b19636034
	
	
		
			
	
		
	
	_This is the first time I ever messed with helm and is an experiment to show what prevents the tests to pass and how far it still depends on the gitea chart_ ### Description of the change - Deletes a single test that seems to depend directly on gitea - make all tests pass - Moves all value accesses from `actions` one level up - Copies content of the gitea chart required by the existing test - Reveals all dependencies that needs to be decoupled - Fixes readme generation - add package.json - copy dependent readme section from helm-gitea - Removes all dependencies - giteaRootURL is now required to be provided - consistency check that this value has been provided - added test for consistency failure - nc command no longer uses an hardcoded dns name and is checked in tests - added test - Copied yamllint from helm-gitea - added pnpm lock file exclusion - Installed pnpm in the workflow - Updated make unittest command in CI to unittest-helm ### Benefits The existing tests are passing ### Possible drawbacks The provision job might still not work. ### Applicable issues - Fixes #5 ### Additional information The following usage should now deploy ```yaml existingSecret: "somesecret" existingSecretKey: "key" ## Specify the root URL of the Gitea instance giteaRootURL: "http://somedomain:3000" ``` ### ⚠ BREAKING - giteaRootURL is now required to be provided - Moves all value accesses from `actions` one level up - The values.yml had this change without updating tests / dev Readme Reviewed-on: https://gitea.com/gitea/helm-actions/pulls/6 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: justusbunsi <justusbunsi@noreply.gitea.com> Reviewed-by: volker.raschek <markus.pesch@web.de> Co-authored-by: Christopher Homberger <christopher.homberger@web.de> Co-committed-by: Christopher Homberger <christopher.homberger@web.de>
		
			
				
	
	
		
			116 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| {{- if .Values.enabled }}
 | |
| {{- if and (and .Values.provisioning.enabled .Values.persistence.enabled) .Values.persistence.mount }}
 | |
| {{- $name := include "gitea.workername" (dict "global" . "worker" "actions-token-job") }}
 | |
| {{- $secretName := include "gitea.workername" (dict "global" . "worker" "actions-token") }}
 | |
| ---
 | |
| apiVersion: batch/v1
 | |
| kind: Job
 | |
| metadata:
 | |
|   name: {{ $name }}
 | |
|   namespace: {{ .Values.namespace | default .Release.Namespace }}
 | |
|   labels:
 | |
|     {{- include "gitea.labels" . | nindent 4 }}
 | |
|     {{- with .Values.provisioning.labels }}
 | |
|     {{- toYaml . | nindent 4 }}
 | |
|     {{- end }}
 | |
|     app.kubernetes.io/component: token-job
 | |
|   annotations:
 | |
|     {{- with .Values.provisioning.annotations }}
 | |
|     {{- toYaml . | nindent 4 }}
 | |
|     {{- end }}
 | |
| spec:
 | |
|   ttlSecondsAfterFinished: {{ .Values.provisioning.ttlSecondsAfterFinished }}
 | |
|   template:
 | |
|     metadata:
 | |
|       labels:
 | |
|         {{- include "gitea.labels" . | nindent 8 }}
 | |
|         {{- with .Values.provisioning.labels }}
 | |
|         {{- toYaml . | nindent 8 }}
 | |
|         {{- end }}
 | |
|         app.kubernetes.io/component: token-job
 | |
|     spec:
 | |
|       initContainers:
 | |
|         - name: init-gitea
 | |
|           image: "{{ .Values.init.image.repository }}:{{ .Values.init.image.tag }}"
 | |
|           command:
 | |
|             - sh
 | |
|             - -c
 | |
|             - |
 | |
|               while ! nc -z {{ include "gitea.act_runner.nc" . }}; do
 | |
|                 sleep 5
 | |
|               done
 | |
|       containers:
 | |
|         - name: actions-token-create
 | |
|           image: "{{ include "gitea.image" . }}"
 | |
|           imagePullPolicy: {{ .Values.image.pullPolicy }}
 | |
|           env:
 | |
|             - name: GITEA_APP_INI
 | |
|               value: /data/gitea/conf/app.ini
 | |
|           command:
 | |
|             - sh
 | |
|             - -c
 | |
|             - |
 | |
|               echo "Generating act_runner token via 'gitea actions generate-runner-token'..."
 | |
|               mkdir -p /data/actions/
 | |
|               gitea actions generate-runner-token | grep -E '^.{40}$' | tr -d '\n' > /data/actions/token
 | |
|           resources:
 | |
|             {{- toYaml .Values.provisioning.resources | nindent 12 }}
 | |
|           volumeMounts:
 | |
|             - name: data
 | |
|               mountPath: /data
 | |
|               {{- if .Values.persistence.subPath }}
 | |
|               subPath: {{ .Values.persistence.subPath }}
 | |
|               {{- end }}
 | |
|         - name: actions-token-upload
 | |
|           image: "{{ .Values.provisioning.publish.repository }}:{{ .Values.provisioning.publish.tag }}"
 | |
|           imagePullPolicy: {{ .Values.provisioning.publish.pullPolicy }}
 | |
|           env:
 | |
|             - name: SECRET_NAME
 | |
|               value: {{ $secretName }}
 | |
|           command:
 | |
|             - sh
 | |
|             - -c
 | |
|             - |
 | |
|               printf "Checking rights to update kubernetes act_runner secret..."
 | |
|               kubectl auth can-i update secret/${SECRET_NAME}
 | |
|               /scripts/token.sh
 | |
|           resources:
 | |
|             {{- toYaml .Values.provisioning.resources | nindent 12 }}
 | |
|           volumeMounts:
 | |
|             - mountPath: /scripts
 | |
|               name: scripts
 | |
|               readOnly: true
 | |
|             - mountPath: /data
 | |
|               name: data
 | |
|               readOnly: true
 | |
|               {{- if .Values.persistence.subPath }}
 | |
|               subPath: {{ .Values.persistence.subPath }}
 | |
|               {{- end }}
 | |
|       {{- range $key, $value := .Values.provisioning.nodeSelector }}
 | |
|       nodeSelector:
 | |
|         {{ $key }}: {{ $value | quote }}
 | |
|       {{- end }}
 | |
|       {{- with .Values.provisioning.affinity }}
 | |
|       affinity:
 | |
|         {{- toYaml . | nindent 8 }}
 | |
|       {{- end }}
 | |
|       {{- with .Values.provisioning.tolerations }}
 | |
|       tolerations:
 | |
|         {{- toYaml . | nindent 8 }}
 | |
|       {{- end }}
 | |
|       restartPolicy: Never
 | |
|       serviceAccount: {{ $name }}
 | |
|       volumes:
 | |
|         - name: scripts
 | |
|           configMap:
 | |
|             name: {{ include "gitea.fullname" . }}-scripts
 | |
|             defaultMode: 0755
 | |
|         - name: data
 | |
|           persistentVolumeClaim:
 | |
|             claimName: {{ .Values.persistence.claimName }}
 | |
|   parallelism: 1
 | |
|   completions: 1
 | |
|   backoffLimit: 1
 | |
| {{- end }}
 | |
| {{- end }}
 |