This is a script to help you to update your helm dependencies in your helm charts. It will create a PR with the changes if you want to. But
Why I build this tool? We have a lot of helm charts and we want to update the dependencies in all of them. The resources from helm-charts will be deployed over argocd, so the helm chart will no be installed on the cluster itself. Because of that you cant use tools like renovate or dependabot running in the cluster. Since recently you can use renovate to update helm-values and maybe you like to use this tool instead of this script.
You can use this tool in your CI/CD pipeline or locally.
You will need the following tools installed on your machine (depends on your target environment):
Please feel to fork this repository. This allows you to customize the script for your needs. Moreover you test the script directly in your environment.
The default for the key config
in the dependencies.yaml
files looks like:
config:
BRANCH: main
DRY_RUN: true
GITHUB: false
AZURE_DEVOPS: false
WITHOUT_PR: false
This will only print the changes to the console. You can run the script with:
./check-helm-dep-updates.sh
You will get an output like:
####################### Begin #######################
Name: External DNS
Version in Chart.yaml: 6.20.4
Latest Version in Repository: 6.21.0
There's a difference between the versions.
Differences:
_ __ __
_| |_ _ / _|/ _| between values.yaml
/ _' | | | | |_| |_ and latest_values.yaml
| (_| | |_| | _| _|
\__,_|\__, |_| |_| returned two differences
|___/
(root level)
+ one map entry added:
## @param ingressClassFilters Filter sources managed by external-dns via IngressClass (optional)
##
ingressClassFilters: []
image.tag
± value change
- 0.13.4-debian-11-r19
+ 0.13.5-debian-11-r55
####################### End #######################
First you have to login against GitHub. You can do this with gh auth login
or get more information here on the official documentation
Now edit the key config
in dependencies.yaml
file like:
config:
BRANCH: main
DRY_RUN: false
GITHUB: true
AZURE_DEVOPS: false
WITHOUT_PR: false
Commit and push the changes to your repository. After that you can run the script with:
Warning
After you set
GITHUB
totrue
, the script will create a new branch and a PR with the changes. If you want to test it first, setDRY_RUN
totrue
.
Execute the script with:
./check-helm-dep-updates.sh
Check the changes on GitHub and if you are happy with them, you can merge the PR.
First you have to create a PAT token. You can find more information here on the official documentation. After you created the PAT token, you need to set the following variable:
AZURE_DEVOPS_EXT_PAT=<your-pat-token>
Now edit the key config
in dependencies.yaml
file like:
config:
BRANCH: main
DRY_RUN: true
GITHUB: false
AZURE_DEVOPS: true
WITHOUT_PR: false
Warning
After you set
AZURE_DEVOPS
totrue
, the script will create a new branch and a PR with the changes. If you want to test it first, setDRY_RUN
totrue
.
Execute the script with:
./check-helm-dep-updates.sh
Check the changes on Azure DevOps and if you are happy with them, you can merge the PR.
This part allows you to update the helm dependencies without creating a PR. You can use this part in your CI/CD pipeline. It can be useful if you want to update the helm dependencies in your main branch over an manual pull request.
Now edit the key config
in dependencies.yaml
file like:
config:
BRANCH: main
DRY_RUN: true
GITHUB: false
AZURE_DEVOPS: false
WITHOUT_PR: true
Warning
After you set
WITHOUT_PR
totrue
, the script will create a new branch and push this branch. If you want to test it first, setDRY_RUN
totrue
.
Execute the script with:
./check-helm-dep-updates.sh
Check the changes on your Git Provider and if you are happy with them, you can merge the PR.
Naturally, you’d want everything to be automated, and the only task on your plate would be to review the pull request. Here’s where CI/CD (Continuous Integration/Continuous Deployment) fits in like a glove.
Under the folder azure-devops you will find a pipeline file. You can use this folder structure in your Azure DevOps project.
You should replace the orga
parameter with your organization and like https://dev.azure.com/<YOUR_ORGA_NAME>/<YOUR_PPROJECT_NAME>/_git/<YOUR_REPO_NAME>
.
You can use this script as a GitHub action in your repository.
To do this, you need only to create a new workflow file in your repository under .github/workflows/
and add the following content:
name: helm-dependencies
on:
workflow_dispatch:
schedule:
- cron: "0 0 * * *"
push:
branches:
- main
paths:
- ".github/workflows/helm-dependencies.yml"
- "dependencies.yaml"
jobs:
helm-dependencies:
name: Helm Dependencies
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Helm Dependencies
uses: la-cc/gh-actions/[email protected]
with:
config-path: dependencies.yaml
user-email: "[email protected]"
user-name: "Meep"
default-branch: "main"
dry-run: false
github-run: true
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
Of course you will be need a dependencies.yaml
file in your repository. You can use the example file from this repository.
If you're eager to contribute to this script, feel free to fork the repository and submit a pull request. Your input is valued and always welcome!
Current Contributors: