Skip to content

Commit

Permalink
[Refactor] workflow move to github-lib-template
Browse files Browse the repository at this point in the history
  • Loading branch information
JanGalek committed Dec 14, 2024
1 parent 2736501 commit 094bd2b
Showing 1 changed file with 4 additions and 164 deletions.
168 changes: 4 additions & 164 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,167 +16,7 @@ on:
default: 'stable'

jobs:
release:
runs-on: ubuntu-latest

steps:
- name: Checkout code
uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Install GitHub CLI
run: |
sudo apt-get update
sudo apt-get install -y gh
- name: Authenticate GitHub CLI
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: gh auth setup-git

- name: Determine release type
id: release_type
run: |
TAG_NAME=${{ github.ref_name }}
if [[ "$TAG_NAME" == *beta* ]]; then
echo "release_type=Pre-release (Beta)" >> $GITHUB_ENV
echo "prerelease=true" >> $GITHUB_ENV
elif [[ "$TAG_NAME" == *rc* ]]; then
echo "release_type=Pre-release (Release Candidate)" >> $GITHUB_ENV
echo "prerelease=true" >> $GITHUB_ENV
else
echo "release_type=Stable" >> $GITHUB_ENV
echo "prerelease=false" >> $GITHUB_ENV
fi
- name: Get commits since last tag
id: commits
run: |
# Získání aktuálního tagu
CURRENT_TAG=$(git describe --tags --abbrev=0 HEAD)
# Funkce pro získání předchozího stabilního tagu
get_previous_stable_tag() {
PREV_TAG=""
# Procházej všechny tagy v obráceném pořadí (od nejnovějšího)
for tag in $(git tag --sort=-creatordate); do
# Pokud je tag stabilní (např. v1.0.0, v1.2.3, atd.), ale není stejný jako aktuální
if [[ "$tag" =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]] && [[ "$tag" != "$CURRENT_TAG" ]]; then
PREV_TAG=$tag
break
fi
done
echo $PREV_TAG
}
# Pokud je aktuální tag beta nebo rc, najdi poslední stabilní verzi
if [[ "$CURRENT_TAG" =~ -beta || "$CURRENT_TAG" =~ -rc ]]; then
# Najdi poslední stabilní verzi (ignoruj beta/rc tagy)
PREV_TAG=$(git tag --sort=-creatordate | grep -E '^v[0-9]+\.[0-9]+\.[0-9]+$' | head -n 1)
else
# Pokud je stabilní verze, použij předchozí stabilní tag
PREV_TAG=$(git tag --sort=-creatordate | grep -E '^v[0-9]+\.[0-9]+\.[0-9]+$' | grep -B 1 "$CURRENT_TAG" | head -n 1)
fi
if [[ "$CURRENT_TAG" == "$PREV_TAG" ]]; then
echo "Current tag is the same as the previous tag, using the previous stable tag."
PREV_TAG=$(get_previous_stable_tag)
fi
if [ -z "$PREV_TAG" ]; then
echo "No previous tag found, using initial commit."
PREV_TAG=$(git rev-list --max-parents=0 HEAD)
fi
echo "PREV TAG: $PREV_TAG"
echo "CURRENT TAG: $CURRENT_TAG"
COMMITS="<ul>"
declare -A FIXUPS
# Iterace přes všechny commity od posledního tagu
while read -r commit_hash; do
COMMIT_MSG=$(git log -n 1 --pretty=format:"%s" "$commit_hash")
AUTHOR=$(gh api "/repos/${{ github.repository }}/commits/$commit_hash" --jq '.author.login')
# Kontrola, zda jde o fixup commit
if [[ "$COMMIT_MSG" == fixup!* ]]; then
ORIGINAL_HASH=$(git log -n 1 --format="%H" "$commit_hash"^)
FIXUPS["$ORIGINAL_HASH"]+="$commit_hash "
continue
fi
# Hledání uzavřených issue nebo PR pro tento commit
COMMIT_URL="https://github.com/${{ github.repository }}/commit/$commit_hash"
echo "Checking commit: $COMMIT_URL"
ISSUE_URLS=$(gh api "/repos/${{ github.repository }}/issues?state=closed" --jq "[.[] | select(.body != null and (.body | test(\"(Resolve|Close).*${commit_hash}\")))][].html_url" || echo "")
ISSUE_COMMENT_URLS=$(gh api "/repos/${{ github.repository }}/issues/comments" --jq "[.[] | select(.body != null and (.body | test(\"(Resolve|Close).*${commit_hash}\")))][].html_url" || echo "")
PR_URLS=$(gh api "/repos/${{ github.repository }}/pulls?state=all" --jq "[.[] | select(.body != null and (.body | contains(\"${commit_hash}\")))][].html_url" || echo "")
REFERENCES="$ISSUE_URLS $ISSUE_COMMENT_URLS"
echo "VANILA"
echo "$ISSUE_URLS"
echo "$ISSUE_COMMENT_URLS"
echo "$PR_URLS"
ISSUE_URLS=$(echo "$ISSUE_URLS" | sed 's/#issuecomment-[0-9]*//g')
ISSUE_COMMENT_URLS=$(echo "$ISSUE_COMMENT_URLS" | sed 's/#issuecomment-[0-9]*//g')
echo "CLEARED"
echo "$ISSUE_URLS"
echo "$ISSUE_COMMENT_URLS"
echo "$PR_URLS"
# Zpracování běžného commitu
COMMITS+="<li>$COMMIT_MSG (@$AUTHOR)"
# Přidání všech odkazů na Issues
if [[ -n "$ISSUE_URLS" ]]; then
COMMITS+=", (Referenced in Issues: "
# Seznam odkazů oddělený mezerou
COMMITS+=$(echo "$ISSUE_URLS" | tr '\n' ' ' | sed -E "s|https://github.com/${{ github.repository }}/issues/([0-9]+)|<a href=\"https://github.com/${{ github.repository }}/issues/\1\">#\1</a>|g" | sed 's/ / , /g')
COMMITS=$(echo "$COMMITS" | sed 's/, $//')
COMMITS+=" )"
fi
# Přidání všech odkazů na komentáře
if [[ -n "$ISSUE_COMMENT_URLS" ]]; then
COMMITS+=", (Referenced in Comments: "
# Seznam odkazů oddělený mezerou
COMMITS+=$(echo "$ISSUE_COMMENT_URLS" | tr '\n' ' '| sed -E "s|https://github.com/${{ github.repository }}/issues/([0-9]+)|<a href=\"https://github.com/${{ github.repository }}/issues/\1\">#\1</a>|g" | sed 's/ / , /g')
COMMITS=$(echo "$COMMITS" | sed 's/, $//')
COMMITS+=" )"
fi
# Přidání všech odkazů na PRs
if [[ -n "$PR_URLS" ]]; then
COMMITS+=", (Referenced in PRs: "
COMMITS+=$(echo "$PR_URLS" | tr '\n' ' '| sed -E "s|https://github.com/${{ github.repository }}/pulls/([0-9]+)|<a href=\"https://github.com/${{ github.repository }}/pulls/\1\">#\1</a>|g" | sed 's/ / , /g')
COMMITS=$(echo "$COMMITS" | sed 's/, $//')
COMMITS+=" )"
fi
COMMITS+="</li>"
done < <(git log --format="%H" $PREV_TAG..HEAD)
COMMITS+="</ul>"
# Odstranění nechtěných znaků
COMMITS=$(echo "$COMMITS" | sed 's/[[:cntrl:]]//g')
echo "commits=$COMMITS" >> $GITHUB_ENV
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}

- name: Create release
uses: ncipollo/release-action@v1
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag: ${{ github.ref_name }}
body: |
${{ env.commits }}
draft: false
prerelease: ${{ env.prerelease }}
name: ${{ github.ref_name }} - ${{ env.release_type }}
call-release:
uses: gouef/github-lib-template/.github/workflows/shared_release.yml@main
with:
branch: ${{ github.ref_name }}

0 comments on commit 094bd2b

Please sign in to comment.