kubernetes/.forgejo/workflows/argocd-diff-preview.yaml

80 lines
2.8 KiB
YAML
Raw Normal View History

2026-03-23 19:57:46 +01:00
---
name: ArgoCD Diff
on:
workflow_dispatch:
workflow_call:
pull_request:
branches:
- main
jobs:
argocd-diff-preview:
runs-on: docker
2026-05-29 09:54:46 +02:00
container:
options: --volume /var/run/docker.sock:/var/run/docker.sock
2026-03-23 19:57:46 +01:00
env:
PR_NUMBER: ${{ forge.event.pull_request.number }}
2026-03-23 20:02:02 +01:00
GITHUB_TOKEN: ${{ secrets.FORGEJO_TOKEN }}
2026-03-23 19:57:46 +01:00
steps:
2026-05-29 09:38:00 +02:00
- uses: https://github.com/actions/checkout@v6
2026-03-23 19:57:46 +01:00
with:
path: pull-request
2026-05-29 09:38:00 +02:00
- uses: https://github.com/actions/checkout@v6
2026-03-23 19:57:46 +01:00
with:
ref: main
path: main
2026-05-29 09:43:03 +02:00
- name: Install Docker CLI
run: |
if command -v apt-get &>/dev/null; then
apt-get update -qq && apt-get install -y --no-install-recommends docker.io
elif command -v apk &>/dev/null; then
apk add --no-cache docker-cli
fi
2026-03-23 19:57:46 +01:00
- name: Generate Diff
run: |
2026-05-29 12:15:45 +02:00
CONTAINER_ID=$(docker inspect --format='{{.Id}}' "$HOSTNAME")
docker cp "$CONTAINER_ID:$(pwd)/main" /tmp/argocd-main
docker cp "$CONTAINER_ID:$(pwd)/pull-request" /tmp/argocd-pr
mkdir -p output
docker run --rm \
2026-05-29 09:54:46 +02:00
--network=host \
-v /var/run/docker.sock:/var/run/docker.sock \
2026-05-29 12:15:45 +02:00
-v /tmp/argocd-main:/base-branch \
-v /tmp/argocd-pr:/target-branch \
-v /tmp/argocd-output:/output \
2026-03-23 19:57:46 +01:00
-e TARGET_BRANCH=refs/pull/$PR_NUMBER/merge \
-e REPO=${{ forge.repository }} \
2026-05-29 09:38:00 +02:00
dagandersen/argocd-diff-preview:v0.2.8
2026-03-23 19:57:46 +01:00
- name: Add comment
id: comment
run: |
DIFF_BODY=$(cat output/diff.md)
payload="{\"body\": $DIFF_BODY}"
existing_comment=$(curl -s \
-H "Authorization: token ${{ secrets.FORGEJO_TOKEN }}" \
"${{ forge.api_url }}/repos/${{ forge.repository }}/issues/$PR_NUMBER/comments")
comment_id=$(echo "$existing_comment" | jq -r \
'.[] | select(.body | test("${{ forge.workflow }}")) | .id' | head -n 1)
if [ -n "${comment_id}" ] && [ "${comment_id}" != "null" ]; then
echo "Found comment with id ${comment_id}, updating..." && \
curl -s -X PATCH \
-H "Authorization: token ${{ secrets.FORGEJO_TOKEN }}" \
-H "Content-Type: application/json" \
"${{ forge.api_url }}/repos/${{ forge.repository }}/issues/comments/${comment_id}" \
-d "$payload"
else
echo "Creating new comment..." && \
curl -s -X POST \
-H "Authorization: token ${{ secrets.FORGEJO_TOKEN }}" \
-H "Content-Type: application/json" \
"${{ forge.api_url }}/repos/${{ forge.repository }}/issues/$PR_NUMBER/comments" \
-d "$payload"
fi