You've already forked helm-gitea
							
							Compare commits
	
		
			101 Commits
		
	
	
		
			v11.0.1
			...
			fcf5a4a7c9
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| fcf5a4a7c9 | |||
| 717aa85adb | |||
| d2a6ffc26e | |||
| 9a64d5b457 | |||
| ee199f21bd | |||
| 6bcf0c1af5 | |||
| bf9c6b2b5d | |||
| 99689c6b8f | |||
| 0e35ed83d4 | |||
| 54a92344cc | |||
| a1754df124 | |||
| 6a2a93c780 | |||
| fb407618dc | |||
|   | 1d7037e55e | ||
|   | 9cf42f55b0 | ||
|   | 8ed2db6aa5 | ||
|   | 667834962e | ||
|   | 78aba58284 | ||
|   | 7c0a924ca3 | ||
|   | 677b1af2ed | ||
|   | c9af860e60 | ||
|   | 3721929be2 | ||
|   | 44e9970b0b | ||
|   | 4fc53cd978 | ||
|   | 122bccd932 | ||
|   | 3233e33e27 | ||
|   | 6b99230843 | ||
| d9e181df93 | |||
|   | 603f8e68a7 | ||
| 10ad0f7743 | |||
| e31bd265b1 | |||
|   | 4cfcbd729f | ||
|   | f786359136 | ||
|   | 6d5fbcbaee | ||
|   | 14a4e47b73 | ||
|   | 3a7859f6cc | ||
|   | 364dfa2076 | ||
| 468c12643f | |||
|   | 46aa0534bb | ||
|   | 455cc67d41 | ||
|   | ec898f1330 | ||
| 82190f3d30 | |||
|   | e059beb82b | ||
|   | 9206b34af3 | ||
|   | 203a282e93 | ||
|   | 81c12fa3e5 | ||
|   | c7e294cf8c | ||
|   | ce60c7bb0f | ||
|   | 2875e08daf | ||
| 09767c4494 | |||
|   | a45253abf9 | ||
|   | f9efe98fe7 | ||
|   | 92c187f264 | ||
|   | 4fbdf634a9 | ||
|   | f0dcbe88dd | ||
|   | aa7ccb47ba | ||
|   | 0f1f329de4 | ||
|   | cb28148dc8 | ||
|   | ee84a1750b | ||
|   | 6e1d516bb2 | ||
|   | 08143654a5 | ||
|   | e134835662 | ||
|   | e7db8cddd9 | ||
| ec7a659535 | |||
|   | db177a356f | ||
|   | d29a7e84a4 | ||
|   | 31fa278145 | ||
|   | 52c249eb08 | ||
|   | 0d532363eb | ||
|   | 8f0f44a864 | ||
|   | cf86118976 | ||
|   | 7f96084a30 | ||
|   | 5292684a4a | ||
|   | edc42f69a9 | ||
|   | 9c607f8a4b | ||
|   | 6d89d0a1b7 | ||
|   | 8f35f45e31 | ||
|   | a94eec4238 | ||
|   | 87272a1244 | ||
|   | ed06694adf | ||
|   | 443a6d0cd7 | ||
|   | 8854e62572 | ||
|   | da2d169d65 | ||
|   | ebb4b1ee49 | ||
|   | e64afe393e | ||
|   | 6e4e414771 | ||
|   | 037eca0c91 | ||
|   | d10adfd064 | ||
|   | a1fc670df5 | ||
|   | 0cfe38aec5 | ||
|   | 5410bb08c2 | ||
|   | 3b32a04b9c | ||
|   | 5b247ea860 | ||
|   | 3aea811f1f | ||
|   | a7035ca4e5 | ||
|   | fa36d2beef | ||
|   | 6c5b42c482 | ||
|   | 356dd6e710 | ||
|   | 1f313ac70e | ||
|   | d2d542e625 | ||
|   | 75cd261b37 | 
							
								
								
									
										114
									
								
								.gitea/scripts/add-annotations.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										114
									
								
								.gitea/scripts/add-annotations.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,114 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| set -e | ||||
|  | ||||
| CHART_FILE="Chart.yaml" | ||||
| if [ ! -f "${CHART_FILE}" ]; then | ||||
|   echo "ERROR: ${CHART_FILE} not found!" 1>&2 | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| DEFAULT_NEW_TAG="$(git tag --sort=-version:refname | head -n 1)" | ||||
| DEFAULT_OLD_TAG="$(git tag --sort=-version:refname | head -n 2 | tail -n 1)" | ||||
|  | ||||
| if [ -z "${1}" ]; then | ||||
|   read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG | ||||
|   if [ -z "${OLD_TAG}" ]; then | ||||
|     OLD_TAG="${DEFAULT_OLD_TAG}" | ||||
|   fi | ||||
|  | ||||
|   while [ -z "$(git tag --list "${OLD_TAG}")" ]; do | ||||
|     echo "ERROR: Tag '${OLD_TAG}' not found!" 1>&2 | ||||
|     read -p "Enter start tag [${DEFAULT_OLD_TAG}]: " OLD_TAG | ||||
|     if [ -z "${OLD_TAG}" ]; then | ||||
|       OLD_TAG="${DEFAULT_OLD_TAG}" | ||||
|     fi | ||||
|   done | ||||
| else | ||||
|   OLD_TAG=${1} | ||||
|   if [ -z "$(git tag --list "${OLD_TAG}")" ]; then | ||||
|     echo "ERROR: Tag '${OLD_TAG}' not found!" 1>&2 | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| if [ -z "${2}" ]; then | ||||
|   read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG | ||||
|   if [ -z "${NEW_TAG}" ]; then | ||||
|     NEW_TAG="${DEFAULT_NEW_TAG}" | ||||
|   fi | ||||
|  | ||||
|   while [ -z "$(git tag --list "${NEW_TAG}")" ]; do | ||||
|     echo "ERROR: Tag '${NEW_TAG}' not found!" 1>&2 | ||||
|     read -p "Enter end tag [${DEFAULT_NEW_TAG}]: " NEW_TAG | ||||
|     if [ -z "${NEW_TAG}" ]; then | ||||
|       NEW_TAG="${DEFAULT_NEW_TAG}" | ||||
|     fi | ||||
|   done | ||||
| else | ||||
|   NEW_TAG=${2} | ||||
|  | ||||
|   if [ -z "$(git tag --list "${NEW_TAG}")" ]; then | ||||
|     echo "ERROR: Tag '${NEW_TAG}' not found!" 1>&2 | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| CHANGE_LOG_YAML=$(mktemp) | ||||
| echo "[]" > "${CHANGE_LOG_YAML}" | ||||
|  | ||||
| function map_type_to_kind() { | ||||
|   case "${1}" in | ||||
|     feat) | ||||
|       echo "added" | ||||
|     ;; | ||||
|     fix) | ||||
|       echo "fixed" | ||||
|     ;; | ||||
|     chore|style|test|ci|docs|refac) | ||||
|       echo "changed" | ||||
|     ;; | ||||
|     revert) | ||||
|       echo "removed" | ||||
|     ;; | ||||
|     sec) | ||||
|       echo "security" | ||||
|     ;; | ||||
|     *) | ||||
|       echo "skip" | ||||
|     ;; | ||||
|   esac | ||||
| } | ||||
|  | ||||
| COMMIT_TITLES="$(git log --pretty=format:"%s" "${OLD_TAG}..${NEW_TAG}")" | ||||
|  | ||||
| echo "INFO: Generate change log entries from ${OLD_TAG} until ${NEW_TAG}" | ||||
|  | ||||
| while IFS= read -r line; do | ||||
|   if [[ "${line}" =~ ^([a-zA-Z]+)(\([^\)]+\))?\:\ (.+)$ ]]; then | ||||
|     TYPE="${BASH_REMATCH[1]}" | ||||
|     KIND=$(map_type_to_kind "${TYPE}") | ||||
|  | ||||
|     if [ "${KIND}" == "skip" ]; then | ||||
|       continue | ||||
|     fi | ||||
|  | ||||
|     DESC="${BASH_REMATCH[3]}" | ||||
|  | ||||
|     echo "- ${KIND}: ${DESC}" | ||||
|  | ||||
|     jq --arg kind "${KIND}" --arg description "${DESC}" '. += [ $ARGS.named ]' < "${CHANGE_LOG_YAML}" > "${CHANGE_LOG_YAML}.new" | ||||
|     mv "${CHANGE_LOG_YAML}.new" "${CHANGE_LOG_YAML}" | ||||
|  | ||||
|   fi | ||||
| done <<< "${COMMIT_TITLES}" | ||||
|  | ||||
| if [ -s "${CHANGE_LOG_YAML}" ]; then | ||||
|   yq --inplace --input-format json --output-format yml "${CHANGE_LOG_YAML}" | ||||
|   yq --no-colors --inplace ".annotations.\"artifacthub.io/changes\" |= loadstr(\"${CHANGE_LOG_YAML}\") | sort_keys(.)" "${CHART_FILE}" | ||||
| else | ||||
|   echo "ERROR: Changelog file is empty: ${CHANGE_LOG_YAML}" 1>&2 | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| rm "${CHANGE_LOG_YAML}" | ||||
| @@ -1,32 +1,31 @@ | ||||
| name: changelog | ||||
| name: Update changelog | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|     branches: [ "main" ] | ||||
|  | ||||
| jobs: | ||||
|   changelog: | ||||
|     container: docker.io/thegeeklab/git-sv:2.0.5 | ||||
|     runs-on: ubuntu-latest | ||||
|     container: docker.io/thegeeklab/git-sv:1.0.12 | ||||
|     steps: | ||||
|       - name: install tools | ||||
|       - name: Install packages via apt | ||||
|         run: | | ||||
|           apk add -q --update --no-cache nodejs curl jq sed | ||||
|       - uses: actions/checkout@v4 | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|       - name: Generate upcoming changelog | ||||
|         run: | | ||||
|           git sv rn -o changelog.md | ||||
|           export RELEASE_NOTES=$(cat changelog.md) | ||||
|           export ISSUE_NUMBER=$(curl -s "https://gitea.com/api/v1/repos/gitea/helm-gitea/issues?state=open&q=Changelog%20for%20upcoming%20version" | jq '.[].number') | ||||
|           export ISSUE_NUMBER=$(curl -s "${GITHUB_SERVER_URL}/api/v1/repos/gitea/helm-gitea/issues?state=open&q=Changelog%20for%20upcoming%20version" | jq '.[].number') | ||||
|  | ||||
|           echo $RELEASE_NOTES | ||||
|           JSON_DATA=$(echo "" | jq -Rs --arg title 'Changelog for upcoming version' --arg body "$(cat changelog.md)" '{title: $title, body: $body}') | ||||
|  | ||||
|           if [ -z "$ISSUE_NUMBER" ]; then | ||||
|             curl -s -X POST "https://gitea.com/api/v1/repos/gitea/helm-gitea/issues" -H "Authorization: token ${{ secrets.ISSUE_RW_TOKEN }}" -H "Content-Type: application/json" -d "$JSON_DATA" | ||||
|             curl -s -X POST "${GITHUB_SERVER_URL}/api/v1/repos/gitea/helm-gitea/issues" -H "Authorization: token ${{ secrets.ISSUE_RW_TOKEN }}" -H "Content-Type: application/json" -d "$JSON_DATA" | ||||
|           else | ||||
|             curl -s -X PATCH "https://gitea.com/api/v1/repos/gitea/helm-gitea/issues/$ISSUE_NUMBER" -H "Authorization: token ${{ secrets.ISSUE_RW_TOKEN }}" -H "Content-Type: application/json" -d "$JSON_DATA" | ||||
|             curl -s -X PATCH "${GITHUB_SERVER_URL}/api/v1/repos/gitea/helm-gitea/issues/$ISSUE_NUMBER" -H "Authorization: token ${{ secrets.ISSUE_RW_TOKEN }}" -H "Content-Type: application/json" -d "$JSON_DATA" | ||||
|           fi | ||||
|   | ||||
| @@ -1,19 +1,17 @@ | ||||
| name: commitlint | ||||
| name: Rum commitlint | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - "*" | ||||
|     types: | ||||
|       - opened | ||||
|       - edited | ||||
|     branches: [ '**' ] | ||||
|     types: [ "opened", "edited" ] | ||||
|  | ||||
| jobs: | ||||
|   check-and-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: commitlint/commitlint:19.7.1 | ||||
|     container: commitlint/commitlint:19.9.1 | ||||
|     name: Execute commitlint | ||||
|     runs-on: docker.io/ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: check PR title | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|       - name: Check PR title | ||||
|         run: | | ||||
|           echo "${{ gitea.event.pull_request.title }}" | commitlint --config .commitlintrc.json | ||||
|   | ||||
							
								
								
									
										75
									
								
								.gitea/workflows/helm.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								.gitea/workflows/helm.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| name: Run Helm tests | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: [ '**' ] | ||||
|   push: | ||||
|     branches: [ '**' ] | ||||
|     tags-ignore: [ '**' ] | ||||
|   workflow_call: {} | ||||
|  | ||||
| env: | ||||
|   # renovate: datasource=github-releases depName=helm-unittest/helm-unittest | ||||
|   HELM_UNITTEST_VERSION: "v1.0.1" | ||||
|  | ||||
| jobs: | ||||
|   helm-lint: | ||||
|     container: docker.io/alpine/helm:3.18.6 | ||||
|     name: Execute helm lint | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Install additional tools | ||||
|         run: | | ||||
|           apk update | ||||
|           apk add --update bash make nodejs | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|       - name: Install helm chart dependencies | ||||
|         run: helm dependency build | ||||
|       - name: Execute helm lint | ||||
|         run: helm lint | ||||
|  | ||||
|   helm-template: | ||||
|     container: docker.io/alpine/helm:3.18.6 | ||||
|     name: Execute helm template | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Install additional tools | ||||
|         run: | | ||||
|           apk update | ||||
|           apk add --update bash make nodejs | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|       - name: Install helm chart dependencies | ||||
|         run: helm dependency build | ||||
|       - name: Execute helm template | ||||
|         run: helm template --debug gitea-helm . | ||||
|  | ||||
|   helm-unittest: | ||||
|     container: docker.io/alpine/helm:3.18.6 | ||||
|     name: Execute helm unittest | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Install additional tools | ||||
|         run: | | ||||
|           apk update | ||||
|           apk add --update bash make nodejs npm yamllint ncurses | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|       - name: Install helm chart dependencies | ||||
|         run: helm dependency build | ||||
|       - name: Install helm plugin 'unittest' | ||||
|         run: | | ||||
|           helm plugin install --version ${{ env.HELM_UNITTEST_VERSION }} https://github.com/helm-unittest/helm-unittest | ||||
|           git submodule update --init --recursive | ||||
|       - name: Execute helm unittest | ||||
|         env: | ||||
|           TERM: xterm | ||||
|         run: make unittests | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|       # - name: verify readme | ||||
|       #   run: | | ||||
|       #     make readme | ||||
|       #     git diff --exit-code --name-only README.md | ||||
|       # - name: yaml lint | ||||
|       #   uses: https://github.com/ibiqlik/action-yamllint@v3 | ||||
							
								
								
									
										52
									
								
								.gitea/workflows/markdown-linters.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								.gitea/workflows/markdown-linters.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| name: Markdown linter | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     types: [ "opened", "reopened", "synchronize" ] | ||||
