Renovate Bot 9c76b8bfdc
All checks were successful
Release / Release (push) Successful in 10s
chore(deps): update azure/setup-kubectl action to v5 (#40)
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [azure/setup-kubectl](https://github.com/azure/setup-kubectl) | action | major | `v4.0.1` → `v5.0.0` |

---

### Release Notes

<details>
<summary>azure/setup-kubectl (azure/setup-kubectl)</summary>

### [`v5.0.0`](https://github.com/Azure/setup-kubectl/releases/tag/v5.0.0)

[Compare Source](https://github.com/azure/setup-kubectl/compare/v4.0.1...v5.0.0)

##### Changed

- [#&#8203;233](https://github.com/azure/setup-kubectl/issues/233) [Update Node.js runtime from node20 to node24](https://github.com/Azure/setup-kubectl/pull/233)
- [#&#8203;228](https://github.com/azure/setup-kubectl/issues/228) [Replace cdn.dl.k8s.io with dl.k8s.io](https://github.com/Azure/setup-kubectl/pull/228)
- [#&#8203;219](https://github.com/azure/setup-kubectl/issues/219) [Remove download redirects, use cdn.dl.k8s.io domain](https://github.com/Azure/setup-kubectl/pull/219)
- [#&#8203;190](https://github.com/azure/setup-kubectl/issues/190) [Update stableVersionUrl to dl.k8s.io](https://github.com/Azure/setup-kubectl/pull/190)
- [#&#8203;235](https://github.com/azure/setup-kubectl/issues/235) [Bump undici from 6.23.0 to 6.24.1](https://github.com/Azure/setup-kubectl/pull/235)
- [#&#8203;226](https://github.com/azure/setup-kubectl/issues/226) [Bump undici and @&#8203;actions/http-client](https://github.com/Azure/setup-kubectl/pull/226)
- [#&#8203;230](https://github.com/azure/setup-kubectl/issues/230) [Bump minimatch](https://github.com/Azure/setup-kubectl/pull/230)

##### Added

- [#&#8203;172](https://github.com/azure/setup-kubectl/issues/172) [Enhance version handling: auto-resolve kubectl major.minor to latest patch](https://github.com/Azure/setup-kubectl/pull/172)
- [#&#8203;171](https://github.com/azure/setup-kubectl/issues/171) [Add husky precommit check](https://github.com/Azure/setup-kubectl/pull/171)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My41LjQiLCJ1cGRhdGVkSW5WZXIiOiI0My41LjQiLCJ0YXJnZXRCcmFuY2giOiJtYWluIiwibGFiZWxzIjpbImFjdGlvbiIsImRlcHMiXX0=-->

Reviewed-on: https://gitea.t000-n.de/t.behrendt/k_deploy_workflows/pulls/40
Reviewed-by: t.behrendt <t.behrendt@noreply.localhost>
Co-authored-by: Renovate Bot <renovate@t00n.de>
Co-committed-by: Renovate Bot <renovate@t00n.de>
2026-04-03 09:10:18 +02:00
2025-08-12 08:54:44 +02:00

Warning

Repo is currently not in use and not tested. We are waiting for proper shared workflow UI support in gitea. Otherwise errors are hard to identify. Follow https://github.com/go-gitea/gitea/issues/24604

Reusable CI Workflow for Kubernetes Services

This directory contains a reusable CI workflow that automatically detects and validates your Kubernetes services, whether they use Helm + Kubernetes or just Kubernetes manifests.

Features

  • Automatic Detection: Automatically detects if your service uses Helm (helmfile.yaml) or just Kubernetes manifests
  • Conditional Validation: Only runs Helm validation when helmfile.yaml exists
  • Flexible Paths: Configurable paths for k8s directory and helmfile
  • Comprehensive Validation: Validates both Kubernetes manifests and Helm charts
  • CI Summary: Provides a clear summary of what was validated

Usage

Simply call the workflow without any parameters - it will automatically detect your service type:

jobs:
  ci:
    uses: ./.gitea/workflows/ci.yaml

Advanced Usage with Custom Paths

If your service uses non-standard directory names:

jobs:
  ci:
    uses: ./.gitea/workflows/ci.yaml
    with:
      k8s_dir: "kubernetes/"
      helmfile_path: "helm/helmfile.yaml"

Force Skip Helm Validation

If you want to skip Helm validation even when helmfile.yaml exists:

jobs:
  ci:
    uses: ./.gitea/workflows/ci.yaml
    with:
      skip_helm_validation: true

Input Parameters

Parameter Description Default Required
k8s_dir Path to Kubernetes manifests directory k8s/ No
helmfile_path Path to helmfile.yaml helmfile.yaml No
skip_helm_validation Skip Helm validation even if helmfile exists false No

Directory Structure Requirements

For Kubernetes-only services:

your-service/
├── k8s/
│   ├── deployment.yaml
│   ├── service.yaml
│   └── ...
└── .gitea/workflows/your-workflow.yaml

For Helm + Kubernetes services:

your-service/
├── k8s/
│   ├── deployment.yaml
│   ├── service.yaml
│   └── ...
├── helmfile.yaml
└── .gitea/workflows/your-workflow.yaml

What Gets Validated

Always (if k8s/ directory exists):

  • Kubernetes manifest validation using kubectl --dry-run
  • Namespace extraction from repository name
  • Basic Kubernetes syntax and schema validation

Conditionally (if helmfile.yaml exists and Helm validation not skipped):

  • Helm chart validation using helmfile diff
  • Kubernetes manifests in Helm context
  • Helm-specific configurations and values

Example Workflows

See example-usage.yaml for complete examples of how to use this workflow in different scenarios.

Available Actions

Extract Chart Name from Repository Name

The extract-chart-name-from-repo-name action extracts the chart name from repository names following the helm-<chart-name> convention.

Usage

- name: Extract chart name
  uses: ./.gitea/actions/extract-chart-name-from-repo-name
  with:
    repo: ${{ github.repository_name }} # e.g., "helm-my-service"

Inputs

Parameter Description Required
repo The full repository name (e.g., "helm-my-chart") Yes

Outputs

Output Description
chart-name The extracted chart name (e.g., "my-chart" from "helm-my-chart")

Example

For a repository named helm-user-service, this action will extract user-service as the chart name.

Dependencies

This workflow requires:

  • ./.gitea/actions/extract-namespace-from-repo-name action
  • ./.gitea/actions/extract-chart-name-from-repo-name action
  • KUBECONFIG secret configured in your repository
  • Access to your Kubernetes cluster

Troubleshooting

Helm validation skipped unexpectedly

  • Check if helmfile.yaml exists in the expected location
  • Verify the skip_helm_validation parameter is not set to true
  • Ensure the file path is correct if using custom paths

Kubernetes validation skipped

  • Verify the k8s/ directory (or custom path) exists
  • Check the directory contains valid Kubernetes manifests

Permission issues

  • Ensure the KUBECONFIG secret is properly configured
  • Verify the workflow has access to your Kubernetes cluster
Description
No description provided
Readme 157 KiB
Languages
Markdown 100%