ci: add notify-failure, deploy tagging, and coverage reporting
Lint / Python (flake8) (push) Failing after 20s
Lint / JS (eslint) (push) Successful in 7s
Security / Python Security (bandit) (push) Failing after 22s
Test / Python Tests (pytest) (push) Successful in 30s
Lint / Notify on failure (push) Successful in 2s
Lint / Deploy (push) Has been skipped

- lint.yml: add notify-failure Matrix alert job; add Tag deployed commit
  step to deploy job with deploy-YYYY.MM.DD-N tagging via Gitea API
- test.yml: add pytest-cov for coverage reporting
- .coveragerc: omit tests and site-packages from coverage

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-04-14 15:16:02 -04:00
parent 7cd39bbe9b
commit 2c4e8fcfda
3 changed files with 41 additions and 3 deletions
+7
View File
@@ -0,0 +1,7 @@
[run]
omit =
tests/*
*/site-packages/*
[report]
show_missing = True
+31
View File
@@ -34,11 +34,31 @@ jobs:
- name: Run ESLint - name: Run ESLint
run: npx eslint --ext .js static/ run: npx eslint --ext .js static/
notify-failure:
name: Notify on failure
runs-on: ubuntu-latest
needs: [python-lint, js-lint]
if: failure() && github.event_name == 'push'
steps:
- name: Send Matrix alert
env:
MATRIX_WEBHOOK_URL: ${{ secrets.MATRIX_WEBHOOK_URL }}
REPO: ${{ github.repository }}
BRANCH: ${{ github.ref_name }}
RUN_URL: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}
run: |
if [ -z "$MATRIX_WEBHOOK_URL" ] || [ "$MATRIX_WEBHOOK_URL" = "CONFIGURE_ME" ]; then exit 0; fi
curl -sf -X POST "$MATRIX_WEBHOOK_URL" \
-H "Content-Type: application/json" \
-d "{\"text\":\"CI FAILED: ${REPO} @ ${BRANCH} — ${RUN_URL}\"}"
deploy: deploy:
name: Deploy name: Deploy
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: [python-lint, js-lint] needs: [python-lint, js-lint]
if: github.event_name == 'push' && github.ref == 'refs/heads/main' if: github.event_name == 'push' && github.ref == 'refs/heads/main'
permissions:
contents: write
steps: steps:
- name: Trigger webhook - name: Trigger webhook
env: env:
@@ -53,3 +73,14 @@ jobs:
-H "X-Gitea-Signature: ${SIG}" \ -H "X-Gitea-Signature: ${SIG}" \
-d "$PAYLOAD" \ -d "$PAYLOAD" \
"http://10.10.10.61:9000/hooks/gandalf-deploy" "http://10.10.10.61:9000/hooks/gandalf-deploy"
- name: Tag deployed commit
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
TAG="deploy-$(date -u +%Y.%m.%d)-${{ github.run_number }}"
curl -sf -X POST \
-H "Authorization: token $GITHUB_TOKEN" \
-H "Content-Type: application/json" \
-d "{\"tag_name\":\"${TAG}\",\"target\":\"${{ github.sha }}\",\"message\":\"Deployed to production\"}" \
"https://code.lotusguild.org/api/v1/repos/${{ github.repository }}/tags"
+3 -3
View File
@@ -17,8 +17,8 @@ jobs:
run: | run: |
apt-get update -qq apt-get update -qq
apt-get install -y -qq python3 python3-pip apt-get install -y -qq python3 python3-pip
pip3 install pytest pip3 install pytest pytest-cov
pip3 install -r requirements.txt --quiet pip3 install -r requirements.txt --quiet
- name: Run pytest - name: Run pytest with coverage
run: python3 -m pytest tests/ -v run: python3 -m pytest tests/ -v --cov=. --cov-report=term-missing --cov-config=.coveragerc