Testing out find PR action.
This commit is contained in:
@@ -18,115 +18,110 @@ jobs:
|
|||||||
- name: Checkout Code
|
- name: Checkout Code
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Check if PR Exists
|
- name: Find Current PR
|
||||||
id: check-pr
|
id: findPr
|
||||||
run: |
|
uses: jwalton/gh-find-current-pr@v1.3.3
|
||||||
echo "Checking for existing PR..."
|
|
||||||
curl ${{ vars.RINOA_GITEA_URL }}/api/v1/repos/${{ github.repository }}/pulls/main/${{ github.ref_name }} \
|
|
||||||
-X 'GET' \
|
|
||||||
-H 'Accept: application/json' \
|
|
||||||
-H 'Authorization: token ${{ secrets.BOT_GITEA_TOKEN }}' \
|
|
||||||
-s | jq '{index: .number, state: .state}' > pr_status.json
|
|
||||||
echo "pr_status=$(jq -c . pr_status.json)" >> "$GITHUB_OUTPUT"
|
|
||||||
|
|
||||||
- name: Create PR in Gitea
|
|
||||||
if: ${{ steps.check-pr.outputs.pr_status.state }} == 'closed'
|
|
||||||
id: create-pr
|
|
||||||
run: |
|
|
||||||
echo "Creating PR..."
|
|
||||||
curl ${{ vars.RINOA_GITEA_URL }}/api/v1/repos/${{ github.repository }}/pulls \
|
|
||||||
-X 'POST' \
|
|
||||||
-H 'Accept: application/json' \
|
|
||||||
-H 'Authorization: token ${{ secrets.BOT_GITEA_TOKEN }}' \
|
|
||||||
-H 'Content-Type: application/json' \
|
|
||||||
-d '{
|
|
||||||
"title": "PR: ${{ github.ref_name }} -> main",
|
|
||||||
"body": "This is an automated PR created by Gitea Actions.",
|
|
||||||
"base": "main",
|
|
||||||
"head": "${{ github.ref_name }}"
|
|
||||||
}' | jq '{index: .number}' > pr_created.json
|
|
||||||
echo "pr_created=$(jq -c . pr_created.json)" >> "$GITHUB_OUTPUT"
|
|
||||||
|
|
||||||
# Job 2: Run SonarQube Analysis
|
|
||||||
sonarqube-analysis:
|
|
||||||
name: SonarQube Analysis
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
needs: check-and-create-pr
|
|
||||||
steps:
|
|
||||||
- name: Checkout Code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
# - name: Start Gitea-Sonarqube Bot
|
|
||||||
# uses: docker://justusbunsi/gitea-sonarqube-bot:v0.3.3
|
|
||||||
# with:
|
|
||||||
# # Required inputs for the bot
|
|
||||||
# args: >
|
|
||||||
# --sonarqube-url ${{ secrets.SONARQUBE_URL }}
|
|
||||||
# --sonarqube-token ${{ secrets.SONARQUBE_TOKEN }}
|
|
||||||
# --git-provider github
|
|
||||||
# --git-api-url https://api.github.com
|
|
||||||
# --git-token ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
# --repository my-org/my-repo
|
|
||||||
# --pull-request-id ${{ github.event.pull_request.number }}
|
|
||||||
|
|
||||||
- name: SonarQube Scan
|
|
||||||
uses: sonarsource/sonarqube-scan-action@v4.1.0
|
|
||||||
env:
|
|
||||||
SONAR_HOST_URL: ${{ secrets.SONARQUBE_HOST }}
|
|
||||||
SONAR_TOKEN: ${{ secrets.SONARQUBE_TOKEN }}
|
|
||||||
|
|
||||||
- name: SonarQube Quality Gate
|
|
||||||
id: quality-gate
|
|
||||||
uses: sonarsource/sonarqube-quality-gate-action@v1.1.0
|
|
||||||
env:
|
|
||||||
SONAR_HOST_URL: ${{ secrets.SONARQUBE_HOST }}
|
|
||||||
SONAR_TOKEN: ${{ secrets.SONARQUBE_TOKEN }}
|
|
||||||
|
|
||||||
- name: Custom Quality Gate Check
|
|
||||||
uses: DesarrolloORT/sonarqube-quality-gate-action@v1.0.1
|
|
||||||
id: quality-gate-check
|
|
||||||
with:
|
with:
|
||||||
sonar-project-key: rinoa-docker
|
state: open
|
||||||
sonar-host-url: ${{ secrets.SONARQUBE_HOST }}
|
# - name: Check if PR Exists
|
||||||
sonar-token: ${{ secrets.SONARQUBE_TOKEN }}
|
# id: check-pr
|
||||||
|
# run: |
|
||||||
|
# echo "Checking for existing PR..."
|
||||||
|
# curl ${{ vars.RINOA_GITEA_URL }}/api/v1/repos/${{ github.repository }}/pulls/main/${{ github.ref_name }} \
|
||||||
|
# -X 'GET' \
|
||||||
|
# -H 'Accept: application/json' \
|
||||||
|
# -H 'Authorization: token ${{ secrets.BOT_GITEA_TOKEN }}' \
|
||||||
|
# -s | jq '{index: .number, state: .state}' > pr_status.json
|
||||||
|
# echo "pr_status=$(jq -c . pr_status.json)" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
- name: JSON clean-up for proccessing...
|
# - name: Create PR in Gitea
|
||||||
id: json-cleanup
|
# if: ${{ steps.check-pr.outputs.pr_status.state }} == 'closed'
|
||||||
run: |
|
# id: create-pr
|
||||||
echo "Cleaning up quality gate response..."
|
# run: |
|
||||||
echo '${{ steps.quality-gate-check.outputs.quality-gate-result }}' > qg_input.txt
|
# echo "Creating PR..."
|
||||||
sed -E 's/([a-zA-Z0-9_]+):/\\"\1\\":/g; s/:([^",{}\[\]]+)/:"\1"/g' qg_input.txt > qg_raw.json
|
# curl ${{ vars.RINOA_GITEA_URL }}/api/v1/repos/${{ github.repository }}/pulls \
|
||||||
jq -c '.' qg_raw.json > qg_fixed_json.json
|
# -X 'POST' \
|
||||||
projstatus=$(jq -r '.projectStatus.status' qg_fixed_json.json)
|
# -H 'Accept: application/json' \
|
||||||
echo "${projstatus}"
|
# -H 'Authorization: token ${{ secrets.BOT_GITEA_TOKEN }}' \
|
||||||
caycStatus=$(jq -r '.projectStatus.caycStatus' qg_fixed_json.json)
|
# -H 'Content-Type: application/json' \
|
||||||
echo "${caycStatus}"
|
# -d '{
|
||||||
conditions=$(jq -c '.projectStatus.conditions' qg_fixed_json.json)
|
# "title": "PR: ${{ github.ref_name }} -> main",
|
||||||
echo "${conditions}"
|
# "body": "This is an automated PR created by Gitea Actions.",
|
||||||
echo "projstatus=${projstatus}" >> $GITHUB_OUTPUT
|
# "base": "main",
|
||||||
echo "caycStatus=${caycStatus}" >> $GITHUB_OUTPUT
|
# "head": "${{ github.ref_name }}"
|
||||||
echo "conditions=${conditions}" >> $GITHUB_OUTPUT
|
# }' | jq '{index: .number}' > pr_created.json
|
||||||
echo "qg_fixed_json=$(cat qg_fixed_json.json)" >> $GITHUB_ENV
|
# echo "pr_created=$(jq -c . pr_created.json)" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
- name: Convert JSON to Markdown Table
|
# # Job 2: Run SonarQube Analysis
|
||||||
id: convert-json-to-md
|
# sonarqube-analysis:
|
||||||
uses: buildingcash/json-to-markdown-table-action@v1.1.0
|
# name: SonarQube Analysis
|
||||||
with:
|
# runs-on: ubuntu-latest
|
||||||
json: ${{ steps.json-cleanup.outputs.conditions }}
|
# needs: check-and-create-pr
|
||||||
|
# steps:
|
||||||
|
# - name: Checkout Code
|
||||||
|
# uses: actions/checkout@v4
|
||||||
|
|
||||||
|
# # - name: Start Gitea-Sonarqube Bot
|
||||||
|
# # uses: docker://justusbunsi/gitea-sonarqube-bot:v0.3.3
|
||||||
|
# # with:
|
||||||
|
# # # Required inputs for the bot
|
||||||
|
# # args: >
|
||||||
|
# # --sonarqube-url ${{ secrets.SONARQUBE_URL }}
|
||||||
|
# # --sonarqube-token ${{ secrets.SONARQUBE_TOKEN }}
|
||||||
|
# # --git-provider github
|
||||||
|
# # --git-api-url https://api.github.com
|
||||||
|
# # --git-token ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
# # --repository my-org/my-repo
|
||||||
|
# # --pull-request-id ${{ github.event.pull_request.number }}
|
||||||
|
|
||||||
|
# - name: SonarQube Scan
|
||||||
|
# uses: sonarsource/sonarqube-scan-action@v4.1.0
|
||||||
|
# env:
|
||||||
|
# SONAR_HOST_URL: ${{ secrets.SONARQUBE_HOST }}
|
||||||
|
# SONAR_TOKEN: ${{ secrets.SONARQUBE_TOKEN }}
|
||||||
|
|
||||||
|
# - name: SonarQube Quality Gate
|
||||||
|
# id: quality-gate
|
||||||
|
# uses: sonarsource/sonarqube-quality-gate-action@v1.1.0
|
||||||
|
# env:
|
||||||
|
# SONAR_HOST_URL: ${{ secrets.SONARQUBE_HOST }}
|
||||||
|
# SONAR_TOKEN: ${{ secrets.SONARQUBE_TOKEN }}
|
||||||
|
|
||||||
|
# - name: Custom Quality Gate Check
|
||||||
|
# uses: DesarrolloORT/sonarqube-quality-gate-action@v1.0.1
|
||||||
|
# id: quality-gate-check
|
||||||
|
# with:
|
||||||
|
# sonar-project-key: rinoa-docker
|
||||||
|
# sonar-host-url: ${{ secrets.SONARQUBE_HOST }}
|
||||||
|
# sonar-token: ${{ secrets.SONARQUBE_TOKEN }}
|
||||||
|
|
||||||
|
# - name: JSON clean-up for proccessing...
|
||||||
|
# id: json-cleanup
|
||||||
|
# run: |
|
||||||
|
# echo "Cleaning up quality gate response..."
|
||||||
|
# echo '${{ steps.quality-gate-check.outputs.quality-gate-result }}' > qg_input.txt
|
||||||
|
# sed -E 's/([a-zA-Z0-9_]+):/\\"\1\\":/g; s/:([^",{}\[\]]+)/:"\1"/g' qg_input.txt > qg_raw.json
|
||||||
|
# jq -c '.' qg_raw.json > qg_fixed_json.json
|
||||||
|
# projstatus=$(jq -r '.projectStatus.status' qg_fixed_json.json)
|
||||||
|
# echo "${projstatus}"
|
||||||
|
# caycStatus=$(jq -r '.projectStatus.caycStatus' qg_fixed_json.json)
|
||||||
|
# echo "${caycStatus}"
|
||||||
|
# conditions=$(jq -c '.projectStatus.conditions' qg_fixed_json.json)
|
||||||
|
# echo "${conditions}"
|
||||||
|
# echo "projstatus=${projstatus}" >> $GITHUB_OUTPUT
|
||||||
|
# echo "caycStatus=${caycStatus}" >> $GITHUB_OUTPUT
|
||||||
|
# echo "conditions=${conditions}" >> $GITHUB_OUTPUT
|
||||||
|
# echo "qg_fixed_json=$(cat qg_fixed_json.json)" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
# - name: Convert JSON to Markdown Table
|
||||||
|
# id: convert-json-to-md
|
||||||
|
# uses: buildingcash/json-to-markdown-table-action@v1.1.0
|
||||||
|
# with:
|
||||||
|
# json: ${{ steps.json-cleanup.outputs.conditions }}
|
||||||
|
|
||||||
# - name: Post SonarQube Results as Comment
|
|
||||||
# run: |
|
|
||||||
# curl ${{ vars.RINOA_GITEA_URL }}/api/v1/repos/${{ github.repository }}/pulls/${{ github.pull_request.number }}/reviews \
|
|
||||||
# -X POST \
|
|
||||||
# -H 'Accept: application/json' \
|
|
||||||
# -H 'Authorization: token ${{ secrets.BOT_GITEA_TOKEN }}' \
|
|
||||||
# -H 'Content-Type: application/json' \
|
|
||||||
# -d '{
|
|
||||||
# "body": "SonarQube analysis results:\n\n- Bugs: ${{ env.SONAR_BUGS }}\n- Vulnerabilities: ${{ env.SONAR_VULNERABILITIES }}\n- Code Smells: ${{ env.SONAR_CODE_SMELLS }}\n- Coverage: ${{ env.SONAR_COVERAGE }}%\n- Duplications: ${{ env.SONAR_DUPLICATIONS }}%\n- Quality Gate Status: ${{ env.SONAR_QUALITY_GATE_STATUS }}"
|
|
||||||
# }'
|
|
||||||
- name: Verify PR number
|
- name: Verify PR number
|
||||||
run: |
|
run: |
|
||||||
echo "PR number: ${{ github.event.pull_request.number }}"
|
echo "PR number: ${{ steps.findPr.outputs.pr }}"
|
||||||
|
|
||||||
# - name: Post SonarQube Results as Comment
|
# - name: Post SonarQube Results as Comment
|
||||||
# run: |
|
# run: |
|
||||||
|
|||||||
Reference in New Issue
Block a user