add k8s vpa rightsizing values yaml to helm pkg #70
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Helm package and push to Github Pages | |
on: | |
push: | |
# run the Github Action on every tag versioned as v*.*.* | |
tags: | |
- "v*.*.*" | |
jobs: | |
helm-package-and-push-to-ghcr-io: | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Install Helm + yq + jq | |
run: | | |
sudo snap install yq | |
sudo snap install helm --classic | |
sudo snap install jq | |
- name: Helm Package | |
id: helm_package | |
run: | | |
echo "Tag version: $GITHUB_REF" | |
RELEASE_TAG="${GITHUB_REF#refs/tags/}" | |
VERSION="${RELEASE_TAG:-v666.666.666}" | |
echo "VERSION Version: $VERSION" | |
CLEAN_VERSION="${VERSION#v}" | |
echo "CLEAN_VERSION Version: $CLEAN_VERSION" | |
# package the helm chart | |
PACKAGE_OUTPUT=$(helm package --version "$CLEAN_VERSION" helm-chart) | |
echo "PACKAGE_OUTPUT=$PACKAGE_OUTPUT" | |
PACKAGE_NAME=$(basename "$PACKAGE_OUTPUT") | |
echo "Generated helm package: $PACKAGE_NAME" | |
# save the generated package name to github_output to pass it to next step | |
echo "package-name=$PACKAGE_NAME" >> $GITHUB_OUTPUT | |
echo "package-version=$CLEAN_VERSION" >> $GITHUB_OUTPUT | |
- name: Patch argocd application yaml | |
id: argocd-application | |
run: | | |
VERSIONED_ARGOCD_APP_YAML="argocd-application-${{ steps.helm_package.outputs.package-version}}.yaml" | |
cp argocd-application.yaml "$VERSIONED_ARGOCD_APP_YAML" | |
echo "Current targetRevision: $(yq '.spec.source.targetRevision' $VERSIONED_ARGOCD_APP_YAML)" | |
yq e '.spec.source.targetRevision = "${{ steps.helm_package.outputs.package-version}}"' --inplace $VERSIONED_ARGOCD_APP_YAML | |
echo "Patched targetRevision: $(yq '.spec.source.targetRevision' $VERSIONED_ARGOCD_APP_YAML)" | |
# save to the github_output to pass it to next step | |
echo "argocd-application-filename=$VERSIONED_ARGOCD_APP_YAML" >> $GITHUB_OUTPUT | |
- name: Print helm_package step output | |
run: | | |
echo "package-name=$MESSAGE" | |
env: | |
MESSAGE: ${{ steps.helm_package.outputs.package-name}} | |
- name: Create new Release and upload helm artifact | |
id: create_release_and_upload_artifacts | |
uses: softprops/[email protected] | |
if: startsWith(github.ref, 'refs/tags/') | |
with: | |
files: | | |
${{ steps.helm_package.outputs.package-name}} | |
${{ steps.argocd-application.outputs.argocd-application-filename}} | |
token: ${{ secrets.GHCR_TOKEN }} | |
generate_release_notes: true | |
fail_on_unmatched_files: true | |
body: | | |
Github Repo: <https://github.com/oguzhan-yilmaz/steampipe-powerpipe-kubernetes> | |
Github Releases: <https://github.com/oguzhan-yilmaz/steampipe-powerpipe-kubernetes/releases> | |
Github Pages: <https://oguzhan-yilmaz.github.io/steampipe-powerpipe-kubernetes/> | |
Github Pages (Helm index): <https://oguzhan-yilmaz.github.io/steampipe-powerpipe-kubernetes/index.yaml> | |
**Helm Repo** | |
```bash | |
helm repo add oguzhan-yilmaz https://oguzhan-yilmaz.github.io/steampipe-powerpipe-kubernetes | |
``` | |
```bash | |
helm repo update oguzhan-yilmaz | |
``` | |
**Helm Install (latest version)** | |
```bash | |
helm repo update oguzhan-yilmaz | |
helm show values oguzhan-yilmaz/steampipe-powerpipe-kubernetes > values.yaml | |
# update the values.yaml on your own accord | |
helm upgrade --install steampipe-powerpipe \ | |
-n turbot \ | |
-f values.yaml \ | |
--create-namespace \ | |
oguzhan-yilmaz/steampipe-powerpipe-kubernetes | |
``` | |
**Helm Install (current version)** | |
```bash | |
helm show values oguzhan-yilmaz/steampipe-powerpipe-kubernetes --version ${{ steps.helm_package.outputs.package-version}} > values.yaml | |
# update the values.yaml on your own accord | |
helm upgrade --install steampipe-powerpipe \ | |
-n turbot \ | |
-f values.yaml \ | |
--create-namespace \ | |
--version ${{ steps.helm_package.outputs.package-version}} \ | |
oguzhan-yilmaz/steampipe-powerpipe-kubernetes | |
``` | |
**ArgoCD Application (current version)** | |
First, download the `argocd-application-X.Y.Z.yaml` from assets. | |
```bash | |
kubectl apply -f argocd-application-X.Y.Z.yaml | |
``` | |
- name: print release upload output | |
run: | | |
echo "assets=${{ steps.create_release_and_upload_artifacts.outputs.assets}}" | |
- name: Save artifact download url | |
id: helm_package_download_url | |
run: | | |
DOWNLOAD_URL=$(echo '${{ steps.create_release_and_upload_artifacts.outputs.assets}}' | jq '.[0].browser_download_url') | |
echo "DOWNLOAD_URL=$DOWNLOAD_URL" | |
echo "download_url=$DOWNLOAD_URL" >> $GITHUB_OUTPUT | |
- name: Print uploaded helm_package download url | |
run: | | |
echo 'package-name=${{ steps.helm_package_download_url.outputs.download_url}}' | |
- name: Clone gh-pages branch and update helm index.yaml on github pages | |
env: | |
GITHUB_TOKEN: ${{ secrets.GHCR_TOKEN }} | |
GIT_AUTHOR_EMAIL: "Oguzhan Yilmaz" | |
GIT_AUTHOR_NAME: "[email protected]" | |
run: | | |
git config --global user.email "[email protected]" | |
git config --global user.name "Oguzhan Yilmaz" | |
# clone gh-pages branch | |
git clone -b gh-pages https://github.com/oguzhan-yilmaz/steampipe-powerpipe-kubernetes.git gh-pages-clone | |
ls -al | |
ls -al gh-pages-clone | |
# merge the helm index.yaml | |
ACTUAL_RELEASE_URL="${{ steps.helm_package_download_url.outputs.download_url}}" | |
RELEASE_BASE_URL="${ACTUAL_RELEASE_URL%/*}" | |
echo "RELEASE_BASE_URL=$RELEASE_BASE_URL" | |
helm repo index . --url "$RELEASE_BASE_URL" --merge gh-pages-clone/index.yaml | |
ls -al | |
# replace the index.yaml with the new one | |
echo "Old index.yaml" | |
cat gh-pages-clone/index.yaml | |
rm gh-pages-clone/index.yaml | |
cp index.yaml gh-pages-clone/index.yaml | |
# check out the new index.yaml | |
cd gh-pages-clone | |
pwd | |
echo "New index.yaml" | |
cat index.yaml | |
git status | |
# commit and push the new index.yaml | |
git add index.yaml | |
git commit -m "update index.yaml in Github Action" | |
git remote set-url origin https://x-access-token:${{ secrets.GHCR_TOKEN }}@github.com/oguzhan-yilmaz/steampipe-powerpipe-kubernetes.git | |
git push | |
git status |