updating gh-action-pypi-publish again #749
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Signature Test | |
on: | |
pull_request: | |
types: [opened, synchronize, reopened] | |
jobs: | |
signature-test: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Python | |
uses: actions/setup-python@v4 | |
with: | |
python-version: '3.10' | |
- name: Install dependencies | |
run: | | |
pip install poetry | |
poetry install | |
- name: Check for specific string in PR title and creator | |
id: check_conditions | |
run: | | |
pr_title="${{ github.event.pull_request.title }}" | |
pr_creator="${{ github.event.pull_request.user.login }}" | |
echo "Pull Request title: $pr_title" > signaturetest.log | |
echo "Pull Request creator: $pr_creator" >> signaturetest.log | |
if [[ "$pr_title" == "[SignatureBot]"* ]]; then | |
echo "::set-output name=is_new_signature_pr::true" | |
echo "PR $pr_title Qualified" >> signaturetest.log | |
else | |
echo "::set-output name=is_new_signature_pr::false" | |
echo "PR $pr_title NOT Qualified" >> signaturetest.log | |
fi | |
env: | |
GH_TOKEN: ${{ secrets.DNSBOT_TOKEN }} | |
- name: Run signature test | |
if: steps.check_conditions.outputs.is_new_signature_pr == 'true' | |
id: signature_test | |
run: | | |
PR_NUMBER=${{ github.event.pull_request.number }} | |
FILE=$(gh pr diff $PR_NUMBER --name-only | grep -v "signature_history.txt") | |
echo "Running signature test against: $FILE" >> signaturetest.log | |
OUTPUT=$(poetry run python3 baddns/scripts/signaturetest.py $FILE) | |
echo "$OUTPUT" > output.json | |
echo "Run finished with this output: $OUTPUT" >> signaturetest.log | |
echo "::set-output name=result::$OUTPUT" | |
SIGNATURE_PASS=$(echo "$OUTPUT" | jq -r '.signature_pass') | |
if [ "$SIGNATURE_PASS" == "true" ] | |
then | |
echo "Signature test passed, adding 'tests-passed' label to PR..." >> signaturetest.log | |
gh pr edit $PR_NUMBER --remove-label "tests-failed" | |
gh pr edit $PR_NUMBER --add-label "tests-passed" | |
else | |
echo "Signature test failed, adding 'tests-failed' label to PR..." >> signaturetest.log | |
gh pr edit $PR_NUMBER --remove-label "tests-passed" | |
gh pr edit $PR_NUMBER --add-label "tests-failed" | |
fi | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Post result comment | |
if: always() && steps.check_conditions.outputs.is_new_signature_pr == 'true' | |
run: | | |
output=$(cat output.json) | |
signature_pass=$(echo $output | jq -r '.signature_pass') | |
match_table=$(echo $output | jq -r '.match_table') | |
error=$(echo $output | jq -r '.error') | |
if [[ "$signature_pass" == "true" ]]; then | |
emoji=":heavy_check_mark:" | |
else | |
emoji=":x:" | |
fi | |
comment="**Test results**: | |
Signature Pass: **$signature_pass** $emoji" | |
if [[ "$match_table" != "{}" ]]; then | |
comment+=$'\n\nMatch Table:\n\n| Domain | Match |\n| --- | --- |' | |
while IFS="|" read -r domain match; do | |
comment+=$'\n| '"$domain"' | '"$match"' |' | |
done < <(echo "$match_table" | jq -r 'to_entries[] | "\(.key)|\(.value)"') | |
fi | |
if [[ "$signature_pass" == "false" ]]; then | |
comment+=" | |
Error: **$error**" | |
fi | |
echo "Attempting to add comment to PR..." >> signaturetest.log | |
gh pr comment "${{ github.event.pull_request.number }}" --body "$comment" | |
env: | |
GH_TOKEN: ${{ secrets.DNSBOT_TOKEN }} | |
- name: Upload Signature Test Log | |
uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: signature-test-log | |
path: signaturetest.log |