|   push: | ||||
|     branches: [ '**' ] | ||||
|     tags-ignore: [ '**' ] | ||||
|   workflow_dispatch: {} | ||||
|  | ||||
| jobs: | ||||
|   readme-link: | ||||
|     container: | ||||
|       image: docker.io/library/node:24.9.0-alpine | ||||
|     name: Execute npm run readme:link | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v5.0.0 | ||||
|     - name: Execute npm run readme:link | ||||
|       run: | | ||||
|         npm install | ||||
|         npm run readme:link | ||||
|  | ||||
|   readme-lint: | ||||
|     container: | ||||
|       image: docker.io/library/node:24.9.0-alpine | ||||
|     name: Execute npm run readme:lint | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - uses: actions/checkout@v5.0.0 | ||||
|     - name: Execute npm run readme:lint | ||||
|       run: | | ||||
|         npm install | ||||
|         npm run readme:lint | ||||
|  | ||||
|   readme-parameters: | ||||
|     container: | ||||
|       image: docker.io/library/node:24.9.0-alpine | ||||
|     name: Execute npm run readme:parameters | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - name: Install tooling | ||||
|       run: | | ||||
|         apk update | ||||
|         apk add git | ||||
|     - uses: actions/checkout@v5.0.0 | ||||
|     - name: Execute npm run readme:parameters | ||||
|       run: | | ||||
|         npm install | ||||
|         npm run readme:parameters | ||||
|     - name: Compare diff | ||||
|       run: git diff --exit-code --name-only README.md | ||||
| @@ -2,36 +2,53 @@ name: generate-chart | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     tags: | ||||
|       - "*" | ||||
|  | ||||
| env: | ||||
|   # renovate: datasource=docker depName=alpine/helm | ||||
|   HELM_VERSION: "3.17.1" | ||||
|     tags: [ '**' ] | ||||
|  | ||||
| jobs: | ||||
|   generate-chart-publish: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: install tools | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Install packages via apt | ||||
|         run: | | ||||
|           apt update -y | ||||
|           apt install -y curl ca-certificates curl gnupg | ||||
|           # helm | ||||
|           curl -O https://get.helm.sh/helm-v${{ env.HELM_VERSION }}-linux-amd64.tar.gz | ||||
|           tar -xzf helm-v${{ env.HELM_VERSION }}-linux-amd64.tar.gz | ||||
|           mv linux-amd64/helm /usr/local/bin/ | ||||
|           rm -rf linux-amd64 helm-v${{ env.HELM_VERSION }}-linux-amd64.tar.gz | ||||
|           apt update --yes | ||||
|           apt install --yes curl ca-certificates curl gnupg jq | ||||
|  | ||||
|       - name: Install helm | ||||
|         env: | ||||
|           # renovate: datasource=docker depName=alpine/helm | ||||
|           HELM_VERSION: "3.18.6" | ||||
|         run: | | ||||
|           curl --fail --location --output /dev/stdout --silent --show-error https://get.helm.sh/helm-v${HELM_VERSION}-linux-$(dpkg --print-architecture).tar.gz | tar --extract --gzip --file /dev/stdin | ||||
|           mv linux-$(dpkg --print-architecture)/helm /usr/local/bin/ | ||||
|           rm --force --recursive linux-$(dpkg --print-architecture) helm-v${HELM_VERSION}-linux-$(dpkg --print-architecture).tar.gz | ||||
|           helm version | ||||
|           # docker | ||||
|  | ||||
|       - name: Install yq | ||||
|         env: | ||||
|           YQ_VERSION: v4.45.4 # renovate: datasource=github-releases depName=mikefarah/yq | ||||
|         run: | | ||||
|           curl --fail --location --output /dev/stdout --silent --show-error https://github.com/mikefarah/yq/releases/download/${YQ_VERSION}/yq_linux_$(dpkg --print-architecture).tar.gz | tar --extract --gzip --file /dev/stdin | ||||
|           mv yq_linux_$(dpkg --print-architecture) /usr/local/bin | ||||
|           rm --force --recursive yq_linux_$(dpkg --print-architecture) yq_linux_$(dpkg --print-architecture).tar.gz | ||||
|           yq --version | ||||
|  | ||||
|       - name: Install docker-ce via apt | ||||
|         run: | | ||||
|           install -m 0755 -d /etc/apt/keyrings | ||||
|           curl -fsSL https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg | ||||
|           curl --fail --location --silent --show-error https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg | ||||
|           chmod a+r /etc/apt/keyrings/docker.gpg | ||||
|           echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null | ||||
|           apt update -y | ||||
|           apt install -y python3 python3-pip apt-transport-https docker-ce-cli | ||||
|           apt update --yes | ||||
|           apt install --yes python3 python3-pip apt-transport-https docker-ce-cli | ||||
|  | ||||
|       - name: Install awscli | ||||
|         run: | | ||||
|           pip install awscli --break-system-packages | ||||
|           aws --version | ||||
|  | ||||
|       - name: Import GPG key | ||||
|         id: import_gpg | ||||
| @@ -41,8 +58,17 @@ jobs: | ||||
|           passphrase: ${{ secrets.GPGSIGN_PASSPHRASE }} | ||||
|           fingerprint: CC64B1DB67ABBEECAB24B6455FC346329753F4B0 | ||||
|  | ||||
|       - name: Add Artifacthub.io annotations | ||||
|         run: | | ||||
|           NEW_TAG="$(git tag --sort=-version:refname | head --lines 1)" | ||||
|           OLD_TAG="$(git tag --sort=-version:refname | head --lines 2 | tail --lines 1)" | ||||
|           .gitea/scripts/add-annotations.sh "${OLD_TAG}" "${NEW_TAG}" | ||||
|  | ||||
|       - name: Print Chart.yaml on stdout | ||||
|         run: cat Chart.yaml | ||||
|  | ||||
|       # Using helm gpg plugin as 'helm package --sign' has issues with gpg2: https://github.com/helm/helm/issues/2843 | ||||
|       - name: package chart | ||||
|       - name: Package Helm chart | ||||
|         run: | | ||||
|           echo ${{ secrets.DOCKER_CHARTS_PASSWORD }} | docker login -u ${{ secrets.DOCKER_CHARTS_USERNAME }} --password-stdin | ||||
|           # FIXME: use upstream after https://github.com/technosophos/helm-gpg/issues/1 is solved | ||||
| @@ -51,15 +77,15 @@ jobs: | ||||
|           helm package --version "${GITHUB_REF#refs/tags/v}" ./ | ||||
|           mkdir gitea | ||||
|           mv gitea*.tgz gitea/ | ||||
|           curl -s -L -o gitea/index.yaml https://dl.gitea.com/charts/index.yaml | ||||
|           curl --fail --location --output gitea/index.yaml --silent --show-error https://dl.gitea.com/charts/index.yaml | ||||
|           helm repo index gitea/ --url https://dl.gitea.com/charts --merge gitea/index.yaml | ||||
|           # push to dockerhub | ||||
|           echo ${{ secrets.DOCKER_CHARTS_PASSWORD }} | helm registry login -u ${{ secrets.DOCKER_CHARTS_USERNAME }} registry-1.docker.io --password-stdin | ||||
|           helm push gitea/gitea-${GITHUB_REF#refs/tags/v}.tgz oci://registry-1.docker.io/giteacharts | ||||
|           helm registry logout registry-1.docker.io | ||||
|  | ||||
|       - name: aws credential configure | ||||
|         uses: https://github.com/aws-actions/configure-aws-credentials@v4 | ||||
|       - name: Configure AWS credentials | ||||
|         uses: https://github.com/aws-actions/configure-aws-credentials@v5 | ||||
|         with: | ||||
|           aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | ||||
|           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||
| @@ -68,3 +94,29 @@ jobs: | ||||
|       - name: Copy files to S3 and clear cache | ||||
|         run: | | ||||
|           aws s3 sync gitea/ s3://${{ secrets.AWS_S3_BUCKET}}/charts/ | ||||
|  | ||||
|   release-gitea: | ||||
|     container: docker.io/thegeeklab/git-sv:2.0.5 | ||||
|     needs: generate-chart-publish | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Install packages via apt | ||||
|         run: | | ||||
|           apk add -q --update --no-cache nodejs | ||||
|       - uses: actions/checkout@v5.0.0 | ||||
|         with: | ||||
|           fetch-tags: true | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Create changelog | ||||
|         run: | | ||||
|           git sv current-version | ||||
|           git sv release-notes -t ${GITHUB_REF#refs/tags/} -o CHANGELOG.md | ||||
|           sed -i '1,2d' CHANGELOG.md # remove version | ||||
|           cat CHANGELOG.md | ||||
|  | ||||
|       - name: Release | ||||
|         uses: https://github.com/akkuman/gitea-release-action@v1 | ||||
|         with: | ||||
|           body_path: CHANGELOG.md | ||||
|           token: "${{ secrets.RELEASE_TOKEN }}" | ||||
|   | ||||
| @@ -1,45 +0,0 @@ | ||||
| name: check-and-test | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - "*" | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|  | ||||
| env: | ||||
|   # renovate: datasource=github-releases depName=helm-unittest/helm-unittest | ||||
|   HELM_UNITTEST_VERSION: "v0.7.2" | ||||
|  | ||||
| jobs: | ||||
|   check-and-test: | ||||
|     runs-on: ubuntu-latest | ||||
|     container: alpine/helm:3.17.1 | ||||
|     steps: | ||||
|       - name: install tools | ||||
|         run: | | ||||
|           apk update | ||||
|           apk add --update bash make nodejs npm yamllint ncurses | ||||
|       - uses: actions/checkout@v4 | ||||
|       - name: install chart dependencies | ||||
|         run: helm dependency build | ||||
|       - name: lint | ||||
|         run: helm lint | ||||
|       - name: template | ||||
|         run: helm template --debug gitea-helm . | ||||
|       - name: prepare unit test environment | ||||
|         run: | | ||||
|           helm plugin install --version ${{ env.HELM_UNITTEST_VERSION }} https://github.com/helm-unittest/helm-unittest | ||||
|           git submodule update --init --recursive | ||||
|       - name: unit tests | ||||
|         env: | ||||
|           TERM: xterm | ||||
|         run: | | ||||
|           make unittests | ||||
|       - name: verify readme | ||||
|         run: | | ||||
|           make readme | ||||
|           git diff --exit-code --name-only README.md | ||||
|       - name: yaml lint | ||||
|         uses: https://github.com/ibiqlik/action-yamllint@v3 | ||||
							
								
								
									
										8
									
								
								.markdownlink.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.markdownlink.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| { | ||||
|   "projectBaseUrl":"${workspaceFolder}", | ||||
|   "ignorePatterns": [ | ||||
|     { | ||||
|       "pattern": "^http://localhost" | ||||
|     } | ||||
|   ] | ||||
| } | ||||
							
								
								
									
										2
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "yaml.schemas": { | ||||
|         "https://raw.githubusercontent.com/helm-unittest/helm-unittest/v0.7.2/schema/helm-testsuite.json": [ | ||||
|         "https://raw.githubusercontent.com/helm-unittest/helm-unittest/v1.0.1/schema/helm-testsuite.json": [ | ||||
|             "/unittests/**/*.yaml" | ||||
|         ] | ||||
|     }, | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| * @justusbunsi @pat-s | ||||
| * @rossigee @volker.raschek @ChristopherHX | ||||
|   | ||||
| @@ -44,8 +44,7 @@ be used: | ||||
|    `helm install --dependency-update gitea . -f values.yaml`. | ||||
| 1. Gitea is now deployed in `minikube`. | ||||
|    To access it, it's port needs to be forwarded first from `minikube` to localhost first via `kubectl --namespace | ||||
| default port-forward svc/gitea-http 3000:3000`. | ||||
|    Now Gitea is accessible at [http://localhost:3000](http://localhost:3000). | ||||
| default port-forward svc/gitea-http 3000:3000`. Now Gitea is accessible at [http://localhost:3000](http://localhost:3000). | ||||
|  | ||||
| ### Unit tests | ||||
|  | ||||
| @@ -75,6 +74,6 @@ See [bats documentation](https://bats-core.readthedocs.io/en/stable/) for usage | ||||
|  | ||||
| ## Release process | ||||
|  | ||||
| 1. Create a tag following the tagging schema | ||||
| 1. Push the tag | ||||
| 1. Ensure you have [`git-sv`](https://github.com/thegeeklab/git-sv) installed | ||||
| 1. Run `git sv tag` (this creates and pushes the tag following the respective next tag according to the semver commits issued since the last release) | ||||
| 1. Let CI do it's work | ||||
|   | ||||
							
								
								
									
										16
									
								
								Chart.lock
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								Chart.lock
									
									
									
									
									
								
							| @@ -1,15 +1,15 @@ | ||||
| dependencies: | ||||
| - name: postgresql | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 16.4.14 | ||||
|   version: 16.7.27 | ||||
| - name: postgresql-ha | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 15.2.3 | ||||
| - name: redis-cluster | ||||
|   version: 16.3.2 | ||||
| - name: valkey-cluster | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 11.4.3 | ||||
| - name: redis | ||||
|   version: 3.0.24 | ||||
| - name: valkey | ||||
|   repository: oci://registry-1.docker.io/bitnamicharts | ||||
|   version: 20.8.0 | ||||
| digest: sha256:ce1a2a02c3e1adb764cae42ccce1efd2d41adb5024576e6d8a92b30b8dfe67db | ||||
| generated: "2025-02-23T00:12:41.541107288Z" | ||||
|   version: 3.0.31 | ||||
| digest: sha256:ceb6a1890cfdc2627abb85d3e2a4baa64d30afd21dcfabce978a824a67f0a2bb | ||||
| generated: "2025-08-30T00:03:04.59764502Z" | ||||
|   | ||||
							
								
								
									
										49
									
								
								Chart.yaml
									
									
									
									
									
								
							
							
						
						
									
										49
									
								
								Chart.yaml
									
									
									
									
									
								
							| @@ -4,7 +4,7 @@ description: Gitea Helm chart for Kubernetes | ||||
| type: application | ||||
| version: 0.0.0 | ||||
| # renovate datasource=github-releases depName=go-gitea/gitea extractVersion=^v(?<version>.*)$ | ||||
| appVersion: 1.23.6 | ||||
| appVersion: 1.24.6 | ||||
| icon: https://gitea.com/assets/img/logo.svg | ||||
|  | ||||
| keywords: | ||||
| @@ -19,37 +19,40 @@ sources: | ||||
|   - https://github.com/go-gitea/gitea | ||||
|   - https://docker.gitea.com/gitea | ||||
| maintainers: | ||||
|   - name: Charlie Drage | ||||
|     email: charlie@charliedrage.com | ||||
|   - name: Gitea Authors | ||||
|     email: maintainers@gitea.io | ||||
|   - name: Konrad Lother | ||||
|     email: konrad.lother@novum-rgi.de | ||||
|   - name: Lucas Hahn | ||||
|     email: lucas.hahn@novum-rgi.de | ||||
|   - name: Steven Kriegler | ||||
|     email: sk.bunsenbrenner@gmail.com | ||||
|   - name: Patrick Schratz | ||||
|     email: patrick.schratz@gmail.com | ||||
|   # https://gitea.com/rossigee | ||||
|   - name: Ross Golder | ||||
|     email: ross@golder.org | ||||
|  | ||||
|   # https://gitea.com/volker.raschek | ||||
|   - name: Markus Pesch | ||||
|     email: markus.pesch+apps@cryptic.systems | ||||
|  | ||||
|   # https://gitea.com/DaanSelen | ||||
|   - name: Daan Selen | ||||
|     email: dselen@nerthus.nl | ||||
|  | ||||
|   # https://gitea.com/ChristopherHX | ||||
|   - name: Christopher Homberger | ||||
|     email: christopher.homberger@web.de | ||||
|  | ||||
| dependencies: | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/postgresql | ||||
|   - name: postgresql | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 16.4.14 | ||||
|     version: 16.7.27 | ||||
|     condition: postgresql.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/postgresql-ha/Chart.yaml | ||||
|   - name: postgresql-ha | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 15.2.3 | ||||
|     version: 16.3.2 | ||||
|     condition: postgresql-ha.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/redis-cluster/Chart.yaml | ||||
|   - name: redis-cluster | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/valkey-cluster/Chart.yaml | ||||
|   - name: valkey-cluster | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 11.4.3 | ||||
|     condition: redis-cluster.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/redis/Chart.yaml | ||||
|   - name: redis | ||||
|     version: 3.0.24 | ||||
|     condition: valkey-cluster.enabled | ||||
|   # https://github.com/bitnami/charts/blob/main/bitnami/valkey/Chart.yaml | ||||
|   - name: valkey | ||||
|     repository: oci://registry-1.docker.io/bitnamicharts | ||||
|     version: 20.8.0 | ||||
|     condition: redis.enabled | ||||
|     version: 3.0.31 | ||||
|     condition: valkey.enabled | ||||
|   | ||||
							
								
								
									
										248
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										248
									
								
								README.md
									
									
									
									
									
								
							| @@ -17,7 +17,7 @@ | ||||
|     - [Rootless Defaults](#rootless-defaults) | ||||
|     - [Session, Cache and Queue](#session-cache-and-queue) | ||||
|   - [Single-Pod Configurations](#single-pod-configurations) | ||||
|   - [Additional _app.ini_ settings](#additional-appini-settings) | ||||
|   - [Additional app.ini settings](#additional-appini-settings) | ||||
|     - [User defined environment variables in app.ini](#user-defined-environment-variables-in-appini) | ||||
|   - [External Database](#external-database) | ||||
|   - [Ports and external url](#ports-and-external-url) | ||||
| @@ -33,6 +33,7 @@ | ||||
| - [Metrics and profiling](#metrics-and-profiling) | ||||
|   - [Secure Metrics Endpoint](#secure-metrics-endpoint) | ||||
| - [Pod annotations](#pod-annotations) | ||||
| - [TLS certificate rotation](#tls-certificate-rotation) | ||||
| - [Themes](#themes) | ||||
| - [Renovate](#renovate) | ||||
| - [Parameters](#parameters) | ||||
| @@ -47,13 +48,12 @@ | ||||
|   - [Persistence](#persistence-1) | ||||
|   - [Init](#init) | ||||
|   - [Signing](#signing) | ||||
|   - [Gitea Actions](#gitea-actions) | ||||
|   - [Gitea](#gitea) | ||||
|   - [LivenessProbe](#livenessprobe) | ||||
|   - [ReadinessProbe](#readinessprobe) | ||||
|   - [StartupProbe](#startupprobe) | ||||
|   - [redis-cluster](#redis-cluster) | ||||
|   - [redis](#redis) | ||||
|   - [valkey-cluster](#valkey-cluster) | ||||
|   - [valkey](#valkey) | ||||
|   - [PostgreSQL HA](#postgresql-ha) | ||||
|   - [PostgreSQL](#postgresql) | ||||
|   - [Advanced](#advanced) | ||||
| @@ -72,7 +72,7 @@ Additionally, this chart allows to provide LDAP and admin user configuration wit | ||||
| ## Update and versioning policy | ||||
|  | ||||
| The Gitea helm chart versioning does not follow Gitea's versioning. | ||||
| The latest chart version can be looked up in [https://dl.gitea.com/charts](https://dl.gitea.com/charts) or in the [repository releases](https://gitea.com/gitea/helm-gitea/releases). | ||||
| The latest chart version can be looked up in [https://dl.gitea.com/charts/](https://dl.gitea.com/charts/) or in the [repository releases](https://gitea.com/gitea/helm-gitea/releases). | ||||
|  | ||||
| The chart aims to follow Gitea's releases closely. | ||||
| There might be times when the chart is behind the latest Gitea release. | ||||
| @@ -96,14 +96,14 @@ Users can also configure their own external providers via the configuration. | ||||
| These dependencies are enabled by default: | ||||
|  | ||||
| - PostgreSQL HA ([Bitnami PostgreSQL-HA](https://github.com/bitnami/charts/blob/main/bitnami/postgresql-ha/Chart.yaml)) | ||||
| - Redis-Cluster ([Bitnami Redis-Cluster](https://github.com/bitnami/charts/blob/main/bitnami/redis-cluster/Chart.yaml)) | ||||
| - Valkey-Cluster ([Bitnami Valkey-Cluster](https://github.com/bitnami/charts/blob/main/bitnami/valkey-cluster/Chart.yaml)) | ||||
|  | ||||
| ### Non-HA Dependencies | ||||
|  | ||||
| Alternatively, the following non-HA replacements are available: | ||||
|  | ||||
| - PostgreSQL ([Bitnami PostgreSQL](<Postgresql](https://github.com/bitnami/charts/blob/main/bitnami/postgresql/Chart.yaml)>)) | ||||
| - Redis ([Bitnami Redis](<Redis](https://github.com/bitnami/charts/blob/main/bitnami/redis/Chart.yaml)>)) | ||||
| - PostgreSQL ([Bitnami PostgreSQL](https://github.com/bitnami/charts/blob/main/bitnami/postgresql/Chart.yaml)) | ||||
| - Valkey ([Bitnami Valkey](https://github.com/bitnami/charts/blob/main/bitnami/valkey/Chart.yaml)) | ||||
|  | ||||
| ### Dependency Versioning | ||||
|  | ||||
| @@ -121,8 +121,8 @@ Please double-check the image repository and available tags in the sub-chart: | ||||
|  | ||||
| - [PostgreSQL-HA](https://hub.docker.com/r/bitnami/postgresql-repmgr/tags) | ||||
| - [PostgreSQL](https://hub.docker.com/r/bitnami/postgresql/tags) | ||||
| - [Redis Cluster](https://hub.docker.com/r/bitnami/redis-cluster/tags) | ||||
| - [Redis](https://hub.docker.com/r/bitnami/redis/tags) | ||||
| - [Valkey Cluster](https://hub.docker.com/r/bitnami/valkey-cluster/tags) | ||||
| - [Valkey](https://hub.docker.com/r/bitnami/valkey/tags) | ||||
|  | ||||
| and look up the image tag which fits your needs on Dockerhub. | ||||
|  | ||||
| @@ -167,7 +167,7 @@ available. As this is a Golang application, this can be implemented using `GOMAX | ||||
| of defining `GOMAXPROCS` automatically based on the defined CPU limit like `1000m`. Please keep in mind, that the CFS | ||||
| rate of `100ms` - default on each kubernetes node, is also very important to avoid CPU throttling. | ||||
|  | ||||
| Further information about this topic can be found [here](https://kanishk.io/posts/cpu-throttling-in-containerized-go-apps/). | ||||
| Further information about this topic can be found [under this link](https://kanishk.io/posts/cpu-throttling-in-containerized-go-apps/). | ||||
|  | ||||
| > [!NOTE] | ||||
| > The environment variable `GOMAXPROCS` is set automatically, when a CPU limit is defined. An explicit configuration is | ||||
| @@ -178,12 +178,12 @@ Further information about this topic can be found [here](https://kanishk.io/post | ||||
| ```yaml | ||||
| deployment: | ||||
|   env: | ||||
|   # Will be automatically defined! | ||||
|   - name: GOMAXPROCS | ||||
|     valueFrom: | ||||
|       resourceFieldRef: | ||||
|         divisor: "1" # Is required for GitDevOps systems like ArgoCD/Flux. Otherwise throw the system a diff error. (k8s-default=1) | ||||
|         resource: limits.cpu | ||||
|     # Will be automatically defined! | ||||
|     - name: GOMAXPROCS | ||||
|       valueFrom: | ||||
|         resourceFieldRef: | ||||
|           divisor: "1" # Is required for GitDevOps systems like ArgoCD/Flux. Otherwise throw the system a diff error. (k8s-default=1) | ||||
|           resource: limits.cpu | ||||
|  | ||||
| resources: | ||||
|   limits: | ||||
| @@ -266,7 +266,7 @@ If `.Values.image.rootless: true`, then the following will occur. In case you us | ||||
|  | ||||
| - `$HOME` becomes `/data/gitea/git` | ||||
|  | ||||
|   [see deployment.yaml](./templates/gitea/deployment.yaml) template inside (init-)container "env" declarations | ||||
|   [see deployment.yaml](./templates/deployment.yaml) template inside (init-)container "env" declarations | ||||
|  | ||||
| - `START_SSH_SERVER: true` (Unless explicity overwritten by `gitea.config.server.START_SSH_SERVER`) | ||||
|  | ||||
| @@ -278,32 +278,32 @@ If `.Values.image.rootless: true`, then the following will occur. In case you us | ||||
|  | ||||
| - `SSH_LOG_LEVEL` environment variable is not injected into the container | ||||
|  | ||||
|   [see deployment.yaml](./templates/gitea/deployment.yaml) template inside container "env" declarations | ||||
|   [see deployment.yaml](./templates/deployment.yaml) template inside container "env" declarations | ||||
|  | ||||
| #### Session, Cache and Queue | ||||
|  | ||||
| The session, cache and queue settings are set to use the built-in Redis Cluster sub-chart dependency. | ||||
| If Redis Cluster is disabled, the chart will fall back to the Gitea defaults which use "memory" for `session` and `cache` and "level" for `queue`. | ||||
| The session, cache and queue settings are set to use the built-in Valkey Cluster sub-chart dependency. | ||||
| If Valkey Cluster is disabled, the chart will fall back to the Gitea defaults which use "memory" for `session` and `cache` and "level" for `queue`. | ||||
|  | ||||
| While these will work and even not cause immediate issues after startup, **they are not recommended for production use**. | ||||
| Reasons being that a single pod will take on all the work for `session` and `cache` tasks in its available memory. | ||||
| It is likely that the pod will run out of memory or will face substantial memory spikes, depending on the workload. | ||||
| External tools such as `redis-cluster` or `memcached` handle these workloads much better. | ||||
| External tools such as `valkey-cluster` or `memcached` handle these workloads much better. | ||||
|  | ||||
| ### Single-Pod Configurations | ||||
|  | ||||
| If HA is not needed/desired, the following configurations can be used to deploy a single-pod Gitea instance. | ||||
|  | ||||
| 1. For a production-ready single-pod Gitea instance without external dependencies (using the chart dependency `postgresql` and `redis`): | ||||
| 1. For a production-ready single-pod Gitea instance without external dependencies (using the chart dependency `postgresql` and `valkey`): | ||||
|  | ||||
|    <details> | ||||
|  | ||||
|    <summary>values.yml</summary> | ||||
|  | ||||
|    ```yaml | ||||
|    redis-cluster: | ||||
|    valkey-cluster: | ||||
|      enabled: false | ||||
|    redis: | ||||
|    valkey: | ||||
|      enabled: true | ||||
|    postgresql: | ||||
|      enabled: true | ||||
| @@ -334,9 +334,9 @@ If HA is not needed/desired, the following configurations can be used to deploy | ||||
|    <summary>values.yml</summary> | ||||
|  | ||||
|    ```yaml | ||||
|    redis-cluster: | ||||
|    valkey-cluster: | ||||
|      enabled: false | ||||
|    redis: | ||||
|    valkey: | ||||
|      enabled: false | ||||
|    postgresql: | ||||
|      enabled: false | ||||
| @@ -360,7 +360,7 @@ If HA is not needed/desired, the following configurations can be used to deploy | ||||
|  | ||||
|    </details> | ||||
|  | ||||
| ### Additional _app.ini_ settings | ||||
| ### Additional app.ini settings | ||||
|  | ||||
| > **The [generic](https://docs.gitea.com/administration/config-cheat-sheet#overall-default) | ||||
| > section cannot be defined that way.** | ||||
| @@ -534,21 +534,21 @@ and the repository exists. | ||||
| ``` | ||||
|  | ||||
| To solve this problem add the capability `SYS_CHROOT` to the `securityContext`. | ||||
| More about this issue [here](https://gitea.com/gitea/helm-gitea/issues/161). | ||||
| More about this issue [under this link](https://gitea.com/gitea/helm-gitea/issues/161). | ||||
|  | ||||
| ### Cache | ||||
|  | ||||
| The cache handling is done via `redis-cluster` (via the `bitnami` chart) by default. | ||||
| The cache handling is done via `valkey-cluster` (via the `bitnami` chart) by default. | ||||
| This deployment is HA-ready but can also be used for single-pod deployments. | ||||
| By default, 6 replicas are deployed for a working `redis-cluster` deployment. | ||||
| Many cloud providers offer a managed redis service, which can be used instead of the built-in `redis-cluster`. | ||||
| By default, 6 replicas are deployed for a working `valkey-cluster` deployment. | ||||
| Many cloud providers offer a managed valkey service, which can be used instead of the built-in `valkey-cluster`. | ||||
|  | ||||
| ```yaml | ||||
| redis-cluster: | ||||
| valkey-cluster: | ||||
|   enabled: true | ||||
| ``` | ||||
|  | ||||
| ⚠️ The redis charts [do not work well with special characters in the password](https://gitea.com/gitea/helm-gitea/issues/690). | ||||
| ⚠️ The valkey charts [do not work well with special characters in the password](https://gitea.com/gitea/helm-chart/issues/690). | ||||
| Consider omitting such or open an issue in the Bitnami repo and let us know once this got fixed. | ||||
|  | ||||
| ### Persistence | ||||
| @@ -694,7 +694,7 @@ Affected options: | ||||
|  | ||||
| Like the admin user, OAuth2 settings can be updated and disabled but not deleted. | ||||
| Deleting OAuth2 settings has to be done in the ui. | ||||
| All OAuth2 values, which are documented [here](https://docs.gitea.com/administration/command-line#admin), are | ||||
| All OAuth2 values, which are documented [under this link](https://docs.gitea.com/administration/command-line#admin), are | ||||
| available. | ||||
|  | ||||
| Multiple OAuth2 sources can be configured with additional OAuth list items. | ||||
| @@ -817,6 +817,31 @@ gitea: | ||||
|   podAnnotations: {} | ||||
| ``` | ||||
|  | ||||
| ## TLS certificate rotation | ||||
|  | ||||
| If Gitea uses TLS certificates that are mounted as a secret in the container file system, Gitea will not automatically apply them when the TLS certificates are rotated. | ||||
| Such a rotation can be for example triggered, when the cert-manager issues new TLS certificates before expiring. Further information is described as GitHub | ||||
| [issue](https://github.com/go-gitea/gitea/issues/27962). | ||||
|  | ||||
| Until the issue is present, a workaround can be applied. | ||||
| For example stakater's [reloader](https://github.com/stakater/Reloader) controller can be used to trigger a rolling update. | ||||
| The following annotation must be added to instruct the reloader controller to trigger a rolling update, when the mounted `configMaps` and `secrets` have been changed. | ||||
|  | ||||
| ```yaml | ||||
| deployment: | ||||
|   annotations: | ||||
|     reloader.stakater.com/auto: "true" | ||||
| ``` | ||||
|  | ||||
| Instead of triggering a rolling update for configMap and secret resources, this action can also be defined for individual items. | ||||
| For example, when the secret named `gitea-tls` is mounted and the reloader controller should only listen for changes of this secret: | ||||
|  | ||||
| ```yaml | ||||
| deployment: | ||||
|   annotations: | ||||
|     secret.reloader.stakater.com/reload: "gitea-tls" | ||||
| ``` | ||||
|  | ||||
| ## Themes | ||||
|  | ||||
| Custom themes can be added via k8s secrets and referencing them in `values.yaml`. | ||||
| @@ -991,16 +1016,15 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
|  | ||||
| ### Ingress | ||||
|  | ||||
| | Name                                 | Description                                                                 | Value             | | ||||
| | ------------------------------------ | --------------------------------------------------------------------------- | ----------------- | | ||||
| | `ingress.enabled`                    | Enable ingress                                                              | `false`           | | ||||
| | `ingress.className`                  | Ingress class name                                                          | `nil`             | | ||||
| | `ingress.annotations`                | Ingress annotations                                                         | `{}`              | | ||||
| | `ingress.hosts[0].host`              | Default Ingress host                                                        | `git.example.com` | | ||||
| | `ingress.hosts[0].paths[0].path`     | Default Ingress path                                                        | `/`               | | ||||
| | `ingress.hosts[0].paths[0].pathType` | Ingress path type                                                           | `Prefix`          | | ||||
| | `ingress.tls`                        | Ingress tls settings                                                        | `[]`              | | ||||
| | `ingress.apiVersion`                 | Specify APIVersion of ingress object. Mostly would only be used for argocd. |                   | | ||||
| | Name                             | Description                     | Value             | | ||||
| | -------------------------------- | ------------------------------- | ----------------- | | ||||
| | `ingress.enabled`                | Enable ingress                  | `false`           | | ||||
| | `ingress.className`              | DEPRECATED: Ingress class name. | `""`              | | ||||
| | `ingress.pathType`               | Ingress Path Type               | `Prefix`          | | ||||
| | `ingress.annotations`            | Ingress annotations             | `{}`              | | ||||
| | `ingress.hosts[0].host`          | Default Ingress host            | `git.example.com` | | ||||
| | `ingress.hosts[0].paths[0].path` | Default Ingress path            | `/`               | | ||||
| | `ingress.tls`                    | Ingress tls settings            | `[]`              | | ||||
|  | ||||
| ### deployment | ||||
|  | ||||
| @@ -1046,6 +1070,8 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
| | `persistence.subPath`                             | Subdirectory of the volume to mount at                                                                | `nil`                  | | ||||
| | `persistence.volumeName`                          | Name of persistent volume in PVC                                                                      | `""`                   | | ||||
| | `extraContainers`                                 | Additional sidecar containers to run in the pod                                                       | `[]`                   | | ||||
| | `preExtraInitContainers`                          | Additional init containers to run in the pod before Gitea runs it owns init containers.               | `[]`                   | | ||||
| | `postExtraInitContainers`                         | Additional init containers to run in the pod after Gitea runs it owns init containers.                | `[]`                   | | ||||
| | `extraVolumes`                                    | Additional volumes to mount to the Gitea deployment                                                   | `[]`                   | | ||||
| | `extraContainerVolumeMounts`                      | Mounts that are only mapped into the Gitea runtime/main container, to e.g. override custom templates. | `[]`                   | | ||||
| | `extraInitVolumeMounts`                           | Mounts that are only mapped into the init-containers. Can be used for additional preconfiguration.    | `[]`                   | | ||||
| @@ -1053,12 +1079,13 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
|  | ||||
| ### Init | ||||
|  | ||||
| | Name                                       | Description                                                                          | Value   | | ||||
| | ------------------------------------------ | ------------------------------------------------------------------------------------ | ------- | | ||||
| | `initPreScript`                            | Bash shell script copied verbatim to the start of the init-container.                | `""`    | | ||||
| | `initContainers.resources.limits`          | initContainers.limits Kubernetes resource limits for init containers                 | `{}`    | | ||||
| | `initContainers.resources.requests.cpu`    | initContainers.requests.cpu Kubernetes cpu resource limits for init containers       | `100m`  | | ||||
| | `initContainers.resources.requests.memory` | initContainers.requests.memory Kubernetes memory resource limits for init containers | `128Mi` | | ||||
| | Name                                       | Description                                                                          | Value        | | ||||
| | ------------------------------------------ | ------------------------------------------------------------------------------------ | ------------ | | ||||
| | `initPreScript`                            | Bash shell script copied verbatim to the start of the init-container.                | `""`         | | ||||
| | `initContainersScriptsVolumeMountPath`     | Path to mount the scripts consumed from the Secrets                                  | `/usr/sbinx` | | ||||
| | `initContainers.resources.limits`          | initContainers.limits Kubernetes resource limits for init containers                 | `{}`         | | ||||
| | `initContainers.resources.requests.cpu`    | initContainers.requests.cpu Kubernetes cpu resource limits for init containers       | `100m`       | | ||||
| | `initContainers.resources.requests.memory` | initContainers.requests.memory Kubernetes memory resource limits for init containers | `128Mi`      | | ||||
|  | ||||
| ### Signing | ||||
|  | ||||
| @@ -1069,44 +1096,6 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
| | `signing.privateKey`     | Inline private gpg key for signed internal Git activity           | `""`               | | ||||
| | `signing.existingSecret` | Use an existing secret to store the value of `signing.privateKey` | `""`               | | ||||
|  | ||||
| ### Gitea Actions | ||||
|  | ||||
| | Name                                              | Description                                                                                                                                 | Value                          | | ||||
| | ------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------ | | ||||
| | `actions.enabled`                                 | Create an act runner StatefulSet.                                                                                                           | `false`                        | | ||||
| | `actions.init.image.repository`                   | The image used for the init containers                                                                                                      | `busybox`                      | | ||||
| | `actions.init.image.tag`                          | The image tag used for the init containers                                                                                                  | `1.37.0`                       | | ||||
| | `actions.statefulset.annotations`                 | Act runner annotations                                                                                                                      | `{}`                           | | ||||
| | `actions.statefulset.labels`                      | Act runner labels                                                                                                                           | `{}`                           | | ||||
| | `actions.statefulset.resources`                   | Act runner resources                                                                                                                        | `{}`                           | | ||||
| | `actions.statefulset.nodeSelector`                | NodeSelector for the statefulset                                                                                                            | `{}`                           | | ||||
| | `actions.statefulset.tolerations`                 | Tolerations for the statefulset                                                                                                             | `[]`                           | | ||||
| | `actions.statefulset.affinity`                    | Affinity for the statefulset                                                                                                                | `{}`                           | | ||||
| | `actions.statefulset.extraVolumes`                | Extra volumes for the statefulset                                                                                                           | `[]`                           | | ||||
| | `actions.statefulset.actRunner.repository`        | The Gitea act runner image                                                                                                                  | `gitea/act_runner`             | | ||||
| | `actions.statefulset.actRunner.tag`               | The Gitea act runner tag                                                                                                                    | `0.2.11`                       | | ||||
| | `actions.statefulset.actRunner.pullPolicy`        | The Gitea act runner pullPolicy                                                                                                             | `IfNotPresent`                 | | ||||
| | `actions.statefulset.actRunner.extraVolumeMounts` | Allows mounting extra volumes in the act runner container                                                                                   | `[]`                           | | ||||
| | `actions.statefulset.actRunner.config`            | Act runner custom configuration. See [Act Runner documentation](https://docs.gitea.com/usage/actions/act-runner#configuration) for details. | `Too complex. See values.yaml` | | ||||
| | `actions.statefulset.dind.repository`             | The Docker-in-Docker image                                                                                                                  | `docker`                       | | ||||
| | `actions.statefulset.dind.tag`                    | The Docker-in-Docker image tag                                                                                                              | `25.0.2-dind`                  | | ||||
| | `actions.statefulset.dind.pullPolicy`             | The Docker-in-Docker pullPolicy                                                                                                             | `IfNotPresent`                 | | ||||
| | `actions.statefulset.dind.extraVolumeMounts`      | Allows mounting extra volumes in the Docker-in-Docker container                                                                             | `[]`                           | | ||||
| | `actions.statefulset.dind.extraEnvs`              | Allows adding custom environment variables, such as `DOCKER_IPTABLES_LEGACY`                                                                | `[]`                           | | ||||
| | `actions.provisioning.enabled`                    | Create a job that will create and save the token in a Kubernetes Secret                                                                     | `false`                        | | ||||
| | `actions.provisioning.annotations`                | Job's annotations                                                                                                                           | `{}`                           | | ||||
| | `actions.provisioning.labels`                     | Job's labels                                                                                                                                | `{}`                           | | ||||
| | `actions.provisioning.resources`                  | Job's resources                                                                                                                             | `{}`                           | | ||||
| | `actions.provisioning.nodeSelector`               | NodeSelector for the job                                                                                                                    | `{}`                           | | ||||
| | `actions.provisioning.tolerations`                | Tolerations for the job                                                                                                                     | `[]`                           | | ||||
| | `actions.provisioning.affinity`                   | Affinity for the job                                                                                                                        | `{}`                           | | ||||
| | `actions.provisioning.ttlSecondsAfterFinished`    | ttl for the job after finished in order to allow helm to properly recognize that the job completed                                          | `300`                          | | ||||
| | `actions.provisioning.publish.repository`         | The image that can create the secret via kubectl                                                                                            | `bitnami/kubectl`              | | ||||
| | `actions.provisioning.publish.tag`                | The publish image tag that can create the secret                                                                                            | `1.29.0`                       | | ||||
| | `actions.provisioning.publish.pullPolicy`         | The publish image pullPolicy that can create the secret                                                                                     | `IfNotPresent`                 | | ||||
| | `actions.existingSecret`                          | Secret that contains the token                                                                                                              | `""`                           | | ||||
| | `actions.existingSecretKey`                       | Secret key                                                                                                                                  | `""`                           | | ||||
|  | ||||
| ### Gitea | ||||
|  | ||||
| | Name                                         | Description                                                                                                                    | Value                | | ||||
| @@ -1169,27 +1158,41 @@ To comply with the Gitea helm chart definition of the digest parameter, a "custo | ||||
| | `gitea.startupProbe.successThreshold`    | Success threshold for startup probe             | `1`     | | ||||
| | `gitea.startupProbe.failureThreshold`    | Failure threshold for startup probe             | `10`    | | ||||
|  | ||||
| ### redis-cluster | ||||
| ### Network Policy | ||||
|  | ||||
| Redis cluster and [Redis](#redis) cannot be enabled at the same time. | ||||
| | Name                        | Description                                                               | Value   | | ||||
| | --------------------------- | ------------------------------------------------------------------------- | ------- | | ||||
| | `networkPolicy.enabled`     | Enable network policies in general.                                       | `false` | | ||||
| | `networkPolicy.annotations` | Additional network policy annotations.                                    | `{}`    | | ||||
| | `networkPolicy.labels`      | Additional network policy labels.                                         | `{}`    | | ||||
| | `networkPolicy.policyTypes` | List of policy types. Supported is ingress, egress or ingress and egress. | `[]`    | | ||||
| | `networkPolicy.egress`      | Concrete egress network policy implementation.                            | `[]`    | | ||||
| | `networkPolicy.ingress`     | Concrete ingress network policy implementation.                           | `[]`    | | ||||
|  | ||||
| | Name                             | Description                                  | Value   | | ||||
| | -------------------------------- | -------------------------------------------- | ------- | | ||||
| | `redis-cluster.enabled`          | Enable redis cluster                         | `true`  | | ||||
| | `redis-cluster.usePassword`      | Whether to use password authentication       | `false` | | ||||
| | `redis-cluster.cluster.nodes`    | Number of redis cluster master nodes         | `3`     | | ||||
| | `redis-cluster.cluster.replicas` | Number of redis cluster master node replicas | `0`     | | ||||
| ### valkey-cluster | ||||
|  | ||||
| ### redis | ||||
| Valkey cluster and [Valkey](#valkey) cannot be enabled at the same time. | ||||
|  | ||||
| Redis and [Redis cluster](#redis-cluster) cannot be enabled at the same time. | ||||
| | Name                                  | Description                                                          | Value   | | ||||
| | ------------------------------------- | -------------------------------------------------------------------- | ------- | | ||||
| | `valkey-cluster.enabled`              | Enable valkey cluster                                                | `true`  | | ||||
| | `valkey-cluster.usePassword`          | Whether to use password authentication                               | `false` | | ||||
| | `valkey-cluster.usePasswordFiles`     | Whether to mount passwords as files instead of environment variables | `false` | | ||||
| | `valkey-cluster.cluster.nodes`        | Number of valkey cluster master nodes                                | `3`     | | ||||
| | `valkey-cluster.cluster.replicas`     | Number of valkey cluster master node replicas                        | `0`     | | ||||
| | `valkey-cluster.service.ports.valkey` | Port of Valkey service                                               | `6379`  | | ||||
|  | ||||
| | Name                          | Description                                | Value        | | ||||
| | ----------------------------- | ------------------------------------------ | ------------ | | ||||
| | `redis.enabled`               | Enable redis standalone or replicated      | `false`      | | ||||
| | `redis.architecture`          | Whether to use standalone or replication   | `standalone` | | ||||
| | `redis.global.redis.password` | Required password                          | `changeme`   | | ||||
| | `redis.master.count`          | Number of Redis master instances to deploy | `1`          | | ||||
| ### valkey | ||||
|  | ||||
| Valkey and [Valkey cluster](#valkey-cluster) cannot be enabled at the same time. | ||||
|  | ||||
| | Name                                 | Description                                 | Value        | | ||||
| | ------------------------------------ | ------------------------------------------- | ------------ | | ||||
| | `valkey.enabled`                     | Enable valkey standalone or replicated      | `false`      | | ||||
| | `valkey.architecture`                | Whether to use standalone or replication    | `standalone` | | ||||
| | `valkey.global.valkey.password`      | Required password                           | `changeme`   | | ||||
| | `valkey.master.count`                | Number of Valkey master instances to deploy | `1`          | | ||||
| | `valkey.master.service.ports.valkey` | Port of Valkey service                      | `6379`       | | ||||
|  | ||||
| ### PostgreSQL HA | ||||
|  | ||||
| @@ -1203,6 +1206,7 @@ Redis and [Redis cluster](#redis-cluster) cannot be enabled at the same time. | ||||
| | `postgresql-ha.postgresql.repmgrPassword`   | Repmgr Password                                                  | `changeme2` | | ||||
| | `postgresql-ha.postgresql.postgresPassword` | postgres Password                                                | `changeme1` | | ||||
| | `postgresql-ha.pgpool.adminPassword`        | pgpool adminPassword                                             | `changeme3` | | ||||
| | `postgresql-ha.pgpool.srCheckPassword`      | pgpool srCheckPassword                                           | `changeme4` | | ||||
| | `postgresql-ha.service.ports.postgresql`    | PostgreSQL service port (overrides `service.ports.postgresql`)   | `5432`      | | ||||
| | `postgresql-ha.persistence.size`            | PVC Storage Request for PostgreSQL HA volume                     | `10Gi`      | | ||||
|  | ||||
| @@ -1241,6 +1245,31 @@ If you miss this, blindly upgrading may delete your Postgres instance and you ma | ||||
|  | ||||
| <details> | ||||
|  | ||||
| <summary>To 12.0.0</summary> | ||||
|  | ||||
| <!-- prettier-ignore-start --> | ||||
| <!-- markdownlint-disable-next-line --> | ||||
| **Breaking changes** | ||||
| <!-- prettier-ignore-end --> | ||||
|  | ||||
| - Outsourced "Actions" related configuration. | ||||
|   To deploy and use "Actions", please see the new dedicated chart at <https://gitea.com/gitea/helm-actions>. | ||||
|   It is maintained by a seperate maintainer group and hasn't seen a release yet (at the time of the 12.0 release). | ||||
|   Feel encouraged to contribute if "Actions" is important to you! | ||||
|  | ||||
|   This change was made to avoid overloading the existing helm chart, which is already quite large in size and configuration options. | ||||
|   In addition, the existing maintainers team was not actively using "Actions" which slowed down development and community contributions. | ||||
|   While the new chart is still young (and waiting for contributions! and maintainers), we believe that it is the best way moving forward for both parts. | ||||
| - Migrated from Redis/Redis-cluster to Valkey/Valkey-cluster charts (#775). | ||||
|   While marked as breaking, there is no need to migrate data. | ||||
|   The cache will start to refill automatically. | ||||
| - Migrated ingress from `networking.k8s.io/v1beta` to `networking.k8s.io/v1`. | ||||
|   We didn't make any changes to the syntax, so the upgrade should be seamless. | ||||
|  | ||||
| </details> | ||||
|  | ||||
| <details> | ||||
|  | ||||
| <summary>To 11.0.0</summary> | ||||
|  | ||||
| <!-- prettier-ignore-start --> | ||||
| @@ -1258,8 +1287,7 @@ If you miss this, blindly upgrading may delete your Postgres instance and you ma | ||||
|   Although there are no breaking changes in the Redis Chart itself, it updates Redis from `7.2` to `7.4`. We recommend checking the release notes: | ||||
|   - [Redis Chart release notes (starting with v11.0.0)](https://github.com/bitnami/charts/blob/HEAD/bitnami/redis-cluster/CHANGELOG.md#1100-2024-08-09). | ||||
|   - [Redis 7.4 release notes](https://raw.githubusercontent.com/redis/redis/7.4/00-RELEASENOTES). | ||||
|  | ||||
| </details> | ||||
|   </details> | ||||
|  | ||||
| <details> | ||||
|  | ||||
| @@ -1336,16 +1364,16 @@ gitea: | ||||
|   config: | ||||
|     session: | ||||
|       PROVIDER: redis-cluster | ||||
|       PROVIDER_CONFIG: redis+cluster://:gitea@gitea-redis-cluster-headless.<namespace>.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|       PROVIDER_CONFIG: redis+cluster://:gitea@gitea-valkey-cluster-headless.<namespace>.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|  | ||||
|     cache: | ||||
|       ENABLED: true | ||||
|       ADAPTER: redis-cluster | ||||
|       HOST: redis+cluster://:gitea@gitea-redis-cluster-headless.<namespace>.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|       HOST: redis+cluster://:gitea@gitea-valkey-cluster-headless.<namespace>.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|  | ||||
|     queue: | ||||
|       TYPE: redis | ||||
|       CONN_STR: redis+cluster://:gitea@gitea-redis-cluster-headless.<namespace>.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|       CONN_STR: redis+cluster://:gitea@gitea-valkey-cluster-headless.<namespace>.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
| ``` | ||||
|  | ||||
| <!-- prettier-ignore-start --> | ||||
|   | ||||
| @@ -1,34 +0,0 @@ | ||||
| # Gitea Actions | ||||
|  | ||||
| In order to use the Gitea Actions act-runner you must either: | ||||
|  | ||||
| - enable persistence (used for automatic deployment to be able to store the token in a place accessible for the Job) | ||||
| - create a secret containing the act runner token and reference it as a `existingSecret` | ||||
|  | ||||
| In order to use Gitea Actions, you must log on the server that's running Gitea and run the command: | ||||
|     `gitea actions generate-runner-token` | ||||
|  | ||||
| This command will out a token that is needed by the act-runner to register with the Gitea backend. | ||||
|  | ||||
| Because this is a manual operation, we automated this using a Kubernetes Job using the following containers: | ||||
|  | ||||
| 1) `actions-token-create`: it uses the current `gitea-rootless` image, mounts the persistent directory to `/data/` then it saves the output from `gitea actions generate-runner-token` to `/data/actions/token` | ||||
| 2) `actions-token-upload`: it uses a `bitnami/kubectl` image, mounts the scripts directory (`/scripts`) and | ||||
| the persistent directory (`/data/`), and using the script from `/scripts/token.sh` stores the token in a Kubernetes secret | ||||
|  | ||||
| After the token is stored in a Kubernetes secret we can create the statefulset that contains the following containers: | ||||
|  | ||||
| 1) `act-runner`: authenticates with Gitea using the token that was stored in the secret | ||||
| 2) `dind`: DockerInDocker image that is used to run the actions | ||||
|  | ||||
| If you are not using persistent volumes, you cannot use the Job to automatically generate the token. | ||||
| In this case, you can use either the Web UI to generate the token or run a shell into a Gitea pod and invoke | ||||
| the command `gitea actions generate-runner-token`. After generating the token, you must create a secret and use it via: | ||||
|  | ||||
| ```yaml | ||||
| actions: | ||||
|   provisioning: | ||||
|     enabled: false | ||||
|   existingSecret: "secret-name" | ||||
|   existingSecretKey: "secret-key" | ||||
| ``` | ||||
| @@ -25,7 +25,7 @@ In addition, the following components are required for full HA-readiness: | ||||
|  | ||||
| - A HA-ready issue (and optionally code) indexer: `elasticsearch` or `meilisearch` | ||||
| - A HA-ready external object/asset storage (`minio`) (optional, assets can also be stored on the RWX file-system) | ||||
| - A HA-ready cache (`redis-cluster`) | ||||
| - A HA-ready cache (`valkey-cluster`) | ||||
| - A HA-ready DB | ||||
|  | ||||
| `postgres.enabled`, which default to `true`, must be set to `false` for a HA setup. | ||||
| @@ -72,33 +72,33 @@ persistence: | ||||
|  | ||||
| ## Cache, session and queue | ||||
|  | ||||
| A `redis` instance is required for the in-memory cache. | ||||
| A `valkey` instance is required for the in-memory cache. | ||||
| Two options exist: | ||||
|  | ||||
| - `redis` | ||||
| - `redis-cluster` | ||||
| - `valkey` | ||||
| - `valkey-cluster` | ||||
|  | ||||
| The chart provides `redis-cluster` as a dependency as this one can be used for both HA and non-HA setups. | ||||
| You're also welcome to go with `redis` if you prefer or already have a running instance. | ||||
| The chart provides `valkey-cluster` as a dependency as this one can be used for both HA and non-HA setups. | ||||
| You're also welcome to go with `valkey` if you prefer or already have a running instance. | ||||
|  | ||||
| It should be noted that `redis-cluster` support is only available starting with Gitea 1.19.2. | ||||
| You can also configure an external (managed) `redis` instance to be used. | ||||
| It should be noted that `valkey-cluster` support is only available starting with Gitea 1.19.2. | ||||
| You can also configure an external (managed) `valkey` instance to be used. | ||||
| To do so, you need to set the following configuration values yourself: | ||||
|  | ||||
| - `gitea.config.queue.TYPE`: redis` | ||||
| - `gitea.config.queue.CONN_STR`: `<your redis connection string>` | ||||
| - `gitea.config.queue.TYPE`: valkey` | ||||
| - `gitea.config.queue.CONN_STR`: `<your valkey connection string>` | ||||
|  | ||||
| - `gitea.config.session.PROVIDER`: `redis` | ||||
| - `gitea.config.session.PROVIDER_CONFIG`: `<your redis connection string>` | ||||
| - `gitea.config.session.PROVIDER`: `valkey` | ||||
| - `gitea.config.session.PROVIDER_CONFIG`: `<your valkey connection string>` | ||||
|  | ||||
| - `gitea.config.cache.ENABLED`: `true` | ||||
| - `gitea.config.cache.ADAPTER`: `redis` | ||||
| - `gitea.config.cache.HOST`: `<your redis connection string>` | ||||
| - `gitea.config.cache.ADAPTER`: `valkey` | ||||
| - `gitea.config.cache.HOST`: `<your valkey connection string>` | ||||
|  | ||||
| By default, the `redis-cluster` chart provisions three standalone master nodes of which each has a single replica. | ||||
| By default, the `valkey-cluster` chart provisions three standalone master nodes of which each has a single replica. | ||||
| To reduce the number of pods for a default Gitea deployment, we opted to omit the replicas (`replicas: 0`) by default. | ||||
| Only the minimum required number of master pods for a functional `redis-cluster` deployment are provisioned. | ||||
| For a "proper" `redis-cluster` setup however, we recommend to set `replicas: 1` and `nodes: 6`. | ||||
| Only the minimum required number of master pods for a functional `valkey-cluster` deployment are provisioned. | ||||
| For a "proper" `valkey-cluster` setup however, we recommend to set `replicas: 1` and `nodes: 6`. | ||||
|  | ||||
| ## Object and asset storage | ||||
|  | ||||
|   | ||||
							
								
								
									
										1295
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1295
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -9,11 +9,13 @@ | ||||
|     "npm": ">=8.0.0" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "readme:link": "markdown-link-check --config .markdownlink.json *.md", | ||||
|     "readme:lint": "markdownlint *.md -f", | ||||
|     "readme:parameters": "readme-generator -v values.yaml -r README.md" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@bitnami/readme-generator-for-helm": "^2.5.0", | ||||
|     "markdownlint-cli": "^0.44.0" | ||||
|     "markdown-link-check": "^3.13.6", | ||||
|     "markdownlint-cli": "^0.45.0" | ||||
|   } | ||||
| } | ||||
| @@ -9,19 +9,19 @@ | ||||
|   labels: [ | ||||
|     'kind/dependency', | ||||
|   ], | ||||
|   "digest": { | ||||
|     "automerge": true | ||||
|   digest: { | ||||
|     automerge: true, | ||||
|   }, | ||||
|   automergeStrategy: 'squash', | ||||
|   'git-submodules': { | ||||
|     'enabled': true | ||||
|     enabled: true, | ||||
|   }, | ||||
|   customManagers: [ | ||||
|     { | ||||
|       description: 'Gitea-version of https://docs.renovatebot.com/presets-regexManagers/#regexmanagersgithubactionsversions', | ||||
|       customType: 'regex', | ||||
|       fileMatch: [ | ||||
|         '.gitea/workflows/.+\\.ya?ml$', | ||||
|       managerFilePatterns: [ | ||||
|         '/.gitea/workflows/.+\\.ya?ml$/', | ||||
|       ], | ||||
|       matchStrings: [ | ||||
|         '# renovate: datasource=(?<datasource>[a-z-.]+?) depName=(?<depName>[^\\s]+?)(?: (?:lookupName|packageName)=(?<packageName>[^\\s]+?))?(?: versioning=(?<versioning>[a-z-0-9]+?))?\\s+[A-Za-z0-9_]+?_VERSION\\s*:\\s*["\']?(?<currentValue>.+?)["\']?\\s', | ||||
| @@ -30,21 +30,33 @@ | ||||
|     { | ||||
|       description: 'Detect helm-unittest yaml schema file', | ||||
|       customType: 'regex', | ||||
|       fileMatch: ['.vscode/settings\\.json$'], | ||||
|       managerFilePatterns: [ | ||||
|         '/.vscode/settings\\.json$/', | ||||
|       ], | ||||
|       matchStrings: [ | ||||
|         'https:\\/\\/raw\\.githubusercontent\\.com\\/(?<depName>[^\\s]+?)\\/(?<currentValue>v[0-9.]+?)\\/schema\\/helm-testsuite\\.json', | ||||
|       ], | ||||
|       datasourceTemplate: 'github-releases', | ||||
|     }, | ||||
|     { | ||||
|       'description': 'Automatically detect new Gitea releases', | ||||
|       'customType': 'regex', | ||||
|       'fileMatch': ['(^|/)Chart\\.yaml$'], | ||||
|       'matchStrings': [ | ||||
|       description: 'Automatically detect new Gitea releases', | ||||
|       customType: 'regex', | ||||
|       managerFilePatterns: [ | ||||
|         '/(^|/)Chart\\.yaml$/', | ||||
|       ], | ||||
|       matchStrings: [ | ||||
|         '# renovate datasource=(?<datasource>\\S+) depName=(?<depName>\\S+) extractVersion=(?<extractVersion>\\S+)\\nappVersion:\\s?(?<currentValue>\\S+)\\n', | ||||
|       ], | ||||
|     }, | ||||
|   ], | ||||
|   lockFileMaintenance: { | ||||
|     "enabled": true, | ||||
|     "commitMessageAction": "update", | ||||
|     "commitMessageTopic": "lockfiles", | ||||
|     schedule: [ | ||||
|       'at any time', | ||||
|     ] | ||||
|   }, | ||||
|   packageRules: [ | ||||
|     { | ||||
|       groupName: 'subcharts (minor & patch)', | ||||
| @@ -57,6 +69,17 @@ | ||||
|         'digest', | ||||
|       ], | ||||
|     }, | ||||
|     { | ||||
|       groupName: 'bats testing framework', | ||||
|       matchManagers: [ | ||||
|         'git-submodules', | ||||
|       ], | ||||
|       matchUpdateTypes: [ | ||||
|         'minor', | ||||
|         'patch', | ||||
|         'digest', | ||||
|       ], | ||||
|     }, | ||||
|     { | ||||
|       groupName: 'workflow dependencies (minor & patch)', | ||||
|       matchManagers: [ | ||||
| @@ -101,7 +124,9 @@ | ||||
|       matchDepNames: [ | ||||
|         'go-gitea/gitea', | ||||
|       ], | ||||
|       schedule: ['at any time'], | ||||
|       schedule: [ | ||||
|         'at any time', | ||||
|       ], | ||||
|     }, | ||||
|   ], | ||||
| } | ||||
|   | ||||
| @@ -87,6 +87,12 @@ storageClassName: {{ $storageClass | quote }} | ||||
| {{- end }} | ||||
| {{- end -}} | ||||
|  | ||||
| {{/* | ||||
| Common annotations | ||||
| */}} | ||||
| {{- define "gitea.annotations" -}} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* | ||||
| Common labels | ||||
| */}} | ||||
| @@ -133,29 +139,29 @@ app.kubernetes.io/instance: {{ .Release.Name }} | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "redis.dns" -}} | ||||
| {{- if and ((index .Values "redis-cluster").enabled) ((index .Values "redis").enabled) -}} | ||||
| {{- fail "redis and redis-cluster cannot be enabled at the same time. Please only choose one." -}} | ||||
| {{- else if (index .Values "redis-cluster").enabled -}} | ||||
| {{- printf "redis+cluster://:%s@%s-redis-cluster-headless.%s.svc.%s:%g/0?pool_size=100&idle_timeout=180s&" (index .Values "redis-cluster").global.redis.password .Release.Name .Release.Namespace .Values.clusterDomain (index .Values "redis-cluster").service.ports.redis -}} | ||||
| {{- else if (index .Values "redis").enabled -}} | ||||
| {{- printf "redis://:%s@%s-redis-headless.%s.svc.%s:%g/0?pool_size=100&idle_timeout=180s&" (index .Values "redis").global.redis.password .Release.Name .Release.Namespace .Values.clusterDomain (index .Values "redis").master.service.ports.redis -}} | ||||
| {{- define "valkey.dns" -}} | ||||
| {{- if and ((index .Values "valkey-cluster").enabled) ((index .Values "valkey").enabled) -}} | ||||
| {{- fail "valkey and valkey-cluster cannot be enabled at the same time. Please only choose one." -}} | ||||
| {{- else if (index .Values "valkey-cluster").enabled -}} | ||||
| {{- printf "redis+cluster://:%s@%s-valkey-cluster-headless.%s.svc.%s:%g/0?pool_size=100&idle_timeout=180s&" (index .Values "valkey-cluster").global.valkey.password .Release.Name .Release.Namespace .Values.clusterDomain (index .Values "valkey-cluster").service.ports.valkey -}} | ||||
| {{- else if (index .Values "valkey").enabled -}} | ||||
| {{- printf "redis://:%s@%s-valkey-headless.%s.svc.%s:%g/0?pool_size=100&idle_timeout=180s&" (index .Values "valkey").global.valkey.password .Release.Name .Release.Namespace .Values.clusterDomain (index .Values "valkey").master.service.ports.valkey -}} | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "redis.port" -}} | ||||
| {{- if (index .Values "redis-cluster").enabled -}} | ||||
| {{ (index .Values "redis-cluster").service.ports.redis }} | ||||
| {{- else if (index .Values "redis").enabled -}} | ||||
| {{ (index .Values "redis").master.service.ports.redis }} | ||||
| {{- define "valkey.port" -}} | ||||
| {{- if (index .Values "valkey-cluster").enabled -}} | ||||
| {{ (index .Values "valkey-cluster").service.ports.valkey }} | ||||
| {{- else if (index .Values "valkey").enabled -}} | ||||
| {{ (index .Values "valkey").master.service.ports.valkey }} | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "redis.servicename" -}} | ||||
| {{- if (index .Values "redis-cluster").enabled -}} | ||||
| {{- printf "%s-redis-cluster-headless.%s.svc.%s" .Release.Name .Release.Namespace .Values.clusterDomain -}} | ||||
| {{- else if (index .Values "redis").enabled -}} | ||||
| {{- printf "%s-redis-headless.%s.svc.%s" .Release.Name .Release.Namespace .Values.clusterDomain -}} | ||||
| {{- define "valkey.servicename" -}} | ||||
| {{- if (index .Values "valkey-cluster").enabled -}} | ||||
| {{- printf "%s-valkey-cluster-headless.%s.svc.%s" .Release.Name .Release.Namespace .Values.clusterDomain -}} | ||||
| {{- else if (index .Values "valkey").enabled -}} | ||||
| {{- printf "%s-valkey-headless.%s.svc.%s" .Release.Name .Release.Namespace .Values.clusterDomain -}} | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| @@ -220,15 +226,6 @@ https | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "gitea.act_runner.local_root_url" -}} | ||||
| {{- if not .Values.gitea.config.server.LOCAL_ROOT_URL -}} | ||||
|     {{- printf "http://%s-http:%.0f" (include "gitea.fullname" .) .Values.service.http.port -}} | ||||
| {{- else -}} | ||||
|   {{/* fallback for allowing to overwrite this value via inline config */}} | ||||
|   {{- .Values.gitea.config.server.LOCAL_ROOT_URL -}} | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "gitea.inline_configuration" -}} | ||||
|   {{- include "gitea.inline_configuration.init" . -}} | ||||
|   {{- include "gitea.inline_configuration.defaults" . -}} | ||||
| @@ -314,14 +311,14 @@ https | ||||
|   {{- if and (not (hasKey .Values.gitea.config.metrics "TOKEN")) (.Values.gitea.metrics.token) (.Values.gitea.metrics.enabled) -}} | ||||
|     {{- $_ := set .Values.gitea.config.metrics "TOKEN" .Values.gitea.metrics.token -}} | ||||
|   {{- end -}} | ||||
|   {{- /* redis queue */ -}} | ||||
|   {{- if or ((index .Values "redis-cluster").enabled) ((index .Values "redis").enabled) -}} | ||||
|   {{- /* valkey queue */ -}} | ||||
|   {{- if or ((index .Values "valkey-cluster").enabled) ((index .Values "valkey").enabled) -}} | ||||
|     {{- $_ := set .Values.gitea.config.queue "TYPE" "redis" -}} | ||||
|     {{- $_ := set .Values.gitea.config.queue "CONN_STR" (include "redis.dns" .) -}} | ||||
|     {{- $_ := set .Values.gitea.config.queue "CONN_STR" (include "valkey.dns" .) -}} | ||||
|     {{- $_ := set .Values.gitea.config.session "PROVIDER" "redis" -}} | ||||
|     {{- $_ := set .Values.gitea.config.session "PROVIDER_CONFIG" (include "redis.dns" .) -}} | ||||
|     {{- $_ := set .Values.gitea.config.session "PROVIDER_CONFIG" (include "valkey.dns" .) -}} | ||||
|     {{- $_ := set .Values.gitea.config.cache "ADAPTER" "redis" -}} | ||||
|     {{- $_ := set .Values.gitea.config.cache "HOST" (include "redis.dns" .) -}} | ||||
|     {{- $_ := set .Values.gitea.config.cache "HOST" (include "valkey.dns" .) -}} | ||||
|   {{- else -}} | ||||
|     {{- if not (get .Values.gitea.config.session "PROVIDER") -}} | ||||
|       {{- $_ := set .Values.gitea.config.session "PROVIDER" "memory" -}} | ||||
| @@ -345,9 +342,6 @@ https | ||||
|   {{- if not .Values.gitea.config.indexer.ISSUE_INDEXER_TYPE -}} | ||||
|      {{- $_ := set .Values.gitea.config.indexer "ISSUE_INDEXER_TYPE" "db" -}} | ||||
|   {{- end -}} | ||||
|   {{- if not .Values.gitea.config.actions.ENABLED -}} | ||||
|      {{- $_ := set .Values.gitea.config.actions "ENABLED" (ternary "true" "false" .Values.actions.enabled) -}} | ||||
|   {{- end -}} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "gitea.inline_configuration.defaults.server" -}} | ||||
| @@ -367,25 +361,24 @@ https | ||||
|   {{- if not .Values.gitea.config.server.ROOT_URL -}} | ||||
|     {{- $_ := set .Values.gitea.config.server "ROOT_URL" (printf "%s://%s" (include "gitea.public_protocol" .) .Values.gitea.config.server.DOMAIN) -}} | ||||
|   {{- end -}} | ||||
|   {{- if .Values.actions.enabled -}} | ||||
|      {{- $_ := set .Values.gitea.config.server "LOCAL_ROOT_URL" (include "gitea.act_runner.local_root_url" .) -}} | ||||
|   {{- end -}} | ||||
|   {{- if not .Values.gitea.config.server.SSH_DOMAIN -}} | ||||
|     {{- $_ := set .Values.gitea.config.server "SSH_DOMAIN" .Values.gitea.config.server.DOMAIN -}} | ||||
|   {{- end -}} | ||||
|   {{- if not .Values.gitea.config.server.SSH_PORT -}} | ||||
|     {{- $_ := set .Values.gitea.config.server "SSH_PORT" .Values.service.ssh.port -}} | ||||
|   {{- end -}} | ||||
|   {{- if not (hasKey .Values.gitea.config.server "SSH_LISTEN_PORT") -}} | ||||
|     {{- if not .Values.image.rootless -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" .Values.gitea.config.server.SSH_PORT -}} | ||||
|     {{- else -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" "2222" -}} | ||||
|     {{- end -}} | ||||
|   {{- end -}} | ||||
|   {{- if not (hasKey .Values.gitea.config.server "START_SSH_SERVER") -}} | ||||
|     {{- if .Values.image.rootless -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "START_SSH_SERVER" "true" -}} | ||||
|       {{- if not (hasKey .Values.gitea.config.server "SSH_LISTEN_PORT") -}} | ||||
|         {{- if not .Values.gitea.config.server.SSH_LISTEN_PORT -}} | ||||
|           {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" .Values.gitea.config.server.SSH_PORT -}} | ||||
|         {{- else -}} | ||||
|           {{- $_ := set .Values.gitea.config.server "SSH_LISTEN_PORT" .Values.gitea.config.server.SSH_LISTEN_PORT -}} | ||||
|         {{- end -}} | ||||
|       {{- end -}} | ||||
|     {{- else -}} | ||||
|       {{- $_ := set .Values.gitea.config.server "START_SSH_SERVER" "false" -}} | ||||
|     {{- end -}} | ||||
|   {{- end -}} | ||||
|   {{- if not (hasKey .Values.gitea.config.server "APP_DATA_PATH") -}} | ||||
| @@ -443,6 +436,18 @@ https | ||||
| {{ .Values.serviceAccount.name | default (include "gitea.fullname" .) }} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "ingress.annotations" -}} | ||||
|   {{- if .Values.ingress.annotations }} | ||||
|   annotations: | ||||
|     {{- $tp := typeOf .Values.ingress.annotations }} | ||||
|     {{- if eq $tp "string" }} | ||||
|       {{- tpl .Values.ingress.annotations . | nindent 4 }} | ||||
|     {{- else }} | ||||
|       {{- toYaml .Values.ingress.annotations | nindent 4 }} | ||||
|     {{- end }} | ||||
|   {{- end }} | ||||
| {{- end -}} | ||||
|  | ||||
| {{- define "gitea.admin.passwordMode" -}} | ||||
| {{- if has .Values.gitea.admin.passwordMode (tuple "keepUpdated" "initialOnlyNoReset" "initialOnlyRequireReset") -}} | ||||
| {{ .Values.gitea.admin.passwordMode }} | ||||
| @@ -471,4 +476,4 @@ https | ||||
|  | ||||
| {{- define "gitea.metrics-secret-name" -}} | ||||
| {{ default (printf "%s-metrics-secret" (include "gitea.fullname" .)) }} | ||||
| {{- end -}} | ||||
| {{- end -}} | ||||
|   | ||||
							
								
								
									
										19
									
								
								templates/_networkPolicy.tpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								templates/_networkPolicy.tpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| {{/* vim: set filetype=mustache: */}} | ||||
|  | ||||
| {{/* annotations */}} | ||||
|  | ||||
| {{- define "gitea.networkPolicy.annotations" -}} | ||||
| {{ include "gitea.annotations" . }} | ||||
| {{- if .Values.networkPolicy.annotations }} | ||||
| {{ toYaml .Values.networkPolicy.annotations }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
|  | ||||
| {{/* labels */}} | ||||
|  | ||||
| {{- define "gitea.networkPolicy.labels" -}} | ||||
| {{ include "gitea.labels" . }} | ||||
| {{- if .Values.networkPolicy.labels }} | ||||
| {{ toYaml .Values.networkPolicy.labels }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
							
								
								
									
										17
									
								
								templates/_pod.tpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								templates/_pod.tpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| --- | ||||
|  | ||||
| {{/* labels */}} | ||||
|  | ||||
| {{- define "gitea.pod.labels" -}} | ||||
| {{- include "gitea.labels" . }} | ||||
| {{- if .Values.deployment.labels }} | ||||
| {{ toYaml .Values.deployment.labels }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
|  | ||||
| {{- define "gitea.pod.selectorLabels" -}} | ||||
| {{- include "gitea.selectorLabels" . }} | ||||
| {{- if .Values.deployment.labels }} | ||||
| {{ toYaml .Values.deployment.labels }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
							
								
								
									
										3
									
								
								templates/check-actions-not-present.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								templates/check-actions-not-present.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| {{- if .Values.actions -}} | ||||
|     {{- fail "The actions sub-chart has been outsourced to a dedicated chart available at https://gitea.com/gitea/helm-actions. For assistance with the migration process, check https://gitea.com/gitea/helm-actions/issues/9." -}} | ||||
| {{- end -}} | ||||
| @@ -27,7 +27,7 @@ stringData: | ||||
|     {{- end }} | ||||
|      | ||||
|     {{- /* multiple replicas assertions */ -}} | ||||
|     {{- if gt .Values.replicaCount 1.0 -}} | ||||
|     {{- if gt (.Values.replicaCount | int) 1 -}} | ||||
|       {{- if .Values.gitea.config.cron -}} | ||||
|         {{- if .Values.gitea.config.cron.GIT_GC_REPOS -}} | ||||
|           {{- if eq .Values.gitea.config.cron.GIT_GC_REPOS.ENABLED true -}} | ||||
| @@ -23,14 +23,11 @@ spec: | ||||
|     {{- end }} | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       {{- include "gitea.selectorLabels" . | nindent 6 }} | ||||
|       {{- if .Values.deployment.labels }} | ||||
|       {{- toYaml .Values.deployment.labels | nindent 6 }} | ||||
|       {{- end }} | ||||
|       {{- include "gitea.pod.selectorLabels" . | nindent 6 }} | ||||
|   template: | ||||
|     metadata: | ||||
|       annotations: | ||||
|         checksum/config: {{ include (print $.Template.BasePath "/gitea/config.yaml") . | sha256sum }} | ||||
|         checksum/config: {{ include (print $.Template.BasePath "/config.yaml") . | sha256sum }} | ||||
|         {{- range $idx, $value := .Values.gitea.ldap }} | ||||
|         checksum/ldap_{{ $idx }}: {{ include "gitea.ldap_settings" (list $idx $value) | sha256sum }} | ||||
|         {{- end }} | ||||
| @@ -41,10 +38,7 @@ spec: | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|         {{- end }} | ||||
|       labels: | ||||
|         {{- include "gitea.labels" . | nindent 8 }} | ||||
|         {{- if .Values.deployment.labels }} | ||||
|         {{- toYaml .Values.deployment.labels | nindent 8 }} | ||||
|         {{- end }} | ||||
|         {{- include "gitea.pod.labels" . | nindent 8 }} | ||||
|     spec: | ||||
|       {{- if .Values.schedulerName }} | ||||
|       schedulerName: "{{ .Values.schedulerName }}" | ||||
| @@ -59,10 +53,14 @@ spec: | ||||
|       securityContext: | ||||
|         {{- toYaml .Values.podSecurityContext | nindent 8 }} | ||||
|       initContainers: | ||||
|         {{- if .Values.preExtraInitContainers }} | ||||
|         {{- toYaml .Values.preExtraInitContainers | nindent 8 }} | ||||
|         {{- end }} | ||||
|         - name: init-directories | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
|           command: ["/usr/sbin/init_directory_structure.sh"] | ||||
|           command: | ||||
|             - "{{ .Values.initContainersScriptsVolumeMountPath }}/init_directory_structure.sh" | ||||
|           env: | ||||
|             - name: GITEA_APP_INI | ||||
|               value: /data/gitea/conf/app.ini | ||||
| @@ -81,7 +79,7 @@ spec: | ||||
|             {{- end }} | ||||
|           volumeMounts: | ||||
|             - name: init | ||||
|               mountPath: /usr/sbin | ||||
|               mountPath: {{ .Values.initContainersScriptsVolumeMountPath }} | ||||
|             - name: temp | ||||
|               mountPath: /tmp | ||||
|             - name: data | ||||
| @@ -97,7 +95,8 @@ spec: | ||||
|         - name: init-app-ini | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
|           command: ["/usr/sbin/config_environment.sh"] | ||||
|           command: | ||||
|           - "{{ .Values.initContainersScriptsVolumeMountPath }}/config_environment.sh" | ||||
|           env: | ||||
|             - name: GITEA_APP_INI | ||||
|               value: /data/gitea/conf/app.ini | ||||
| @@ -115,11 +114,11 @@ spec: | ||||
|             {{- toYaml .Values.deployment.env | nindent 12 }} | ||||
|             {{- end }} | ||||
|             {{- if .Values.gitea.additionalConfigFromEnvs }} | ||||
|             {{- toYaml .Values.gitea.additionalConfigFromEnvs | nindent 12 }} | ||||
|             {{- tpl (toYaml .Values.gitea.additionalConfigFromEnvs) $ | nindent 12 }} | ||||
|             {{- end }} | ||||
|           volumeMounts: | ||||
|             - name: config | ||||
|               mountPath: /usr/sbin | ||||
|               mountPath: {{ .Values.initContainersScriptsVolumeMountPath }} | ||||
|             - name: temp | ||||
|               mountPath: /tmp | ||||
|             - name: data | ||||
| @@ -141,7 +140,8 @@ spec: | ||||
|         {{- if .Values.signing.enabled }} | ||||
|         - name: configure-gpg | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           command: ["/usr/sbin/configure_gpg_environment.sh"] | ||||
|           command: | ||||
|           - "{{ .Values.initContainersScriptsVolumeMountPath }}/configure_gpg_environment.sh" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
|           securityContext: | ||||
|             {{- /* By default this container runs as user 1000 unless otherwise stated */ -}} | ||||
| @@ -157,7 +157,7 @@ spec: | ||||
|               value: /raw/private.asc | ||||
|           volumeMounts: | ||||
|             - name: init | ||||
|               mountPath: /usr/sbin | ||||
|               mountPath: {{ .Values.initContainersScriptsVolumeMountPath }} | ||||
|             - name: data | ||||
|               mountPath: /data | ||||
|               {{- if .Values.persistence.subPath }} | ||||
| @@ -174,7 +174,8 @@ spec: | ||||
|         {{- end }} | ||||
|         - name: configure-gitea | ||||
|           image: "{{ include "gitea.image" . }}" | ||||
|           command: ["/usr/sbin/configure_gitea.sh"] | ||||
|           command: | ||||
|           - "{{ .Values.initContainersScriptsVolumeMountPath }}/configure_gitea.sh" | ||||
|           imagePullPolicy: {{ .Values.image.pullPolicy }} | ||||
|           securityContext: | ||||
|             {{- /* By default this container runs as user 1000 unless otherwise stated */ -}} | ||||
| @@ -257,7 +258,7 @@ spec: | ||||
|             {{- end }} | ||||
|           volumeMounts: | ||||
|             - name: init | ||||
|               mountPath: /usr/sbin | ||||
|               mountPath: {{ .Values.initContainersScriptsVolumeMountPath }} | ||||
|             - name: temp | ||||
|               mountPath: /tmp | ||||
|             - name: data | ||||
| @@ -268,6 +269,9 @@ spec: | ||||
|             {{- include "gitea.init-additional-mounts" . | nindent 12 }} | ||||
|           resources: | ||||
|             {{- toYaml .Values.initContainers.resources | nindent 12 }} | ||||
|         {{- if .Values.postExtraInitContainers }} | ||||
|         {{- toYaml .Values.postExtraInitContainers | nindent 8 }} | ||||
|         {{- end }} | ||||
|       terminationGracePeriodSeconds: {{ .Values.deployment.terminationGracePeriodSeconds }} | ||||
|       containers: | ||||
|         - name: {{ .Chart.Name }} | ||||
| @@ -1,15 +0,0 @@ | ||||
| {{- if .Values.actions.enabled -}} | ||||
|     {{- if .Values.actions.provisioning.enabled -}} | ||||
|         {{- if not (and .Values.persistence.enabled .Values.persistence.mount) -}} | ||||
|             {{- fail "persistence.enabled and persistence.mount are required when provisioning is enabled" -}} | ||||
|         {{- end -}} | ||||
|         {{- if and .Values.persistence.enabled .Values.persistence.mount -}} | ||||
|             {{- if .Values.actions.existingSecret -}} | ||||
|                 {{- fail "Can't specify both actions.provisioning.enabled and actions.existingSecret" -}} | ||||
|             {{- end -}} | ||||
|         {{- end -}} | ||||
|     {{- end -}} | ||||
|     {{- if and (not .Values.actions.provisioning.enabled) (or (empty .Values.actions.existingSecret) (empty .Values.actions.existingSecretKey)) -}} | ||||
|         {{- fail "actions.existingSecret and actions.existingSecretKey are required when provisioning is disabled" -}} | ||||
|     {{- end -}} | ||||
| {{- end -}} | ||||
| @@ -1,15 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| --- | ||||
| apiVersion: v1 | ||||
| kind: ConfigMap | ||||
| metadata: | ||||
|   name: {{ include "gitea.fullname" . }}-act-runner-config | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
|     {{- include "gitea.labels" . | nindent 4 }} | ||||
| data: | ||||
|   config.yaml: | | ||||
|     {{- with .Values.actions.statefulset.actRunner.config -}} | ||||
|     {{ . | nindent 4}} | ||||
|     {{- end -}} | ||||
| {{- end }} | ||||
| @@ -1,14 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- if and (and .Values.actions.provisioning.enabled .Values.persistence.enabled) .Values.persistence.mount }} | ||||
| --- | ||||
| apiVersion: v1 | ||||
| kind: ConfigMap | ||||
| metadata: | ||||
|   name: {{ include "gitea.fullname" . }}-scripts | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
|     {{- include "gitea.labels" . | nindent 4 }} | ||||
| data: | ||||
| {{ (.Files.Glob "scripts/act_runner/*.sh").AsConfig | indent 2 }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| @@ -1,115 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- if and (and .Values.actions.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.actions.provisioning.labels }} | ||||
|     {{- toYaml . | nindent 4 }} | ||||
|     {{- end }} | ||||
|     app.kubernetes.io/component: token-job | ||||
|   annotations: | ||||
|     {{- with .Values.actions.provisioning.annotations }} | ||||
|     {{- toYaml . | nindent 4 }} | ||||
|     {{- end }} | ||||
| spec: | ||||
|   ttlSecondsAfterFinished: {{ .Values.actions.provisioning.ttlSecondsAfterFinished }} | ||||
|   template: | ||||
|     metadata: | ||||
|       labels: | ||||
|         {{- include "gitea.labels" . | nindent 8 }} | ||||
|         {{- with .Values.actions.provisioning.labels }} | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|         {{- end }} | ||||
|         app.kubernetes.io/component: token-job | ||||
|     spec: | ||||
|       initContainers: | ||||
|         - name: init-gitea | ||||
|           image: "{{ .Values.actions.init.image.repository }}:{{ .Values.actions.init.image.tag }}" | ||||
|           command: | ||||
|             - sh | ||||
|             - -c | ||||
|             - | | ||||
|               while ! nc -z {{ include "gitea.fullname" . }}-http {{ .Values.service.http.port }}; 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.actions.provisioning.resources | nindent 12 }} | ||||
|           volumeMounts: | ||||
|             - name: data | ||||
|               mountPath: /data | ||||
|               {{- if .Values.persistence.subPath }} | ||||
|               subPath: {{ .Values.persistence.subPath }} | ||||
|               {{- end }} | ||||
|         - name: actions-token-upload | ||||
|           image: "{{ .Values.actions.provisioning.publish.repository }}:{{ .Values.actions.provisioning.publish.tag }}" | ||||
|           imagePullPolicy: {{ .Values.actions.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.actions.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.actions.provisioning.nodeSelector }} | ||||
|       nodeSelector: | ||||
|         {{ $key }}: {{ $value | quote }} | ||||
|       {{- end }} | ||||
|       {{- with .Values.actions.provisioning.affinity }} | ||||
|       affinity: | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|       {{- end }} | ||||
|       {{- with .Values.actions.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 }} | ||||
| @@ -1,26 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- if and (and .Values.actions.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: rbac.authorization.k8s.io/v1 | ||||
| kind: Role | ||||
| metadata: | ||||
|   name: {{ $name }} | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
|     {{- include "gitea.labels" . | nindent 4 }} | ||||
|     app.kubernetes.io/component: token-job | ||||
| rules: | ||||
|   - apiGroups: | ||||
|       - "" | ||||
|     resources: | ||||
|       - secrets | ||||
|     resourceNames: | ||||
|       - {{ $secretName }} | ||||
|     verbs: | ||||
|       - get | ||||
|       - update | ||||
|       - patch | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| @@ -1,23 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- if and (and .Values.actions.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: rbac.authorization.k8s.io/v1 | ||||
| kind: RoleBinding | ||||
| metadata: | ||||
|   name: {{ $name }} | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
|     {{- include "gitea.labels" . | nindent 4 }} | ||||
|     app.kubernetes.io/component: token-job | ||||
| roleRef: | ||||
|   apiGroup: rbac.authorization.k8s.io | ||||
|   kind: Role | ||||
|   name: {{ $name }} | ||||
| subjects: | ||||
|   - kind: ServiceAccount | ||||
|     name: {{ $name }} | ||||
|     namespace: {{ .Release.Namespace }} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| @@ -1,20 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- if and (and .Values.actions.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: v1 | ||||
| kind: Secret | ||||
| metadata: | ||||
|   name: {{ $secretName }} | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
|     {{- include "gitea.labels" . | nindent 4 }} | ||||
|     app.kubernetes.io/component: token-job | ||||
| {{ $secret := (lookup "v1" "Secret" .Release.Namespace $secretName) -}} | ||||
| {{ if $secret -}} | ||||
| data: | ||||
|   token: {{ (b64dec (index $secret.data "token")) | b64enc }} | ||||
| {{ end -}} | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| @@ -1,14 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- if and (and .Values.actions.provisioning.enabled .Values.persistence.enabled) .Values.persistence.mount }} | ||||
| {{- $name := include "gitea.workername" (dict "global" . "worker" "actions-token-job") }} | ||||
| --- | ||||
| apiVersion: v1 | ||||
| kind: ServiceAccount | ||||
| metadata: | ||||
|   name: {{ $name }} | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
|     {{- include "gitea.labels" . | nindent 4 }} | ||||
|     app.kubernetes.io/component: token-job | ||||
| {{- end }} | ||||
| {{- end }} | ||||
| @@ -1,129 +0,0 @@ | ||||
| {{- if .Values.actions.enabled }} | ||||
| {{- $secretName := include "gitea.workername" (dict "global" . "worker" "actions-token") }} | ||||
| --- | ||||
| apiVersion: apps/v1 | ||||
| kind: StatefulSet | ||||
| metadata: | ||||
|   labels: | ||||
|     {{- include "gitea.labels.actRunner" . | nindent 4 }} | ||||
|     {{- with .Values.actions.statefulset.labels }} | ||||
|     {{- toYaml . | nindent 4 }} | ||||
|     {{- end }} | ||||
|   annotations: | ||||
|     {{- with .Values.actions.statefulset.annotations }} | ||||
|     {{- toYaml . | nindent 4 }} | ||||
|     {{- end }} | ||||
|   name: {{ include "gitea.fullname" . }}-act-runner | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
| spec: | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       {{- include "gitea.selectorLabels.actRunner" . | nindent 6 }} | ||||
|   template: | ||||
|     metadata: | ||||
|       annotations: | ||||
|         checksum/config: {{ include (print $.Template.BasePath "/gitea/act_runner/config-act-runner.yaml") . | sha256sum }} | ||||
|       labels: | ||||
|         {{- include "gitea.labels.actRunner" . | nindent 8 }} | ||||
|         {{- with .Values.actions.statefulset.labels }} | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|         {{- end }} | ||||
|     spec: | ||||
|       initContainers: | ||||
|         - name: init-gitea | ||||
|           image: "{{ .Values.actions.init.image.repository }}:{{ .Values.actions.init.image.tag }}" | ||||
|           command: | ||||
|             - sh | ||||
|             - -c | ||||
|             - | | ||||
|               while ! nc -z {{ include "gitea.fullname" . }}-http {{ .Values.service.http.port }}; do | ||||
|                 sleep 5 | ||||
|               done | ||||
|       containers: | ||||
|         - name: act-runner | ||||
|           image: "{{ .Values.actions.statefulset.actRunner.repository }}:{{ .Values.actions.statefulset.actRunner.tag }}" | ||||
|           imagePullPolicy: {{ .Values.actions.statefulset.actRunner.pullPolicy }} | ||||
|           workingDir: /data | ||||
|           env: | ||||
|             - name: DOCKER_HOST | ||||
|               value: tcp://127.0.0.1:2376 | ||||
|             - name: DOCKER_TLS_VERIFY | ||||
|               value: "1" | ||||
|             - name: DOCKER_CERT_PATH | ||||
|               value: /certs/server | ||||
|             - name: GITEA_RUNNER_REGISTRATION_TOKEN | ||||
|               valueFrom: | ||||
|                 secretKeyRef: | ||||
|                   name: "{{ .Values.actions.existingSecret | default $secretName }}" | ||||
|                   key: "{{ .Values.actions.existingSecretKey | default "token" }}" | ||||
|             - name: GITEA_INSTANCE_URL | ||||
|               value: {{ include "gitea.act_runner.local_root_url" . }} | ||||
|             - name: CONFIG_FILE | ||||
|               value: /actrunner/config.yaml | ||||
|           resources: | ||||
|             {{- toYaml .Values.actions.statefulset.resources | nindent 12 }} | ||||
|           volumeMounts: | ||||
|             - mountPath: /actrunner/config.yaml | ||||
|               name: act-runner-config | ||||
|               subPath: config.yaml | ||||
|             - mountPath: /certs/server | ||||
|               name: docker-certs | ||||
|             - mountPath: /data | ||||
|               name: data-act-runner | ||||
|             {{- with .Values.actions.statefulset.actRunner.extraVolumeMounts }} | ||||
|             {{- toYaml . | nindent 12 }} | ||||
|             {{- end }} | ||||
|         - name: dind | ||||
|           image: "{{ .Values.actions.statefulset.dind.repository }}:{{ .Values.actions.statefulset.dind.tag }}" | ||||
|           imagePullPolicy: {{ .Values.actions.statefulset.dind.pullPolicy }} | ||||
|           env: | ||||
|             - name: DOCKER_HOST | ||||
|               value: tcp://127.0.0.1:2376 | ||||
|             - name: DOCKER_TLS_VERIFY | ||||
|               value: "1" | ||||
|             - name: DOCKER_CERT_PATH | ||||
|               value: /certs/server | ||||
|             {{- if .Values.actions.statefulset.dind.extraEnvs }} | ||||
|             {{- toYaml .Values.actions.statefulset.dind.extraEnvs | nindent 12 }} | ||||
|             {{- end }} | ||||
|           securityContext: | ||||
|             privileged: true | ||||
|           resources: | ||||
|             {{- toYaml .Values.actions.statefulset.resources | nindent 12 }} | ||||
|           volumeMounts: | ||||
|             - mountPath: /certs/server | ||||
|               name: docker-certs | ||||
|             {{- with .Values.actions.statefulset.dind.extraVolumeMounts }} | ||||
|             {{- toYaml . | nindent 12 }} | ||||
|             {{- end }} | ||||
|       {{- range $key, $value := .Values.actions.statefulset.nodeSelector }} | ||||
|       nodeSelector: | ||||
|         {{ $key }}: {{ $value | quote }} | ||||
|       {{- end }} | ||||
|       {{- with .Values.actions.statefulset.affinity }} | ||||
|       affinity: | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|       {{- end }} | ||||
|       {{- with .Values.actions.statefulset.tolerations }} | ||||
|       tolerations: | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|       {{- end }} | ||||
|       volumes: | ||||
|         - name: act-runner-config | ||||
|           configMap: | ||||
|             name: {{ include "gitea.fullname" . }}-act-runner-config | ||||
|         - name: docker-certs | ||||
|           emptyDir: {} | ||||
|         {{- with .Values.actions.statefulset.extraVolumes }} | ||||
|         {{- toYaml . | nindent 8 }} | ||||
|         {{- end }} | ||||
|   volumeClaimTemplates: | ||||
|     - metadata: | ||||
|         name: data-act-runner | ||||
|       spec: | ||||
|         accessModes: [ "ReadWriteOnce" ] | ||||
|         {{- include "gitea.persistence.storageClass" . | nindent 8 }} | ||||
|         resources: | ||||
|           requests: | ||||
|             storage: 1Mi | ||||
| {{- end }} | ||||
| @@ -1,15 +1,7 @@ | ||||
| {{- if .Values.ingress.enabled -}} | ||||
| {{- $fullName := include "gitea.fullname" . -}} | ||||
| {{- $httpPort := .Values.service.http.port -}} | ||||
| {{- $apiVersion := "extensions/v1beta1" -}} | ||||
| {{- if .Values.ingress.apiVersion -}} | ||||
| {{- $apiVersion = .Values.ingress.apiVersion -}} | ||||
| {{- else if .Capabilities.APIVersions.Has "networking.k8s.io/v1/Ingress" -}} | ||||
| {{- $apiVersion = "networking.k8s.io/v1" }} | ||||
| {{- else if .Capabilities.APIVersions.Has "networking.k8s.io/v1beta1/Ingress" -}} | ||||
| {{- $apiVersion = "networking.k8s.io/v1beta1" }} | ||||
| {{- end }} | ||||
| apiVersion: {{ $apiVersion }} | ||||
| apiVersion: networking.k8s.io/v1 | ||||
| kind: Ingress | ||||
| metadata: | ||||
|   name: {{ $fullName }} | ||||
| @@ -21,9 +13,7 @@ metadata: | ||||
|       {{ $key }}: {{ $value | quote }} | ||||
|     {{- end }} | ||||
| spec: | ||||
| {{- if .Values.ingress.className }} | ||||
|   ingressClassName: {{ tpl .Values.ingress.className . }} | ||||
| {{- end }} | ||||
| {{- if .Values.ingress.tls }} | ||||
|   tls: | ||||
|   {{- range .Values.ingress.tls }} | ||||
| @@ -39,21 +29,34 @@ spec: | ||||
|     - host: {{ tpl .host $ | quote }} | ||||
|       http: | ||||
|         paths: | ||||
|           {{- if .paths }} | ||||
|           {{- range .paths }} | ||||
|           - path: {{ .path }} | ||||
|             {{- if and .pathType (eq $apiVersion "networking.k8s.io/v1") }} | ||||
|             pathType: {{ .pathType }} | ||||
|             {{- end }} | ||||
|           {{- if kindIs "string" . }} | ||||
|           - path: {{ . }} | ||||
|             pathType: {{ default "Prefix" $.Values.ingress.pathType }} | ||||
|             backend: | ||||
|               service: | ||||
|                 name: {{ $fullName }}-http | ||||
|                 port: | ||||
|                   number: {{ $httpPort }} | ||||
|           {{- else }} | ||||
|           - path: {{ .path | default "/" }} | ||||
|             pathType: {{ .pathType | default "Prefix" }} | ||||
|             backend: | ||||
|               service: | ||||
|                 name: {{ $fullName }}-http | ||||
|                 port: | ||||
|                   number: {{ $httpPort }} | ||||
|           {{- end }} | ||||
|           {{- end }} | ||||
|           {{- else }} | ||||
|           - path: "/" | ||||
|             pathType: "Prefix" | ||||
|             backend: | ||||
|             {{- if eq $apiVersion "networking.k8s.io/v1" }} | ||||
|               service: | ||||
|                 name: {{ $fullName }}-http | ||||
|                 port: | ||||
|                   number: {{ $httpPort }} | ||||
|             {{- else }} | ||||
|               serviceName: {{ $fullName }}-http | ||||
|               servicePort: {{ $httpPort }} | ||||
|             {{- end }} | ||||
|           {{- end }} | ||||
|     {{- end }} | ||||
| {{- end }} | ||||
| @@ -57,25 +57,25 @@ stringData: | ||||
|       exit 1 | ||||
|     } | ||||
| 
 | ||||
|     {{- if include "redis.servicename" . }} | ||||
|     function test_redis_connection() { | ||||
|     {{- if include "valkey.servicename" . }} | ||||
|     function test_valkey_connection() { | ||||
|       local RETRY=0 | ||||
|       local MAX=30 | ||||
|        | ||||
|       echo 'Wait for redis to become available...' | ||||
|       echo 'Wait for valkey to become avialable...' | ||||
|       until [ "${RETRY}" -ge "${MAX}" ]; do | ||||
|         nc -vz -w2 {{ include "redis.servicename" . }} {{ include "redis.port" . }} && break | ||||
|         nc -vz -w2 {{ include "valkey.servicename" . }} {{ include "valkey.port" . }} && break | ||||
|         RETRY=$[${RETRY}+1] | ||||
|         echo "...not ready yet (${RETRY}/${MAX})" | ||||
|       done | ||||
| 
 | ||||
|       if [ "${RETRY}" -ge "${MAX}" ]; then | ||||
|         echo "Redis not reachable after '${MAX}' attempts!" | ||||
|         echo "Valkey not reachable after '${MAX}' attempts!" | ||||
|         exit 1 | ||||
|       fi | ||||
|     } | ||||
| 
 | ||||
|     test_redis_connection | ||||
|     test_valkey_connection | ||||
|     {{- end }} | ||||
|      | ||||
| 
 | ||||
| @@ -225,4 +225,4 @@ stringData: | ||||
| 
 | ||||
|     configure_oauth | ||||
| 
 | ||||
|     echo '==== END GITEA CONFIGURATION ====' | ||||
|     echo '==== END GITEA CONFIGURATION ====' | ||||
							
								
								
									
										32
									
								
								templates/networkPolicy.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								templates/networkPolicy.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| {{- if .Values.networkPolicy.enabled }} | ||||
| --- | ||||
| apiVersion: networking.k8s.io/v1 | ||||
| kind: NetworkPolicy | ||||
| metadata: | ||||
|   {{- with (include "gitea.networkPolicy.annotations" . | fromYaml) }} | ||||
|   annotations: | ||||
|     {{- tpl (toYaml .) $ | nindent 4 }} | ||||
|   {{- end }} | ||||
|   {{- with (include "gitea.networkPolicy.labels" . | fromYaml) }} | ||||
|   labels: | ||||
|     {{- toYaml . | nindent 4 }} | ||||
|   {{- end }} | ||||
|   name: {{ include "gitea.fullname" . }} | ||||
|   namespace: {{ .Release.Namespace }} | ||||
| spec: | ||||
|   podSelector: | ||||
|     matchLabels: | ||||
|       {{- include "gitea.pod.selectorLabels" $ | nindent 6 }} | ||||
|   {{- with .Values.networkPolicy.policyTypes }} | ||||
|   policyTypes: | ||||
|   {{- toYaml . | nindent 2 }} | ||||
|   {{- end }} | ||||
|   {{- with .Values.networkPolicy.egress }} | ||||
|   egress: | ||||
|   {{- toYaml . | nindent 2 }} | ||||
|   {{- end }} | ||||
|   {{- with .Values.networkPolicy.ingress }} | ||||
|   ingress: | ||||
|   {{- toYaml . | nindent 2 }} | ||||
|   {{- end }} | ||||
| {{- end }} | ||||
| @@ -10,7 +10,7 @@ metadata: | ||||
| {{ .Values.persistence.labels | toYaml | indent 4}} | ||||
| spec: | ||||
|   accessModes: | ||||
|   {{- if gt .Values.replicaCount 1.0 }} | ||||
|   {{- if gt (.Values.replicaCount | int) 1 }} | ||||
|       - ReadWriteMany | ||||
|   {{- else }} | ||||
|     {{- .Values.persistence.accessModes | toYaml | nindent 4 }} | ||||
| @@ -1,18 +0,0 @@ | ||||
| {{- if .Values.test.enabled }} | ||||
| apiVersion: v1 | ||||
| kind: Pod | ||||
| metadata: | ||||
|   name: "{{ include "gitea.fullname" . }}-test-connection" | ||||
|   namespace: {{ .Values.namespace | default .Release.Namespace }} | ||||
|   labels: | ||||
| {{ include "gitea.labels" . | nindent 4 }} | ||||
|   annotations: | ||||
|     "helm.sh/hook": test-success | ||||
| spec: | ||||
|   containers: | ||||
|     - name: wget | ||||
|       image: "{{ .Values.test.image.name }}:{{ .Values.test.image.tag }}" | ||||
|       command: ['wget'] | ||||
|       args:  ['{{ include "gitea.fullname" . }}-http:{{ .Values.service.http.port }}'] | ||||
|   restartPolicy: Never | ||||
| {{- end }} | ||||
 Submodule unittests/bash/bats updated: 3172a45e55...855844b834
									
								
							 Submodule unittests/bash/test_helper/bats-assert updated: b93143a1bf...3be0fb7856
									
								
							 Submodule unittests/bash/test_helper/bats-mock updated: 93e0128b87...9d8aa349f1
									
								
							 Submodule unittests/bash/test_helper/bats-support updated: d007fc1f45...0954abb992
									
								
							| @@ -1,69 +0,0 @@ | ||||
| suite: actions template | consistency checks | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/01-consistency-checks.yaml | ||||
| tests: | ||||
|   - it: fails when provisioning is enabled BUT persistence is completely disabled | ||||
|     set: | ||||
|       persistence: | ||||
|         enabled: false | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "persistence.enabled and persistence.mount are required when provisioning is enabled" | ||||
|   - it: fails when provisioning is enabled BUT mount is disabled, although persistence is enabled | ||||
|     set: | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: false | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "persistence.enabled and persistence.mount are required when provisioning is enabled" | ||||
|   - it: fails when provisioning is enabled AND existingSecret is given | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|         existingSecret: "secret-reference" | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "Can't specify both actions.provisioning.enabled and actions.existingSecret" | ||||
|   - it: fails when provisioning is disabled BUT existingSecret and existingSecretKey are missing | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: false | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "actions.existingSecret and actions.existingSecretKey are required when provisioning is disabled" | ||||
|   - it: fails when provisioning is disabled BUT existingSecretKey is missing | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: false | ||||
|         existingSecret: "my-secret" | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "actions.existingSecret and actions.existingSecretKey are required when provisioning is disabled" | ||||
|   - it: fails when provisioning is disabled BUT existingSecret is missing | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: false | ||||
|         existingSecretKey: "my-secret-key" | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "actions.existingSecret and actions.existingSecretKey are required when provisioning is disabled" | ||||
| @@ -1,45 +0,0 @@ | ||||
| # yaml-language-server: $schema=https://raw.githubusercontent.com/helm-unittest/helm-unittest/main/schema/helm-testsuite.json | ||||
| suite: actions template | config-act-runner | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/config-act-runner.yaml | ||||
| tests: | ||||
|   - it: doesn't renders a ConfigMap by default | ||||
|     template: templates/gitea/act_runner/config-act-runner.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: renders a ConfigMap | ||||
|     template: templates/gitea/act_runner/config-act-runner.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         statefulset: | ||||
|           actRunner: | ||||
|             config: | | ||||
|               log: | ||||
|                 level: info | ||||
|               cache: | ||||
|                 enabled: false | ||||
|               runner: | ||||
|                 labels: | ||||
|                   - "ubuntu-latest" | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: ConfigMap | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-act-runner-config | ||||
|       - equal: | ||||
|           path: data["config.yaml"] | ||||
|           value: | | ||||
|             log: | ||||
|               level: info | ||||
|             cache: | ||||
|               enabled: false | ||||
|             runner: | ||||
|               labels: | ||||
|                 - "ubuntu-latest" | ||||
| @@ -1,49 +0,0 @@ | ||||
| suite: actions template | config-scripts | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/config-scripts.yaml | ||||
| tests: | ||||
|   - it: renders a ConfigMap when all criteria are met | ||||
|     template: templates/gitea/act_runner/config-scripts.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: ConfigMap | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-scripts | ||||
|       - isNotNullOrEmpty: | ||||
|           path: data["token.sh"] | ||||
|   - it: doesn't renders a ConfigMap by default | ||||
|     template: templates/gitea/act_runner/config-scripts.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: doesn't renders a ConfigMap with disabled actions but enabled provisioning | ||||
|     template: templates/gitea/act_runner/config-scripts.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: doesn't renders a ConfigMap with disabled actions but otherwise met criteria | ||||
|     template: templates/gitea/act_runner/config-scripts.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: false | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
| @@ -1,65 +0,0 @@ | ||||
| suite: actions template | job | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| chart: | ||||
|   # Override appVersion to have a pinned version for comparison | ||||
|   appVersion: 1.19.3 | ||||
| templates: | ||||
|   - templates/gitea/act_runner/job.yaml | ||||
| tests: | ||||
|   - it: renders a Job | ||||
|     template: templates/gitea/act_runner/job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: Job | ||||
|           apiVersion: batch/v1 | ||||
|           name: gitea-unittests-actions-token-job | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.3-rootless" | ||||
|   - it: tag override | ||||
|     template: templates/gitea/act_runner/job.yaml | ||||
|     set: | ||||
|       image.tag: "1.19.4" | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|           publish: | ||||
|             tag: "1.29.0" | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.4-rootless" | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[1].image | ||||
|           value: "bitnami/kubectl:1.29.0" | ||||
|   - it: doesn't renders a Job by default | ||||
|     template: templates/gitea/act_runner/job.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: doesn't renders a Job when provisioning is enabled BUT actions are not enabled | ||||
|     template: templates/gitea/act_runner/job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: false | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
| @@ -1,42 +0,0 @@ | ||||
| suite: actions template | role-job | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/role-job.yaml | ||||
| tests: | ||||
|   - it: doesn't renders a Role by default | ||||
|     template: templates/gitea/act_runner/role-job.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: renders a Role | ||||
|     template: templates/gitea/act_runner/role-job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: Role | ||||
|           apiVersion: rbac.authorization.k8s.io/v1 | ||||
|           name: gitea-unittests-actions-token-job | ||||
|   - it: doesn't renders a Role when criteria met BUT actions are not enabled | ||||
|     template: templates/gitea/act_runner/role-job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: false | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
| @@ -1,42 +0,0 @@ | ||||
| suite: actions template | rolebinding-job | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/rolebinding-job.yaml | ||||
| tests: | ||||
|   - it: doesn't renders a RoleBinding by default | ||||
|     template: templates/gitea/act_runner/rolebinding-job.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: renders a RoleBinding | ||||
|     template: templates/gitea/act_runner/rolebinding-job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: RoleBinding | ||||
|           apiVersion: rbac.authorization.k8s.io/v1 | ||||
|           name: gitea-unittests-actions-token-job | ||||
|   - it: doesn't renders a RoleBinding when criteria met BUT actions are not enabled | ||||
|     template: templates/gitea/act_runner/rolebinding-job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: false | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
| @@ -1,42 +0,0 @@ | ||||
| suite: actions template | secret-token | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/secret-token.yaml | ||||
| tests: | ||||
|   - it: doesn't renders a Secret by default | ||||
|     template: templates/gitea/act_runner/secret-token.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: renders a Secret | ||||
|     template: templates/gitea/act_runner/secret-token.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: Secret | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-actions-token | ||||
|   - it: doesn't renders a Secret when criteria met BUT actions are not enabled | ||||
|     template: templates/gitea/act_runner/secret-token.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: false | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
| @@ -1,42 +0,0 @@ | ||||
| suite: actions template | serviceaccount-job | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/serviceaccount-job.yaml | ||||
| tests: | ||||
|   - it: doesn't renders a ServiceAccount by default | ||||
|     template: templates/gitea/act_runner/serviceaccount-job.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: renders a ServiceAccount | ||||
|     template: templates/gitea/act_runner/serviceaccount-job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: ServiceAccount | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-actions-token-job | ||||
|   - it: doesn't renders a ServiceAccount when criteria met BUT actions are not enabled | ||||
|     template: templates/gitea/act_runner/serviceaccount-job.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: false | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|       persistence: | ||||
|         enabled: true | ||||
|         mount: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
| @@ -1,182 +0,0 @@ | ||||
| suite: actions template | statefulset | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/act_runner/statefulset.yaml | ||||
|   - templates/gitea/act_runner/config-act-runner.yaml | ||||
| tests: | ||||
|   - it: doesn't renders a StatefulSet by default | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|   - it: renders a StatefulSet (with given existingSecret/existingSecretKey) | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         existingSecret: "my-secret" | ||||
|         existingSecretKey: "my-secret-key" | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].env[3] | ||||
|           value: | ||||
|             name: GITEA_RUNNER_REGISTRATION_TOKEN | ||||
|             valueFrom: | ||||
|               secretKeyRef: | ||||
|                 name: "my-secret" | ||||
|                 key: "my-secret-key" | ||||
|   - it: renders a StatefulSet (with secret reference defaults for enabled provisioning) | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         provisioning: | ||||
|           enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].env[3] | ||||
|           value: | ||||
|             name: GITEA_RUNNER_REGISTRATION_TOKEN | ||||
|             valueFrom: | ||||
|               secretKeyRef: | ||||
|                 name: "gitea-unittests-actions-token" | ||||
|                 key: "token" | ||||
|   - it: renders a StatefulSet (that tracks changes of the runner configuration as annotation) | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       image.tag: "1.22.3" # lock image tag to prevent test failures on future Gitea upgrades | ||||
|       actions: | ||||
|         enabled: true | ||||
|         existingSecret: "my-secret" | ||||
|         existingSecretKey: "my-secret-key" | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - equal: | ||||
|           path: spec.template.metadata.annotations["checksum/config"] | ||||
|           value: "2a2200e80fc29111d18b675789c265cd3d5f917754850f946f1ce3c55dcd65f8" | ||||
|   - it: renders a StatefulSet (with correct GITEA_INSTANCE_URL env with default act-runner specific LOCAL_ROOT_URL) | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         existingSecret: "my-secret" | ||||
|         existingSecretKey: "my-secret-key" | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].env[4] | ||||
|           value: | ||||
|             name: GITEA_INSTANCE_URL | ||||
|             value: "http://gitea-unittests-http:3000" | ||||
|   - it: renders a StatefulSet (with correct GITEA_INSTANCE_URL env from customized LOCAL_ROOT_URL) | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       gitea.config.server.LOCAL_ROOT_URL: "http://git.example.com" | ||||
|       actions: | ||||
|         enabled: true | ||||
|         existingSecret: "my-secret" | ||||
|         existingSecretKey: "my-secret-key" | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].env[4] | ||||
|           value: | ||||
|             name: GITEA_INSTANCE_URL | ||||
|             value: "http://git.example.com" | ||||
|   - it: allows adding custom environment variables to the docker-in-docker container | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         statefulset: | ||||
|           dind: | ||||
|             extraEnvs: | ||||
|               - name: "CUSTOM_ENV_NAME" | ||||
|                 value: "custom env value" | ||||
|     asserts: | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[1].env[3] | ||||
|           value: | ||||
|             name: "CUSTOM_ENV_NAME" | ||||
|             value: "custom env value" | ||||
|   - it: should mount an extra volume in the act runner container | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         statefulset: | ||||
|           extraVolumes: | ||||
|             - name: my-act-runner-volume | ||||
|               emptyDir: {} | ||||
|           actRunner: | ||||
|             extraVolumeMounts: | ||||
|               - mountPath: /mnt | ||||
|                 name: my-act-runner-volume | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - contains: | ||||
|           any: true | ||||
|           path: spec.template.spec.containers[0].volumeMounts | ||||
|           content: | ||||
|             mountPath: /mnt | ||||
|             name: my-act-runner-volume | ||||
|   - it: should mount an extra volume in the docker-in-docker container | ||||
|     template: templates/gitea/act_runner/statefulset.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|         statefulset: | ||||
|           extraVolumes: | ||||
|             - name: my-dind-volume | ||||
|               emptyDir: {} | ||||
|           dind: | ||||
|             extraVolumeMounts: | ||||
|               - mountPath: /mnt | ||||
|                 name: my-dind-volume | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: StatefulSet | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests-act-runner | ||||
|       - contains: | ||||
|           any: true | ||||
|           path: spec.template.spec.containers[1].volumeMounts | ||||
|           content: | ||||
|             mountPath: /mnt | ||||
|             name: my-dind-volume | ||||
							
								
								
									
										12
									
								
								unittests/helm/check-actions-not-present.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								unittests/helm/check-actions-not-present.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| suite: Check if actions raises an error | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| tests: | ||||
|   - it: fails when trying to configure actions due to removal | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: The actions sub-chart has been outsourced to a dedicated chart available at https://gitea.com/gitea/helm-actions. For assistance with the migration process, check https://gitea.com/gitea/helm-actions/issues/9. | ||||
| @@ -3,59 +3,22 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: "actions are not enabled by default" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "actions are enabled by default (based on vanilla Gitea behavior)" | ||||
|     template: templates/config.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         notExists: | ||||
|           path: stringData.actions | ||||
|  | ||||
|   - it: "actions can be disabled via inline config" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       gitea.config.actions.ENABLED: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: stringData.actions | ||||
|           value: |- | ||||
|             ENABLED=false | ||||
|  | ||||
|   - it: "actions can be enabled via inline config" | ||||
|     template: templates/gitea/config.yaml | ||||
|     set: | ||||
|       gitea.config.actions.ENABLED: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: stringData.actions | ||||
|           value: |- | ||||
|             ENABLED=true | ||||
|  | ||||
|   - it: "actions can be enabled via dedicated values object" | ||||
|     template: templates/gitea/config.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: stringData.actions | ||||
|           value: |- | ||||
|             ENABLED=true | ||||
|  | ||||
|   - it: "defines LOCAL_ROOT_URL when actions are enabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: stringData.server | ||||
|           pattern: \nLOCAL_ROOT_URL=http://gitea-unittests-http:3000 | ||||
|  | ||||
|   - it: "respects custom LOCAL_ROOT_URL, even when actions are enabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|     set: | ||||
|       actions: | ||||
|         enabled: true | ||||
|       gitea.config.server.LOCAL_ROOT_URL: "http://git.example.com" | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: stringData.server | ||||
|           pattern: \nLOCAL_ROOT_URL=http://git.example.com | ||||
|   | ||||
| @@ -3,12 +3,12 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| tests: | ||||
|   - it: "cache is configured correctly for redis-cluster" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "cache is configured correctly for valkey-cluster" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: true | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -16,14 +16,14 @@ tests: | ||||
|           path: stringData.cache | ||||
|           value: |- | ||||
|             ADAPTER=redis | ||||
|             HOST=redis+cluster://:@gitea-unittests-redis-cluster-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             HOST=redis+cluster://:@gitea-unittests-valkey-cluster-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|  | ||||
|   - it: "cache is configured correctly for redis" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "cache is configured correctly for valkey" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -31,14 +31,14 @@ tests: | ||||
|           path: stringData.cache | ||||
|           value: |- | ||||
|             ADAPTER=redis | ||||
|             HOST=redis://:changeme@gitea-unittests-redis-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             HOST=redis://:changeme@gitea-unittests-valkey-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|  | ||||
|   - it: "cache is configured correctly for 'memory' when redis (or redis-cluster) is disabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "cache is configured correctly for 'memory' when valkey (or valkey-cluster) is disabled" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -48,12 +48,12 @@ tests: | ||||
|             ADAPTER=memory | ||||
|             HOST= | ||||
|  | ||||
|   - it: "cache can be customized when redis (or redis-cluster) is disabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "cache can be customized when valkey (or valkey-cluster) is disabled" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|       gitea.config.cache.ADAPTER: custom-adapter | ||||
|       gitea.config.cache.HOST: custom-host | ||||
|   | ||||
| @@ -4,7 +4,7 @@ release: | ||||
|   namespace: testing | ||||
| tests: | ||||
|   - it: metrics token is set | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         metrics: | ||||
| @@ -18,7 +18,7 @@ tests: | ||||
|             ENABLED=true | ||||
|             TOKEN=somepassword | ||||
|   - it: metrics token is empty | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         metrics: | ||||
| @@ -31,7 +31,7 @@ tests: | ||||
|           value: |- | ||||
|             ENABLED=true | ||||
|   - it: metrics token is nil | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         metrics: | ||||
| @@ -44,7 +44,7 @@ tests: | ||||
|           value: |- | ||||
|             ENABLED=true | ||||
|   - it: does not configures a token if metrics are disabled | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         metrics: | ||||
|   | ||||
| @@ -3,42 +3,42 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| tests: | ||||
|   - it: "queue is configured correctly for redis-cluster" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "queue is configured correctly for valkey-cluster" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: true | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: stringData.queue | ||||
|           value: |- | ||||
|             CONN_STR=redis+cluster://:@gitea-unittests-redis-cluster-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             CONN_STR=redis+cluster://:@gitea-unittests-valkey-cluster-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             TYPE=redis | ||||
|  | ||||
|   - it: "queue is configured correctly for redis" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "queue is configured correctly for valkey" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: stringData.queue | ||||
|           value: |- | ||||
|             CONN_STR=redis://:changeme@gitea-unittests-redis-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             CONN_STR=redis://:changeme@gitea-unittests-valkey-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             TYPE=redis | ||||
|  | ||||
|   - it: "queue is configured correctly for 'levelDB' when redis (and redis-cluster) is disabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "queue is configured correctly for 'levelDB' when valkey (and valkey-cluster) is disabled" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -48,12 +48,12 @@ tests: | ||||
|             CONN_STR= | ||||
|             TYPE=level | ||||
|  | ||||
|   - it: "queue can be customized when redis (and redis-cluster) are disabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "queue can be customized when valkey (and valkey-cluster) are disabled" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|       gitea.config.queue.TYPE: custom-type | ||||
|       gitea.config.queue.CONN_STR: custom-connection-string | ||||
|   | ||||
| @@ -4,7 +4,7 @@ release: | ||||
|   namespace: testing | ||||
| tests: | ||||
|   - it: "[default values] uses ingress host for DOMAIN|SSH_DOMAIN|ROOT_URL" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
| @@ -22,7 +22,7 @@ tests: | ||||
|   ################################################ | ||||
|  | ||||
|   - it: "[no ingress hosts] uses gitea http service for DOMAIN|SSH_DOMAIN|ROOT_URL" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       ingress: | ||||
|         hosts: [] | ||||
| @@ -43,7 +43,7 @@ tests: | ||||
|   ################################################ | ||||
|  | ||||
|   - it: "[provided via values] uses that for DOMAIN|SSH_DOMAIN|ROOT_URL" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       gitea.config.server.DOMAIN: provided.example.com | ||||
|       ingress: | ||||
|   | ||||
| @@ -3,12 +3,12 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| tests: | ||||
|   - it: "session is configured correctly for redis-cluster" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "session is configured correctly for valkey-cluster" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: true | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -16,14 +16,14 @@ tests: | ||||
|           path: stringData.session | ||||
|           value: |- | ||||
|             PROVIDER=redis | ||||
|             PROVIDER_CONFIG=redis+cluster://:@gitea-unittests-redis-cluster-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             PROVIDER_CONFIG=redis+cluster://:@gitea-unittests-valkey-cluster-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|  | ||||
|   - it: "session is configured correctly for redis" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "session is configured correctly for valkey" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -31,14 +31,14 @@ tests: | ||||
|           path: stringData.session | ||||
|           value: |- | ||||
|             PROVIDER=redis | ||||
|             PROVIDER_CONFIG=redis://:changeme@gitea-unittests-redis-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|             PROVIDER_CONFIG=redis://:changeme@gitea-unittests-valkey-headless.testing.svc.cluster.local:6379/0?pool_size=100&idle_timeout=180s& | ||||
|  | ||||
|   - it: "session is configured correctly for 'memory' when redis (and redis-cluster) is disabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "session is configured correctly for 'memory' when valkey (and valkey-cluster) is disabled" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
| @@ -48,12 +48,12 @@ tests: | ||||
|             PROVIDER=memory | ||||
|             PROVIDER_CONFIG= | ||||
|  | ||||
|   - it: "session can be customized when redis (and redis-cluster) is disabled" | ||||
|     template: templates/gitea/config.yaml | ||||
|   - it: "session can be customized when valkey (and valkey-cluster) is disabled" | ||||
|     template: templates/config.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|       gitea.config.session.PROVIDER: custom-provider | ||||
|       gitea.config.session.PROVIDER_CONFIG: custom-provider-config | ||||
|   | ||||
| @@ -18,6 +18,7 @@ set: | ||||
|       password: custom-password-overwritten-by-global-postgresql-password | ||||
|     pgpool: | ||||
|       adminPassword: custom-password-pgpool | ||||
|       srCheckPassword: custom-password-sr-check | ||||
|     service: | ||||
|       ports: | ||||
|         postgresql: 1234 | ||||
| @@ -75,6 +76,13 @@ tests: | ||||
|         equal: | ||||
|           path: data["admin-password"] | ||||
|           value: "Y3VzdG9tLXBhc3N3b3JkLXBncG9vbA==" | ||||
|   - it: "[postgresql-ha] pgpool.srCheckPassword is applied as expected" | ||||
|     template: charts/postgresql-ha/templates/pgpool/secrets.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: data["sr-check-password"] | ||||
|           value: "Y3VzdG9tLXBhc3N3b3JkLXNyLWNoZWNr" | ||||
|   - it: "[postgresql-ha] persistence.size is applied as expected" | ||||
|     template: charts/postgresql-ha/templates/postgresql/statefulset.yaml | ||||
|     asserts: | ||||
| @@ -98,14 +106,14 @@ tests: | ||||
|           name: gitea-unittests-postgresql-ha-pgpool | ||||
|           namespace: testing | ||||
|   - it: "[gitea] connects to pgpool service" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: stringData.database | ||||
|           pattern: HOST=gitea-unittests-postgresql-ha-pgpool.testing.svc.cluster.local:1234 | ||||
|   - it: "[gitea] connects to configured database" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|   | ||||
| @@ -65,14 +65,14 @@ tests: | ||||
|           name: gitea-unittests-postgresql | ||||
|           namespace: testing | ||||
|   - it: "[gitea] connects to postgresql service" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: stringData.database | ||||
|           pattern: HOST=gitea-unittests-postgresql.testing.svc.cluster.local:1234 | ||||
|   - it: "[gitea] connects to configured database" | ||||
|     template: templates/gitea/config.yaml | ||||
|     template: templates/config.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|   | ||||
| @@ -1,19 +1,19 @@ | ||||
| suite: Dependency checks | Customization integrity | redis-cluster | ||||
| suite: Dependency checks | Customization integrity | valkey-cluster | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| set: | ||||
|   redis: | ||||
|   valkey: | ||||
|     enabled: false | ||||
|   redis-cluster: | ||||
|   valkey-cluster: | ||||
|     enabled: true | ||||
|     usePassword: false | ||||
|     cluster: | ||||
|       nodes: 5 | ||||
|       replicas: 2 | ||||
| tests: | ||||
|   - it: "[redis-cluster] configures correct nodes/replicas" | ||||
|     template: charts/redis-cluster/templates/redis-statefulset.yaml | ||||
|   - it: "[valkey-cluster] configures correct nodes/replicas" | ||||
|     template: charts/valkey-cluster/templates/valkey-statefulset.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
| @@ -22,31 +22,31 @@ tests: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].args[0] | ||||
|           pattern: REDIS_CLUSTER_REPLICAS="2" | ||||
|   - it: "[redis-cluster] support auth-less connections" | ||||
|           pattern: VALKEY_CLUSTER_REPLICAS="2" | ||||
|   - it: "[valkey-cluster] support auth-less connections" | ||||
|     asserts: | ||||
|       - template: charts/redis-cluster/templates/secret.yaml | ||||
|       - template: charts/valkey-cluster/templates/secret.yaml | ||||
|         hasDocuments: | ||||
|           count: 0 | ||||
|       - template: charts/redis-cluster/templates/redis-statefulset.yaml | ||||
|       - template: charts/valkey-cluster/templates/valkey-statefulset.yaml | ||||
|         documentIndex: 0 | ||||
|         contains: | ||||
|           path: spec.template.spec.containers[0].env | ||||
|           content: | ||||
|             name: ALLOW_EMPTY_PASSWORD | ||||
|             value: "yes" | ||||
|   - it: "[redis-cluster] support auth-full connections" | ||||
|   - it: "[valkey-cluster] support auth-full connections" | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         usePassword: true | ||||
|     asserts: | ||||
|       - template: charts/redis-cluster/templates/secret.yaml | ||||
|       - template: charts/valkey-cluster/templates/secret.yaml | ||||
|         containsDocument: | ||||
|           kind: Secret | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-redis-cluster | ||||
|           name: gitea-unittests-valkey-cluster | ||||
|           namespace: testing | ||||
|       - template: charts/redis-cluster/templates/redis-statefulset.yaml | ||||
|       - template: charts/valkey-cluster/templates/valkey-statefulset.yaml | ||||
|         documentIndex: 0 | ||||
|         contains: | ||||
|           path: spec.template.spec.containers[0].env | ||||
| @@ -54,25 +54,25 @@ tests: | ||||
|             name: REDISCLI_AUTH | ||||
|             valueFrom: | ||||
|               secretKeyRef: | ||||
|                 name: gitea-unittests-redis-cluster | ||||
|                 key: redis-password | ||||
|       - template: charts/redis-cluster/templates/redis-statefulset.yaml | ||||
|                 name: gitea-unittests-valkey-cluster | ||||
|                 key: valkey-password | ||||
|       - template: charts/valkey-cluster/templates/valkey-statefulset.yaml | ||||
|         documentIndex: 0 | ||||
|         contains: | ||||
|           path: spec.template.spec.containers[0].env | ||||
|           content: | ||||
|             name: REDIS_PASSWORD | ||||
|             name: REDISCLI_AUTH | ||||
|             valueFrom: | ||||
|               secretKeyRef: | ||||
|                 name: gitea-unittests-redis-cluster | ||||
|                 key: redis-password | ||||
|   - it: "[redis-cluster] renders the referenced service" | ||||
|     template: charts/redis-cluster/templates/headless-svc.yaml | ||||
|                 name: gitea-unittests-valkey-cluster | ||||
|                 key: valkey-password | ||||
|   - it: "[valkey-cluster] renders the referenced service" | ||||
|     template: charts/valkey-cluster/templates/headless-svc.yaml | ||||
|     asserts: | ||||
|       - containsDocument: | ||||
|           kind: Service | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-redis-cluster-headless | ||||
|           name: gitea-unittests-valkey-cluster-headless | ||||
|           namespace: testing | ||||
|       - documentIndex: 0 | ||||
|         contains: | ||||
| @@ -81,10 +81,10 @@ tests: | ||||
|             name: tcp-redis | ||||
|             port: 6379 | ||||
|             targetPort: tcp-redis | ||||
|   - it: "[gitea] waits for redis-cluster to be up and running" | ||||
|     template: templates/gitea/init.yaml | ||||
|   - it: "[gitea] waits for valkey-cluster to be up and running" | ||||
|     template: templates/init.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: stringData["configure_gitea.sh"] | ||||
|           pattern: nc -vz -w2 gitea-unittests-redis-cluster-headless.testing.svc.cluster.local 6379 | ||||
|           pattern: nc -vz -w2 gitea-unittests-valkey-cluster-headless.testing.svc.cluster.local 6379 | ||||
| @@ -1,40 +1,40 @@ | ||||
| suite: Dependency checks | Customization integrity | redis | ||||
| suite: Dependency checks | Customization integrity | valkey | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| set: | ||||
|   redis-cluster: | ||||
|   valkey-cluster: | ||||
|     enabled: false | ||||
|   redis: | ||||
|   valkey: | ||||
|     enabled: true | ||||
|     architecture: standalone | ||||
|     global: | ||||
|       redis: | ||||
|       valkey: | ||||
|         password: gitea-password | ||||
|     master: | ||||
|       count: 2 | ||||
| tests: | ||||
|   - it: "[redis] configures correct 'master' nodes" | ||||
|     template: charts/redis/templates/master/application.yaml | ||||
|   - it: "[valkey] configures correct 'master' nodes" | ||||
|     template: charts/valkey/templates/primary/application.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: spec.replicas | ||||
|           value: 2 | ||||
|   - it: "[redis] redis.global.redis.password is applied as expected" | ||||
|     template: charts/redis/templates/secret.yaml | ||||
|           value: 1 | ||||
|   - it: "[valkey] valkey.global.valkey.password is applied as expected" | ||||
|     template: charts/valkey/templates/secret.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         equal: | ||||
|           path: data["redis-password"] | ||||
|           path: data["valkey-password"] | ||||
|           value: "Z2l0ZWEtcGFzc3dvcmQ=" | ||||
|   - it: "[redis] renders the referenced service" | ||||
|     template: charts/redis/templates/headless-svc.yaml | ||||
|   - it: "[valkey] renders the referenced service" | ||||
|     template: charts/valkey/templates/headless-svc.yaml | ||||
|     asserts: | ||||
|       - containsDocument: | ||||
|           kind: Service | ||||
|           apiVersion: v1 | ||||
|           name: gitea-unittests-redis-headless | ||||
|           name: gitea-unittests-valkey-headless | ||||
|           namespace: testing | ||||
|       - documentIndex: 0 | ||||
|         contains: | ||||
| @@ -43,10 +43,10 @@ tests: | ||||
|             name: tcp-redis | ||||
|             port: 6379 | ||||
|             targetPort: redis | ||||
|   - it: "[gitea] waits for redis to be up and running" | ||||
|     template: templates/gitea/init.yaml | ||||
|   - it: "[gitea] waits for valkey to be up and running" | ||||
|     template: templates/init.yaml | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: stringData["configure_gitea.sh"] | ||||
|           pattern: nc -vz -w2 gitea-unittests-redis-headless.testing.svc.cluster.local 6379 | ||||
|           pattern: nc -vz -w2 gitea-unittests-valkey-headless.testing.svc.cluster.local 6379 | ||||
| @@ -29,29 +29,29 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/postgresql:17.+$ | ||||
|   - it: "[redis-cluster] ensures we detect major image version upgrades" | ||||
|     template: charts/redis-cluster/templates/redis-statefulset.yaml | ||||
|   - it: "[valkey-cluster] ensures we detect major image version upgrades" | ||||
|     template: charts/valkey-cluster/templates/valkey-statefulset.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: true | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: false | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/redis-cluster:7.+$ | ||||
|   - it: "[redis] ensures we detect major image version upgrades" | ||||
|     template: charts/redis/templates/master/application.yaml | ||||
|           pattern: bitnami/valkey-cluster:8.+$ | ||||
|   - it: "[valkey] ensures we detect major image version upgrades" | ||||
|     template: charts/valkey/templates/primary/application.yaml | ||||
|     set: | ||||
|       redis-cluster: | ||||
|       valkey-cluster: | ||||
|         enabled: false | ||||
|       redis: | ||||
|       valkey: | ||||
|         enabled: true | ||||
|     asserts: | ||||
|       - documentIndex: 0 | ||||
|         matchRegex: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           # IN CASE OF AN INTENTIONAL MAJOR BUMP, ADJUST THIS TEST | ||||
|           pattern: bitnami/redis:7.+$ | ||||
|           pattern: bitnami/valkey:8.+$ | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: fails with multiple replicas and "GIT_GC_REPOS" enabled | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       replicaCount: 2 | ||||
|       persistence: | ||||
| @@ -22,14 +22,14 @@ tests: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "Invoking the garbage collector via CRON is not yet supported when running with multiple replicas. Please set 'gitea.config.cron.GIT_GC_REPOS.enabled = false'." | ||||
|   - it: fails with multiple replicas and RWX file system not set | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       replicaCount: 2 | ||||
|     asserts: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "When using multiple replicas, a RWX file system is required and persistence.accessModes[0] must be set to ReadWriteMany." | ||||
|   - it: fails with multiple replicas and bleve issue indexer | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       replicaCount: 2 | ||||
|       persistence: | ||||
| @@ -43,7 +43,7 @@ tests: | ||||
|       - failedTemplate: | ||||
|           errorMessage: "When using multiple replicas, the issue indexer (gitea.config.indexer.ISSUE_INDEXER_TYPE) must be set to a HA-ready provider such as 'meilisearch', 'elasticsearch' or 'db' (if the DB is HA-ready)." | ||||
|   - it: fails with multiple replicas and bleve repo indexer | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       replicaCount: 2 | ||||
|       persistence: | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: renders a deployment | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
| @@ -16,7 +16,7 @@ tests: | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests | ||||
|   - it: deployment labels are set | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       deployment.labels: | ||||
|         hello: world | ||||
| @@ -30,7 +30,7 @@ tests: | ||||
|           content: | ||||
|             hello: world | ||||
|   - it: "injects TMP_EXISTING_ENVS_FILE as environment variable to 'init-app-ini' init container" | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - contains: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
| @@ -38,7 +38,7 @@ tests: | ||||
|             name: TMP_EXISTING_ENVS_FILE | ||||
|             value: /tmp/existing-envs | ||||
|   - it: "injects ENV_TO_INI_MOUNT_POINT as environment variable to 'init-app-ini' init container" | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - contains: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
| @@ -46,7 +46,7 @@ tests: | ||||
|             name: ENV_TO_INI_MOUNT_POINT | ||||
|             value: /env-to-ini-mounts | ||||
|   - it: CPU resources are defined as well as GOMAXPROCS | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       resources: | ||||
|         limits: | ||||
| @@ -73,3 +73,23 @@ tests: | ||||
|             requests: | ||||
|               cpu: 100ms | ||||
|               memory: 100Mi | ||||
|   - it: Init containers have correct volumeMount path | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       initContainersScriptsVolumeMountPath: "/custom/init/path" | ||||
|     asserts: | ||||
|       - equal: | ||||
|           path: spec.template.spec.initContainers[*].volumeMounts[?(@.name=="init")].mountPath | ||||
|           value: "/custom/init/path" | ||||
|       - equal: | ||||
|           path: spec.template.spec.initContainers[*].volumeMounts[?(@.name=="config")].mountPath | ||||
|           value: "/custom/init/path" | ||||
|   - it: Init containers have correct volumeMount path if there is no override | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - equal: | ||||
|           path: spec.template.spec.initContainers[*].volumeMounts[?(@.name=="init")].mountPath | ||||
|           value: "/usr/sbinx" | ||||
|       - equal: | ||||
|           path: spec.template.spec.initContainers[*].volumeMounts[?(@.name=="config")].mountPath | ||||
|           value: "/usr/sbinx" | ||||
|   | ||||
							
								
								
									
										150
									
								
								unittests/helm/deployment/deployment-additional-config.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								unittests/helm/deployment/deployment-additional-config.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,150 @@ | ||||
| suite: deployment template | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: Renders a deployment | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           kind: Deployment | ||||
|           apiVersion: apps/v1 | ||||
|           name: gitea-unittests | ||||
|   - it: Deployment with empty additionalConfigFromEnvs | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea.additionalConfigFromEnvs: [] | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - exists: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|           count: 6 | ||||
|       - isSubset: | ||||
|           path: spec.template.spec.initContainers[1] | ||||
|           content: | ||||
|             env: | ||||
|               - name: GITEA_APP_INI | ||||
|                 value: /data/gitea/conf/app.ini | ||||
|               - name: GITEA_CUSTOM | ||||
|                 value: /data/gitea | ||||
|               - name: GITEA_WORK_DIR | ||||
|                 value: /data | ||||
|               - name: GITEA_TEMP | ||||
|                 value: /tmp/gitea | ||||
|               - name: TMP_EXISTING_ENVS_FILE | ||||
|                 value: /tmp/existing-envs | ||||
|               - name: ENV_TO_INI_MOUNT_POINT | ||||
|                 value: /env-to-ini-mounts | ||||
|   - it: Deployment with standard additionalConfigFromEnvs | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea.additionalConfigFromEnvs: [{name: GITEA_database_HOST, value: my-db:123}, {name: GITEA_database_USER, value: my-user}] | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - exists: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|           count: 8 | ||||
|       - isSubset: | ||||
|           path: spec.template.spec.initContainers[1] | ||||
|           content: | ||||
|             env: | ||||
|               - name: GITEA_APP_INI | ||||
|                 value: /data/gitea/conf/app.ini | ||||
|               - name: GITEA_CUSTOM | ||||
|                 value: /data/gitea | ||||
|               - name: GITEA_WORK_DIR | ||||
|                 value: /data | ||||
|               - name: GITEA_TEMP | ||||
|                 value: /tmp/gitea | ||||
|               - name: TMP_EXISTING_ENVS_FILE | ||||
|                 value: /tmp/existing-envs | ||||
|               - name: ENV_TO_INI_MOUNT_POINT | ||||
|                 value: /env-to-ini-mounts | ||||
|               - name: GITEA_database_HOST | ||||
|                 value: my-db:123 | ||||
|               - name: GITEA_database_USER | ||||
|                 value: my-user | ||||
|   - it: Deployment with templated additionalConfigFromEnvs | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea.misc.host: my-db-host:321 | ||||
|       gitea.misc.user: my-db-user | ||||
|       gitea.additionalConfigFromEnvs: [{name: GITEA_database_HOST, value: "{{ .Values.gitea.misc.host }}"}, {name: GITEA_database_USER, value: "{{ .Values.gitea.misc.user }}"}] | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - exists: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|           count: 8 | ||||
|       - isSubset: | ||||
|           path: spec.template.spec.initContainers[1] | ||||
|           content: | ||||
|             env: | ||||
|               - name: GITEA_APP_INI | ||||
|                 value: /data/gitea/conf/app.ini | ||||
|               - name: GITEA_CUSTOM | ||||
|                 value: /data/gitea | ||||
|               - name: GITEA_WORK_DIR | ||||
|                 value: /data | ||||
|               - name: GITEA_TEMP | ||||
|                 value: /tmp/gitea | ||||
|               - name: TMP_EXISTING_ENVS_FILE | ||||
|                 value: /tmp/existing-envs | ||||
|               - name: ENV_TO_INI_MOUNT_POINT | ||||
|                 value: /env-to-ini-mounts | ||||
|               - name: GITEA_database_HOST | ||||
|                 value: my-db-host:321 | ||||
|               - name: GITEA_database_USER | ||||
|                 value: my-db-user | ||||
|   - it: Deployment with additionalConfigFromEnvs templated secret name | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea.misc.existingSecret: my-db-secret | ||||
|       gitea.additionalConfigFromEnvs[0]: | ||||
|         name: GITEA_database_HOST | ||||
|         valueFrom: | ||||
|           secretKeyRef: | ||||
|             name: "{{ .Values.gitea.misc.existingSecret }}" | ||||
|             key: password | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - exists: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers[1].env | ||||
|           count: 7 | ||||
|       - isSubset: | ||||
|           path: spec.template.spec.initContainers[1] | ||||
|           content: | ||||
|             env: | ||||
|               - name: GITEA_APP_INI | ||||
|                 value: /data/gitea/conf/app.ini | ||||
|               - name: GITEA_CUSTOM | ||||
|                 value: /data/gitea | ||||
|               - name: GITEA_WORK_DIR | ||||
|                 value: /data | ||||
|               - name: GITEA_TEMP | ||||
|                 value: /tmp/gitea | ||||
|               - name: TMP_EXISTING_ENVS_FILE | ||||
|                 value: /tmp/existing-envs | ||||
|               - name: ENV_TO_INI_MOUNT_POINT | ||||
|                 value: /env-to-ini-mounts | ||||
|               - name: GITEA_database_HOST | ||||
|                 valueFrom: | ||||
|                   secretKeyRef: | ||||
|                     name: "my-db-secret" | ||||
|                     key: password | ||||
							
								
								
									
										59
									
								
								unittests/helm/deployment/extraInitContainers.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								unittests/helm/deployment/extraInitContainers.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| suite: deployment template | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: Render the deployment (default) | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|         template: templates/deployment.yaml | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers | ||||
|           count: 3 | ||||
|         template: templates/deployment.yaml | ||||
|  | ||||
|   - it: Render the deployment (signing) | ||||
|     set: | ||||
|       signing.enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|         template: templates/deployment.yaml | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers | ||||
|           count: 4 | ||||
|         template: templates/deployment.yaml | ||||
|  | ||||
|   - it: Render the deployment (extraInitContainers) | ||||
|     set: | ||||
|       postExtraInitContainers: | ||||
|         - name: foo | ||||
|           image: docker.io/library/busybox:latest | ||||
|       preExtraInitContainers: | ||||
|         - name: bar | ||||
|           image: docker.io/library/busybox:latest | ||||
|       signing.enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|         template: templates/deployment.yaml | ||||
|       - lengthEqual: | ||||
|           path: spec.template.spec.initContainers | ||||
|           count: 6 | ||||
|         template: templates/deployment.yaml | ||||
|       - contains: | ||||
|           path: spec.template.spec.initContainers | ||||
|           content: | ||||
|             name: foo | ||||
|             image: docker.io/library/busybox:latest | ||||
|         template: templates/deployment.yaml | ||||
|       - contains: | ||||
|           path: spec.template.spec.initContainers | ||||
|           content: | ||||
|             name: bar | ||||
|             image: docker.io/library/busybox:latest | ||||
|         template: templates/deployment.yaml | ||||
| @@ -6,17 +6,17 @@ chart: | ||||
|   # Override appVersion to be consistent with used digest :) | ||||
|   appVersion: 1.19.3 | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: default values | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - equal: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.3-rootless" | ||||
|   - it: tag override | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.tag: "1.19.4" | ||||
|     asserts: | ||||
| @@ -24,7 +24,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.4-rootless" | ||||
|   - it: root-based image | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.rootless: false | ||||
|     asserts: | ||||
| @@ -32,7 +32,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.3" | ||||
|   - it: scoped registry | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.registry: "example.com" | ||||
|     asserts: | ||||
| @@ -40,7 +40,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "example.com/gitea:1.19.3-rootless" | ||||
|   - it: global registry | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       global.imageRegistry: "global.example.com" | ||||
|     asserts: | ||||
| @@ -48,7 +48,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "global.example.com/gitea:1.19.3-rootless" | ||||
|   - it: digest for rootless image | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image: | ||||
|         rootless: true | ||||
| @@ -58,7 +58,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.3-rootless@sha256:b28e8f3089b52ebe6693295df142f8c12eff354e9a4a5bfbb5c10f296c3a537a" | ||||
|   - it: image fullOverride (does not append rootless) | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image: | ||||
|         fullOverride: docker.gitea.com/gitea:1.19.3 | ||||
| @@ -73,7 +73,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.3" | ||||
|   - it: digest for root-based image | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image: | ||||
|         rootless: false | ||||
| @@ -83,7 +83,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "docker.gitea.com/gitea:1.19.3@sha256:b28e8f3089b52ebe6693295df142f8c12eff354e9a4a5bfbb5c10f296c3a537a" | ||||
|   - it: digest and global registry | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       global.imageRegistry: "global.example.com" | ||||
|       image.digest: "sha256:b28e8f3089b52ebe6693295df142f8c12eff354e9a4a5bfbb5c10f296c3a537a" | ||||
| @@ -92,7 +92,7 @@ tests: | ||||
|           path: spec.template.spec.containers[0].image | ||||
|           value: "global.example.com/gitea:1.19.3-rootless@sha256:b28e8f3089b52ebe6693295df142f8c12eff354e9a4a5bfbb5c10f296c3a537a" | ||||
|   - it: correctly renders floating tag references | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.tag: 1.21 # use non-quoted value on purpose. See: https://gitea.com/gitea/helm-gitea/issues/631 | ||||
|     asserts: | ||||
|   | ||||
| @@ -1,28 +1,7 @@ | ||||
| suite: ingress template | ||||
| release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| suite: Test ingress tpl use | ||||
| templates: | ||||
|   - templates/gitea/ingress.yaml | ||||
|   - templates/ingress.yaml | ||||
| tests: | ||||
|   - it: hostname using TPL | ||||
|     set: | ||||
|       global.giteaHostName: "gitea.example.com" | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts[0].host: "{{ .Values.global.giteaHostName }}" | ||||
|       ingress.tls: | ||||
|         - secretName: gitea-tls | ||||
|           hosts: | ||||
|             - "{{ .Values.global.giteaHostName }}" | ||||
|     asserts: | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "gitea.example.com" | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "gitea.example.com" | ||||
|   - it: Ingress Class using TPL | ||||
|     set: | ||||
|       global.ingress.className: "ingress-class" | ||||
| @@ -45,3 +24,22 @@ tests: | ||||
|       - equal: | ||||
|           path: spec.ingressClassName | ||||
|           value: "ingress-class" | ||||
|  | ||||
|   - it: hostname using TPL | ||||
|     set: | ||||
|       global.giteaHostName: "gitea.example.com" | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts[0].host: "{{ .Values.global.giteaHostName }}" | ||||
|       ingress.tls: | ||||
|         - secretName: gitea-tls | ||||
|           hosts: | ||||
|             - "{{ .Values.global.giteaHostName }}" | ||||
|     asserts: | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "gitea.example.com" | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "gitea.example.com" | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: inline config stringData.server using TPL | ||||
|     set: | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: renders default liveness probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - notExists: | ||||
|           path: spec.template.spec.containers[0].livenessProbe.enabled | ||||
| @@ -22,7 +22,7 @@ tests: | ||||
|               port: http | ||||
|             timeoutSeconds: 1 | ||||
|   - it: renders default readiness probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - notExists: | ||||
|           path: spec.template.spec.containers[0].readinessProbe.enabled | ||||
| @@ -37,12 +37,12 @@ tests: | ||||
|               port: http | ||||
|             timeoutSeconds: 1 | ||||
|   - it: does not render a default startup probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - notExists: | ||||
|           path: spec.template.spec.containers[0].startupProbe | ||||
|   - it: allows enabling a startup probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea.startupProbe.enabled: true | ||||
|     asserts: | ||||
| @@ -60,7 +60,7 @@ tests: | ||||
|             timeoutSeconds: 1 | ||||
|  | ||||
|   - it: allows overwriting the default port of the liveness probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         livenessProbe: | ||||
| @@ -74,7 +74,7 @@ tests: | ||||
|               port: my-port | ||||
|  | ||||
|   - it: allows overwriting the default port of the readiness probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         readinessProbe: | ||||
| @@ -88,7 +88,7 @@ tests: | ||||
|               port: my-port | ||||
|  | ||||
|   - it: allows overwriting the default port of the startup probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         startupProbe: | ||||
| @@ -103,7 +103,7 @@ tests: | ||||
|               port: my-port | ||||
|  | ||||
|   - it: allows using a non-default method as liveness probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         livenessProbe: | ||||
| @@ -131,7 +131,7 @@ tests: | ||||
|             timeoutSeconds: 13372 | ||||
|  | ||||
|   - it: allows using a non-default method as readiness probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         readinessProbe: | ||||
| @@ -159,7 +159,7 @@ tests: | ||||
|             timeoutSeconds: 13372 | ||||
|  | ||||
|   - it: allows using a non-default method as startup probe | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       gitea: | ||||
|         startupProbe: | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: supports adding a sidecar container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       extraContainers: | ||||
|         - name: sidecar-bob | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: skips gpg init container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - notContains: | ||||
|           path: spec.template.spec.initContainers | ||||
| @@ -15,7 +15,7 @@ tests: | ||||
|           content: | ||||
|             name: configure-gpg | ||||
|   - it: skips gpg env in `init-directories` init container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       signing.enabled: false | ||||
|     asserts: | ||||
| @@ -25,14 +25,14 @@ tests: | ||||
|             name: GNUPGHOME | ||||
|             value: /data/git/.gnupg | ||||
|   - it: skips gpg env in runtime container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - notContains: | ||||
|           path: spec.template.spec.containers[0].env | ||||
|           content: | ||||
|             name: GNUPGHOME | ||||
|   - it: skips gpg volume spec | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     asserts: | ||||
|       - notContains: | ||||
|           path: spec.template.spec.volumes | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: adds gpg init container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       signing: | ||||
|         enabled: true | ||||
| @@ -18,7 +18,7 @@ tests: | ||||
|           value: configure-gpg | ||||
|       - equal: | ||||
|           path: spec.template.spec.initContainers[2].command | ||||
|           value: ["/usr/sbin/configure_gpg_environment.sh"] | ||||
|           value: ["/usr/sbinx/configure_gpg_environment.sh"] | ||||
|       - equal: | ||||
|           path: spec.template.spec.initContainers[2].securityContext | ||||
|           value: | ||||
| @@ -34,14 +34,14 @@ tests: | ||||
|           path: spec.template.spec.initContainers[2].volumeMounts | ||||
|           value: | ||||
|             - name: init | ||||
|               mountPath: /usr/sbin | ||||
|               mountPath: /usr/sbinx | ||||
|             - name: data | ||||
|               mountPath: /data | ||||
|             - name: gpg-private-key | ||||
|               mountPath: /raw | ||||
|               readOnly: true | ||||
|   - it: adds gpg env in `init-directories` init container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       signing.enabled: true | ||||
|       signing.existingSecret: "custom-gpg-secret" | ||||
| @@ -52,7 +52,7 @@ tests: | ||||
|             name: GNUPGHOME | ||||
|             value: /data/git/.gnupg | ||||
|   - it: adds gpg env in runtime container | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       signing.enabled: true | ||||
|       signing.existingSecret: "custom-gpg-secret" | ||||
| @@ -63,7 +63,7 @@ tests: | ||||
|             name: GNUPGHOME | ||||
|             value: /data/git/.gnupg | ||||
|   - it: adds gpg volume spec | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       signing: | ||||
|         enabled: true | ||||
| @@ -80,7 +80,7 @@ tests: | ||||
|                   path: private.asc | ||||
|               defaultMode: 0100 | ||||
|   - it: supports gpg volume spec with external reference | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       signing: | ||||
|         enabled: true | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/deployment.yaml | ||||
|   - templates/gitea/config.yaml | ||||
|   - templates/deployment.yaml | ||||
|   - templates/config.yaml | ||||
| tests: | ||||
|   - it: supports defining SSH log level for root based image | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.rootless: false | ||||
|     asserts: | ||||
| @@ -17,7 +17,7 @@ tests: | ||||
|             name: SSH_LOG_LEVEL | ||||
|             value: "INFO" | ||||
|   - it: supports overriding SSH log level | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.rootless: false | ||||
|       gitea.ssh.logLevel: "DEBUG" | ||||
| @@ -28,7 +28,7 @@ tests: | ||||
|             name: SSH_LOG_LEVEL | ||||
|             value: "DEBUG" | ||||
|   - it: supports overriding SSH log level (even when image.fullOverride set) | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.fullOverride: docker.gitea.com/gitea:1.19.3 | ||||
|       image.rootless: false | ||||
| @@ -40,7 +40,7 @@ tests: | ||||
|             name: SSH_LOG_LEVEL | ||||
|             value: "DEBUG" | ||||
|   - it: skips SSH_LOG_LEVEL for rootless image | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.rootless: true | ||||
|       gitea.ssh.logLevel: "DEBUG" # explicitly defining a non-standard level here | ||||
| @@ -51,7 +51,7 @@ tests: | ||||
|           content: | ||||
|             name: SSH_LOG_LEVEL | ||||
|   - it: skips SSH_LOG_LEVEL for rootless image (even when image.fullOverride set) | ||||
|     template: templates/gitea/deployment.yaml | ||||
|     template: templates/deployment.yaml | ||||
|     set: | ||||
|       image.fullOverride: docker.gitea.com/gitea:1.19.3 | ||||
|       image.rootless: true | ||||
|   | ||||
| @@ -7,11 +7,11 @@ release: | ||||
|   namespace: testing | ||||
|  | ||||
| templates: | ||||
|   - templates/gitea/pvc.yaml | ||||
|   - templates/pvc.yaml | ||||
|  | ||||
| tests: | ||||
|   - it: should set storageClassName when persistence.storageClass is defined | ||||
|     template: templates/gitea/pvc.yaml | ||||
|     template: templates/pvc.yaml | ||||
|     set: | ||||
|       persistence.storageClass: "my-storage-class" | ||||
|     asserts: | ||||
| @@ -20,7 +20,7 @@ tests: | ||||
|           value: "my-storage-class" | ||||
|  | ||||
|   - it: should set global.storageClass when persistence.storageClass is not defined | ||||
|     template: templates/gitea/pvc.yaml | ||||
|     template: templates/pvc.yaml | ||||
|     set: | ||||
|       global.storageClass: "default-storage-class" | ||||
|     asserts: | ||||
| @@ -29,7 +29,7 @@ tests: | ||||
|           value: "default-storage-class" | ||||
|  | ||||
|   - it: should set storageClassName when persistence.storageClass is defined and global.storageClass is defined | ||||
|     template: templates/gitea/pvc.yaml | ||||
|     template: templates/pvc.yaml | ||||
|     set: | ||||
|       global.storageClass: "default-storage-class" | ||||
|       persistence.storageClass: "my-storage-class" | ||||
|   | ||||
| @@ -3,11 +3,11 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/ssh-svc.yaml | ||||
|   - templates/gitea/http-svc.yaml | ||||
|   - templates/ssh-svc.yaml | ||||
|   - templates/http-svc.yaml | ||||
| tests: | ||||
|   - it: supports adding custom labels to ssh-svc | ||||
|     template: templates/gitea/ssh-svc.yaml | ||||
|     template: templates/ssh-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         ssh: | ||||
| @@ -19,7 +19,7 @@ tests: | ||||
|           value: "testvalue" | ||||
|  | ||||
|   - it: keeps existing labels (ssh) | ||||
|     template: templates/gitea/ssh-svc.yaml | ||||
|     template: templates/ssh-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         ssh: | ||||
| @@ -29,7 +29,7 @@ tests: | ||||
|           path: metadata.labels["app"] | ||||
|  | ||||
|   - it: supports adding custom labels to http-svc | ||||
|     template: templates/gitea/http-svc.yaml | ||||
|     template: templates/http-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         http: | ||||
| @@ -41,7 +41,7 @@ tests: | ||||
|           value: "testvalue" | ||||
|  | ||||
|   - it: keeps existing labels (http) | ||||
|     template: templates/gitea/http-svc.yaml | ||||
|     template: templates/http-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         http: | ||||
| @@ -51,7 +51,7 @@ tests: | ||||
|           path: metadata.labels["app"] | ||||
|  | ||||
|   - it: render service.ssh.loadBalancerClass if set and type is LoadBalancer | ||||
|     template: templates/gitea/ssh-svc.yaml | ||||
|     template: templates/ssh-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         ssh: | ||||
| @@ -73,7 +73,7 @@ tests: | ||||
|           value: ["1.2.3.4/32", "5.6.7.8/32"] | ||||
|  | ||||
|   - it: does not render when loadbalancer properties are set but type is not loadBalancerClass | ||||
|     template: templates/gitea/http-svc.yaml | ||||
|     template: templates/http-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         http: | ||||
| @@ -92,7 +92,7 @@ tests: | ||||
|           path: spec.loadBalancerSourceRanges | ||||
|  | ||||
|   - it: does not render loadBalancerClass by default even when type is LoadBalancer | ||||
|     template: templates/gitea/http-svc.yaml | ||||
|     template: templates/http-svc.yaml | ||||
|     set: | ||||
|       service: | ||||
|         http: | ||||
| @@ -107,8 +107,8 @@ tests: | ||||
|  | ||||
|   - it: both ssh and http services exist | ||||
|     templates: | ||||
|       - templates/gitea/ssh-svc.yaml | ||||
|       - templates/gitea/http-svc.yaml | ||||
|       - templates/ssh-svc.yaml | ||||
|       - templates/http-svc.yaml | ||||
|     asserts: | ||||
|       - matchRegex: | ||||
|           path: metadata.name | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/gpg-secret.yaml | ||||
|   - templates/gpg-secret.yaml | ||||
| tests: | ||||
|   - it: renders nothing | ||||
|     set: | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/gpg-secret.yaml | ||||
|   - templates/gpg-secret.yaml | ||||
| tests: | ||||
|   - it: fails rendering when nothing is configured | ||||
|     set: | ||||
|   | ||||
							
								
								
									
										93
									
								
								unittests/helm/ingress/basic.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								unittests/helm/ingress/basic.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| suite: Test ingress.yaml | ||||
| templates: | ||||
|   - templates/ingress.yaml | ||||
| tests: | ||||
|   - it: should enable ingress when ingress.enabled is true | ||||
|     set: | ||||
|       ingress.enabled: true | ||||
|       ingress.apiVersion: networking.k8s.io/v1 | ||||
|       ingress.annotations: | ||||
|         kubernetes.io/ingress.class: nginx | ||||
|       ingress.className: nginx | ||||
|       ingress.tls: | ||||
|         - hosts: | ||||
|             - example.com | ||||
|           secretName: tls-secret | ||||
|       ingress.hosts: | ||||
|         - host: example.com | ||||
|           paths: ["/"] | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: metadata.name | ||||
|           value: RELEASE-NAME-gitea | ||||
|       - matchRegex: | ||||
|           path: apiVersion | ||||
|           pattern: networking.k8s.io/v1 | ||||
|       - equal: | ||||
|           path: spec.ingressClassName | ||||
|           value: nginx | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "example.com" | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "example.com" | ||||
|       - equal: | ||||
|           path: spec.tls[0].secretName | ||||
|           value: tls-secret | ||||
|       - equal: | ||||
|           path: metadata.annotations["kubernetes.io/ingress.class"] | ||||
|           value: nginx | ||||
|  | ||||
|   - it: should not create ingress when ingress.enabled is false | ||||
|     set: | ||||
|       ingress.enabled: false | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|  | ||||
|   - it: Ingress Class using TPL | ||||
|     set: | ||||
|       global.ingress.className: "ingress-class" | ||||
|       ingress.className: "{{ .Values.global.ingress.className }}" | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts[0].host: "some-host" | ||||
|       ingress.tls: | ||||
|         - secretName: gitea-tls | ||||
|           hosts: | ||||
|             - "some-host" | ||||
|     asserts: | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "some-host" | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "some-host" | ||||
|       - equal: | ||||
|           path: spec.ingressClassName | ||||
|           value: "ingress-class" | ||||
|  | ||||
|   - it: hostname using TPL | ||||
|     set: | ||||
|       global.giteaHostName: "gitea.example.com" | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts[0].host: "{{ .Values.global.giteaHostName }}" | ||||
|       ingress.tls: | ||||
|         - secretName: gitea-tls | ||||
|           hosts: | ||||
|             - "{{ .Values.global.giteaHostName }}" | ||||
|     asserts: | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "gitea.example.com" | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "gitea.example.com" | ||||
							
								
								
									
										23
									
								
								unittests/helm/ingress/implicit-defaults.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								unittests/helm/ingress/implicit-defaults.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| suite: Test ingress with implicit path defaults | ||||
| templates: | ||||
|   - templates/ingress.yaml | ||||
| tests: | ||||
|   - it: should use default path and pathType when no paths are specified | ||||
|     set: | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts: | ||||
|         - host: git.example.com | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "git.example.com" | ||||
|       - equal: | ||||
|           path: spec.rules[0].http.paths[0].path | ||||
|           value: "/" | ||||
|       - equal: | ||||
|           path: spec.rules[0].http.paths[0].pathType | ||||
|           value: "Prefix" | ||||
							
								
								
									
										45
									
								
								unittests/helm/ingress/ingress.tpl.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								unittests/helm/ingress/ingress.tpl.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| suite: Test ingress tpl use | ||||
| templates: | ||||
|   - templates/ingress.yaml | ||||
| tests: | ||||
|   - it: Ingress Class using TPL | ||||
|     set: | ||||
|       global.ingress.className: "ingress-class" | ||||
|       ingress.className: "{{ .Values.global.ingress.className }}" | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts[0].host: "some-host" | ||||
|       ingress.tls: | ||||
|         - secretName: gitea-tls | ||||
|           hosts: | ||||
|             - "some-host" | ||||
|     asserts: | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "some-host" | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "some-host" | ||||
|       - equal: | ||||
|           path: spec.ingressClassName | ||||
|           value: "ingress-class" | ||||
|  | ||||
|   - it: hostname using TPL | ||||
|     set: | ||||
|       global.giteaHostName: "gitea.example.com" | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts[0].host: "{{ .Values.global.giteaHostName }}" | ||||
|       ingress.tls: | ||||
|         - secretName: gitea-tls | ||||
|           hosts: | ||||
|             - "{{ .Values.global.giteaHostName }}" | ||||
|     asserts: | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.tls[0].hosts[0] | ||||
|           value: "gitea.example.com" | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "gitea.example.com" | ||||
							
								
								
									
										26
									
								
								unittests/helm/ingress/structured-paths.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								unittests/helm/ingress/structured-paths.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| suite: Test ingress with structured paths | ||||
| templates: | ||||
|   - templates/ingress.yaml | ||||
| tests: | ||||
|   - it: should work with structured path definitions | ||||
|     set: | ||||
|       ingress.enabled: true | ||||
|       ingress.hosts: | ||||
|         - host: git.devxy.io | ||||
|           paths: | ||||
|             - path: / | ||||
|               pathType: Prefix | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - isKind: | ||||
|           of: Ingress | ||||
|       - equal: | ||||
|           path: spec.rules[0].host | ||||
|           value: "git.devxy.io" | ||||
|       - equal: | ||||
|           path: spec.rules[0].http.paths[0].path | ||||
|           value: "/" | ||||
|       - equal: | ||||
|           path: spec.rules[0].http.paths[0].pathType | ||||
|           value: "Prefix" | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/init.yaml | ||||
|   - templates/init.yaml | ||||
| tests: | ||||
|   - it: renders a secret | ||||
|     asserts: | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/init.yaml | ||||
|   - templates/init.yaml | ||||
| tests: | ||||
|   - it: runs gpg in batch mode | ||||
|     set: | ||||
| @@ -63,7 +63,7 @@ tests: | ||||
|               chown -v 1000:1000 "${GNUPGHOME}" | ||||
|             fi | ||||
|   - it: it does not chown /data even when image.fullOverride is set | ||||
|     template: templates/gitea/init.yaml | ||||
|     template: templates/init.yaml | ||||
|     set: | ||||
|       image.fullOverride: docker.gitea.com/gitea:1.20.5 | ||||
|     asserts: | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/init.yaml | ||||
|   - templates/init.yaml | ||||
| tests: | ||||
|   - it: runs gpg in batch mode | ||||
|     set: | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/metrics-secret.yaml | ||||
|   - templates/metrics-secret.yaml | ||||
| tests: | ||||
|   - it: renders nothing if monitoring disabled and gitea.metrics.token empty | ||||
|     set: | ||||
|   | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/metrics-secret.yaml | ||||
|   - templates/metrics-secret.yaml | ||||
| tests: | ||||
|   - it: renders nothing if monitoring enabled and gitea.metrics.token empty | ||||
|     set: | ||||
|   | ||||
							
								
								
									
										100
									
								
								unittests/helm/networkPolicy/networkPolicy.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								unittests/helm/networkPolicy/networkPolicy.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| chart: | ||||
|   appVersion: 0.1.0 | ||||
|   version: 0.1.0 | ||||
| suite: NetworkPolicy template | ||||
| release: | ||||
|   name: gitea-unittest | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/networkPolicy.yaml | ||||
| tests: | ||||
|   - it: Skip rendering networkPolicy | ||||
|     set: | ||||
|       networkPolicy.enabled: false | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 0 | ||||
|  | ||||
|   - it: Render default networkPolicy | ||||
|     set: | ||||
|       networkPolicy.enabled: true | ||||
|     asserts: | ||||
|       - hasDocuments: | ||||
|           count: 1 | ||||
|       - containsDocument: | ||||
|           apiVersion: networking.k8s.io/v1 | ||||
|           kind: NetworkPolicy | ||||
|           name: gitea-unittest | ||||
|           namespace: testing | ||||
|       - notExists: | ||||
|           path: metadata.annotations | ||||
|       - equal: | ||||
|           path: metadata.labels | ||||
|           value: | ||||
|             app: gitea | ||||
|             app.kubernetes.io/instance: gitea-unittest | ||||
|             app.kubernetes.io/managed-by: Helm | ||||
|             app.kubernetes.io/name: gitea | ||||
|             app.kubernetes.io/version: 0.1.0 | ||||
|             helm.sh/chart: gitea-0.1.0 | ||||
|             version: 0.1.0 | ||||
|       - equal: | ||||
|           path: spec.podSelector.matchLabels | ||||
|           value: | ||||
|             app.kubernetes.io/instance: gitea-unittest | ||||
|             app.kubernetes.io/name: gitea | ||||
|       - notExists: | ||||
|           path: spec.policyTypes | ||||
|       - notExists: | ||||
|           path: spec.egress | ||||
|       - notExists: | ||||
|           path: spec.ingress | ||||
|  | ||||
|   - it: Template networkPolicy with policyTypes, egress and ingress configuration | ||||
|     set: | ||||
|       networkPolicy.enabled: true | ||||
|       networkPolicy.policyTypes: | ||||
|         - Egress | ||||
|         - Ingress | ||||
|       networkPolicy.ingress: | ||||
|         - from: | ||||
|             - namespaceSelector: | ||||
|                 matchLabels: | ||||
|                   kubernetes.io/metadata.name: monitoring | ||||
|               podSelector: | ||||
|                 matchLabels: | ||||
|                   app.kubernetes.io/name: prometheus | ||||
|       networkPolicy.egress: | ||||
|         - to: | ||||
|             - namespaceSelector: | ||||
|                 matchLabels: | ||||
|                   kubernetes.io/metadata.name: ingress-nginx | ||||
|               podSelector: | ||||
|                 matchLabels: | ||||
|                   app.kubernetes.io/name: ingress-nginx | ||||
|     asserts: | ||||
|       - equal: | ||||
|           path: spec.policyTypes | ||||
|           value: | ||||
|             - Egress | ||||
|             - Ingress | ||||
|       - equal: | ||||
|           path: spec.egress | ||||
|           value: | ||||
|             - to: | ||||
|                 - namespaceSelector: | ||||
|                     matchLabels: | ||||
|                       kubernetes.io/metadata.name: ingress-nginx | ||||
|                   podSelector: | ||||
|                     matchLabels: | ||||
|                       app.kubernetes.io/name: ingress-nginx | ||||
|       - equal: | ||||
|           path: spec.ingress | ||||
|           value: | ||||
|             - from: | ||||
|                 - namespaceSelector: | ||||
|                     matchLabels: | ||||
|                       kubernetes.io/metadata.name: monitoring | ||||
|                   podSelector: | ||||
|                     matchLabels: | ||||
|                       app.kubernetes.io/name: prometheus | ||||
| @@ -3,7 +3,7 @@ release: | ||||
|   name: gitea-unittests | ||||
|   namespace: testing | ||||
| templates: | ||||
|   - templates/gitea/pvc.yaml | ||||
|   - templates/pvc.yaml | ||||
| tests: | ||||
|   - it: Storage Class using TPL | ||||
|     set: | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user