From 1717965bf98b896ae89dedf7b59aecc8f631d1d2 Mon Sep 17 00:00:00 2001 From: Gabor Szarnyas Date: Sat, 24 Aug 2024 08:25:13 +0200 Subject: [PATCH] CI: Add issue mirroring jobs --- .../workflows/InternalIssuesCreateMirror.yml | 36 ++++++++++++++ .../workflows/InternalIssuesUpdateMirror.yml | 48 +++++++++++++++++++ 2 files changed, 84 insertions(+) create mode 100644 .github/workflows/InternalIssuesCreateMirror.yml create mode 100644 .github/workflows/InternalIssuesUpdateMirror.yml diff --git a/.github/workflows/InternalIssuesCreateMirror.yml b/.github/workflows/InternalIssuesCreateMirror.yml new file mode 100644 index 00000000..a94d359b --- /dev/null +++ b/.github/workflows/InternalIssuesCreateMirror.yml @@ -0,0 +1,36 @@ +name: Create or Label Mirror Issue +on: + issues: + types: + - labeled + +env: + GH_TOKEN: ${{ secrets.DUCKDBLABS_BOT_TOKEN }} + TITLE_PREFIX: "[duckdb-java/#${{ github.event.issue.number }}]" + PUBLIC_ISSUE_TITLE: ${{ github.event.issue.title }} + +jobs: + create_or_label_issue: + if: github.event.label.name == 'reproduced' + runs-on: ubuntu-latest + steps: + - name: Get mirror issue number + run: | + gh issue list --repo duckdblabs/duckdb-internal --search "${TITLE_PREFIX}" --json title,number --state all --jq ".[] | select(.title | startswith(\"$TITLE_PREFIX\")).number" > mirror_issue_number.txt + echo "MIRROR_ISSUE_NUMBER=$(cat mirror_issue_number.txt)" >> $GITHUB_ENV + + - name: Print whether mirror issue exists + run: | + if [ "$MIRROR_ISSUE_NUMBER" == "" ]; then + echo "Mirror issue with title prefix '$TITLE_PREFIX' does not exist yet" + else + echo "Mirror issue with title prefix '$TITLE_PREFIX' exists with number $MIRROR_ISSUE_NUMBER" + fi + + - name: Create or label issue + run: | + export LABEL="JDBC" + if [ "$MIRROR_ISSUE_NUMBER" == "" ]; then + gh issue create --repo duckdblabs/duckdb-internal --label "$LABEL" --title "$TITLE_PREFIX - $PUBLIC_ISSUE_TITLE" --body "See https://github.com/duckdb/duckdb-java/issues/${{ github.event.issue.number }}" + fi + diff --git a/.github/workflows/InternalIssuesUpdateMirror.yml b/.github/workflows/InternalIssuesUpdateMirror.yml new file mode 100644 index 00000000..9b2192b2 --- /dev/null +++ b/.github/workflows/InternalIssuesUpdateMirror.yml @@ -0,0 +1,48 @@ +name: Update Mirror Issue +on: + issues: + types: + - closed + - reopened + +env: + GH_TOKEN: ${{ secrets.DUCKDBLABS_BOT_TOKEN }} + TITLE_PREFIX: "[duckdb-wasm/#${{ github.event.issue.number }}]" + +jobs: + update_mirror_issue: + runs-on: ubuntu-latest + steps: + - name: Get mirror issue number + run: | + gh issue list --repo duckdblabs/duckdb-internal --search "${TITLE_PREFIX}" --json title,number --state all --jq ".[] | select(.title | startswith(\"$TITLE_PREFIX\")).number" > mirror_issue_number.txt + echo "MIRROR_ISSUE_NUMBER=$(cat mirror_issue_number.txt)" >> $GITHUB_ENV + + - name: Print whether mirror issue exists + run: | + if [ "$MIRROR_ISSUE_NUMBER" == "" ]; then + echo "Mirror issue with title prefix '$TITLE_PREFIX' does not exist yet" + else + echo "Mirror issue with title prefix '$TITLE_PREFIX' exists with number $MIRROR_ISSUE_NUMBER" + fi + + - name: Add comment with status to mirror issue + run: | + if [ "$MIRROR_ISSUE_NUMBER" != "" ]; then + gh issue comment --repo duckdblabs/duckdb-internal $MIRROR_ISSUE_NUMBER --body "The issue has been ${{ github.event.action }} (https://github.com/duckdb/duckdb-wasm/issues/${{ github.event.issue.number }})." + fi + + - name: Add closed label to mirror issue + if: github.event.action == 'closed' + run: | + if [ "$MIRROR_ISSUE_NUMBER" != "" ]; then + gh issue edit --repo duckdblabs/duckdb-internal $MIRROR_ISSUE_NUMBER --add-label "public closed" --remove-label "public reopened" + fi + + - name: Reopen mirror issue and add reopened label + if: github.event.action == 'reopened' + run: | + if [ "$MIRROR_ISSUE_NUMBER" != "" ]; then + gh issue reopen --repo duckdblabs/duckdb-internal $MIRROR_ISSUE_NUMBER + gh issue edit --repo duckdblabs/duckdb-internal $MIRROR_ISSUE_NUMBER --add-label "public reopened" --remove-label "public closed" + fi