aboutsummaryrefslogtreecommitdiff
path: root/.github/workflows
diff options
context:
space:
mode:
authorCraig Jennings <c@cjennings.net>2026-05-05 10:15:00 -0500
committerCraig Jennings <c@cjennings.net>2026-05-05 10:15:00 -0500
commitbe96465271012b86010b9dee04abea8585dc177c (patch)
tree2212e6685a36fefa005662c8c0d3c51009068e89 /.github/workflows
parent6bb7f9b91304847d92222bf25ca6021fd82d468d (diff)
downloadorg-drill-be96465271012b86010b9dee04abea8585dc177c.tar.gz
org-drill-be96465271012b86010b9dee04abea8585dc177c.zip
ci: add GitHub Actions workflow with test matrix, lint, and coverage
Three jobs: - test: matrix across Emacs 28.2 / 29.4 / snapshot. Sets up Emacs via jcs090218/setup-emacs and Cask via cask/setup-cask, then runs make setup (with 3 retries to absorb MELPA flakes) and make test-unit. Org 9.6 ships built-in with Emacs 29; on 28 Cask pulls it from MELPA per our depends-on declaration. - lint: Emacs 29.4 only, runs make lint (informational), then make compile and make validate-parens. - coverage: same Emacs version, runs make coverage, prints a per-file summary via scripts/coverage-summary.py (copied from emacs-wttrin), uploads .coverage/simplecov.json as a workflow artifact, and sends results to Coveralls via continue-on-error so CI doesn't fail when COVERALLS_REPO_TOKEN isn't set yet. The README badge URL points at this workflow file (ci.yml) so it auto-populates on the next push to main. Closes the [#B] GitHub Actions TODO. After this lands, the remaining setup is enabling the org-drill repo on coveralls.io and adding COVERALLS_REPO_TOKEN as a GitHub secret so the upload step actually publishes.
Diffstat (limited to '.github/workflows')
-rw-r--r--.github/workflows/ci.yml138
1 files changed, 138 insertions, 0 deletions
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
new file mode 100644
index 0000000..6491867
--- /dev/null
+++ b/.github/workflows/ci.yml
@@ -0,0 +1,138 @@
+name: CI
+
+on:
+ push:
+ branches: [main]
+ pull_request:
+ branches: [main]
+
+jobs:
+ test:
+ name: Test (Emacs ${{ matrix.emacs-version }})
+ runs-on: ubuntu-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ emacs-version:
+ # Org 9.6 (our floor) ships built-in with Emacs 29; on Emacs
+ # 28 Cask pulls it from MELPA, so 28 still works as a target.
+ - '28.2'
+ - '29.4'
+ - 'snapshot'
+ steps:
+ - uses: actions/checkout@v4
+
+ - name: Set up Emacs
+ uses: jcs090218/setup-emacs@master
+ with:
+ version: ${{ matrix.emacs-version }}
+
+ - name: Set up Cask
+ uses: cask/setup-cask@master
+
+ - name: Install dependencies
+ run: |
+ for attempt in 1 2 3; do
+ if make setup; then
+ exit 0
+ fi
+ if [ "$attempt" -lt 3 ]; then
+ echo "::warning::setup attempt $attempt failed, retrying in 15s"
+ sleep 15
+ fi
+ done
+ echo "::error::setup failed after 3 attempts"
+ exit 1
+
+ - name: Run unit tests
+ run: make test-unit
+
+ lint:
+ name: Lint
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v4
+
+ - name: Set up Emacs
+ uses: jcs090218/setup-emacs@master
+ with:
+ version: '29.4'
+
+ - name: Set up Cask
+ uses: cask/setup-cask@master
+
+ - name: Install dependencies
+ run: |
+ for attempt in 1 2 3; do
+ if make setup; then
+ exit 0
+ fi
+ if [ "$attempt" -lt 3 ]; then
+ echo "::warning::setup attempt $attempt failed, retrying in 15s"
+ sleep 15
+ fi
+ done
+ echo "::error::setup failed after 3 attempts"
+ exit 1
+
+ # `make lint' is informational right now (the source has known
+ # docstring/style debt); kept here so warnings show up in PRs.
+ - name: Run linters
+ run: make lint
+
+ - name: Byte-compile
+ run: make compile
+
+ - name: Validate parens
+ run: make validate-parens
+
+ coverage:
+ name: Coverage
+ runs-on: ubuntu-latest
+ steps:
+ - uses: actions/checkout@v4
+
+ - name: Set up Emacs
+ uses: jcs090218/setup-emacs@master
+ with:
+ version: '29.4'
+
+ - name: Set up Cask
+ uses: cask/setup-cask@master
+
+ - name: Install dependencies
+ run: |
+ for attempt in 1 2 3; do
+ if make setup; then
+ exit 0
+ fi
+ if [ "$attempt" -lt 3 ]; then
+ echo "::warning::setup attempt $attempt failed, retrying in 15s"
+ sleep 15
+ fi
+ done
+ echo "::error::setup failed after 3 attempts"
+ exit 1
+
+ - name: Run coverage
+ run: make coverage
+
+ - name: Print coverage summary
+ run: python3 scripts/coverage-summary.py
+
+ - name: Upload coverage report
+ uses: actions/upload-artifact@v4
+ with:
+ name: coverage-simplecov
+ path: .coverage/simplecov.json
+ if-no-files-found: error
+ retention-days: 30
+
+ - name: Send coverage to Coveralls
+ uses: coverallsapp/github-action@v2
+ continue-on-error: true
+ with:
+ file: .coverage/simplecov.json
+ format: simplecov
+ env:
+ COVERALLS_REPO_TOKEN: ${{ secrets.COVERALLS_REPO_TOKEN }}