|
@@ -0,0 +1,93 @@
|
|
|
|
+name: Stable Backport Check
|
|
|
|
+on:
|
|
|
|
+ issue_comment:
|
|
|
|
+ pull_request:
|
|
|
|
+ types:
|
|
|
|
+ - labeled
|
|
|
|
+ - synchronize
|
|
|
|
+
|
|
|
|
+jobs:
|
|
|
|
+ check-backport:
|
|
|
|
+ name: Check Backport
|
|
|
|
+ if: ${{ ( github.event.issue.pull_request && contains(github.event.comment.body, '@jellyfin-bot check backport') ) || github.event.label.name == 'stable backport' || contains(github.event.pull_request.labels.*.name, 'stable backport' ) }}
|
|
|
|
+ runs-on: ubuntu-latest
|
|
|
|
+ steps:
|
|
|
|
+ - name: Notify as seen
|
|
|
|
+ uses: peter-evans/create-or-update-comment@v1.4.5
|
|
|
|
+ if: ${{ github.event.comment != null }}
|
|
|
|
+ with:
|
|
|
|
+ token: ${{ secrets.JF_BOT_TOKEN }}
|
|
|
|
+ comment-id: ${{ github.event.comment.id }}
|
|
|
|
+ reactions: eyes
|
|
|
|
+
|
|
|
|
+ - name: Checkout the latest code
|
|
|
|
+ uses: actions/checkout@v2
|
|
|
|
+ with:
|
|
|
|
+ token: ${{ secrets.JF_BOT_TOKEN }}
|
|
|
|
+ fetch-depth: 0
|
|
|
|
+
|
|
|
|
+ - name: Notify as running
|
|
|
|
+ id: comment_running
|
|
|
|
+ uses: peter-evans/create-or-update-comment@v1.4.5
|
|
|
|
+ if: ${{ github.event.comment != null }}
|
|
|
|
+ with:
|
|
|
|
+ token: ${{ secrets.JF_BOT_TOKEN }}
|
|
|
|
+ issue-number: ${{ github.event.issue.number }}
|
|
|
|
+ body: |
|
|
|
|
+ Running backport tests...
|
|
|
|
+
|
|
|
|
+ - name: Perform test backport
|
|
|
|
+ id: run_tests
|
|
|
|
+ run: |
|
|
|
|
+ set +o errexit
|
|
|
|
+ git config --global user.name "Jellyfin Bot"
|
|
|
|
+ git config --global user.email "team@jellyfin.org"
|
|
|
|
+ CURRENT_BRANCH="origin/${GITHUB_HEAD_REF}"
|
|
|
|
+ git checkout master
|
|
|
|
+ git merge --no-ff ${CURRENT_BRANCH}
|
|
|
|
+ MERGE_COMMIT_HASH=$( git log -q -1 | head -1 | awk '{ print $2 }' )
|
|
|
|
+ git fetch --all
|
|
|
|
+ CURRENT_STABLE=$( git branch -r | grep 'origin/release' | sort -rV | head -1 | awk -F '/' '{ print $NF }' )
|
|
|
|
+ stable_branch="Current stable release branch: ${CURRENT_STABLE}"
|
|
|
|
+ echo ${stable_branch}
|
|
|
|
+ echo ::set-output name=branch::${stable_branch}
|
|
|
|
+ git checkout -t origin/${CURRENT_STABLE} -b ${CURRENT_STABLE}
|
|
|
|
+ git cherry-pick -sx -m1 ${MERGE_COMMIT_HASH} &>output.txt
|
|
|
|
+ retcode=$?
|
|
|
|
+ cat output.txt | grep -v 'hint:'
|
|
|
|
+ output="$( grep -v 'hint:' output.txt )"
|
|
|
|
+ output="${output//'%'/'%25'}"
|
|
|
|
+ output="${output//$'\n'/'%0A'}"
|
|
|
|
+ output="${output//$'\r'/'%0D'}"
|
|
|
|
+ echo ::set-output name=output::$output
|
|
|
|
+ exit ${retcode}
|
|
|
|
+
|
|
|
|
+ - name: Notify with result success
|
|
|
|
+ uses: peter-evans/create-or-update-comment@v1.4.5
|
|
|
|
+ if: ${{ github.event.comment != null && success() }}
|
|
|
|
+ with:
|
|
|
|
+ token: ${{ secrets.JF_BOT_TOKEN }}
|
|
|
|
+ comment-id: ${{ steps.comment_running.outputs.comment-id }}
|
|
|
|
+ body: |
|
|
|
|
+ ${{ steps.run_tests.outputs.branch }}
|
|
|
|
+ Output from `git cherry-pick`:
|
|
|
|
+
|
|
|
|
+ ---
|
|
|
|
+
|
|
|
|
+ ${{ steps.run_tests.outputs.output }}
|
|
|
|
+ reactions: hooray
|
|
|
|
+
|
|
|
|
+ - name: Notify with result failure
|
|
|
|
+ uses: peter-evans/create-or-update-comment@v1.4.5
|
|
|
|
+ if: ${{ github.event.comment != null && failure() }}
|
|
|
|
+ with:
|
|
|
|
+ token: ${{ secrets.JF_BOT_TOKEN }}
|
|
|
|
+ comment-id: ${{ steps.comment_running.outputs.comment-id }}
|
|
|
|
+ body: |
|
|
|
|
+ ${{ steps.run_tests.outputs.branch }}
|
|
|
|
+ Output from `git cherry-pick`:
|
|
|
|
+
|
|
|
|
+ ---
|
|
|
|
+
|
|
|
|
+ ${{ steps.run_tests.outputs.output }}
|
|
|
|
+ reactions: confused
|