Skip to content

Commit

Permalink
Better on pr workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
dyakovri committed Apr 6, 2024
1 parent bc97f9b commit 008c0c0
Showing 1 changed file with 72 additions and 66 deletions.
138 changes: 72 additions & 66 deletions .github/workflows/checks.yml
Original file line number Diff line number Diff line change
@@ -1,67 +1,73 @@
#name: Python package
#
#on:
# pull_request:
#
#jobs:
# test:
# name: Unit tests
# runs-on: ubuntu-latest
# steps:
# - name: Checkout
# uses: actions/checkout@v4
# - name: Set up docker
# uses: docker-practice/actions-setup-docker@master
# - name: Run postgres
# run: |
# docker run -d -p 5432:5432 -e POSTGRES_HOST_AUTH_METHOD=trust --name db-test postgres:15-alpine
# - uses: actions/setup-python@v4
# with:
# python-version: '3.11'
# - name: Install dependencies
# run: |
# python -m ensurepip
# python -m pip install --upgrade --no-cache-dir pip
# python -m pip install --upgrade --no-cache-dir -r requirements.txt -r requirements.dev.txt
# - name: Migrate DB
# run: |
# DB_DSN=postgresql://postgres@localhost:5432/postgres alembic upgrade head
# - name: Build coverage file
# run: |
# DB_DSN=postgresql://postgres@localhost:5432/postgres pytest --junitxml=pytest.xml --cov-report=term-missing:skip-covered --cov=achievement_api tests/ | tee pytest-coverage.txt
# - name: Print report
# if: always()
# run: |
# cat pytest-coverage.txt
# - name: Pytest coverage comment
# uses: MishaKav/pytest-coverage-comment@main
# with:
# pytest-coverage-path: ./pytest-coverage.txt
# title: Coverage Report
# badge-title: Code Coverage
# hide-badge: false
# hide-report: false
# create-new-comment: false
# hide-comment: false
# report-only-changed-files: false
# remove-link-from-badge: false
# junitxml-path: ./pytest.xml
# junitxml-title: Summary
# linting:
# runs-on: ubuntu-latest
# steps:
# - uses: actions/checkout@v4
# - uses: actions/setup-python@v2
# with:
# python-version: 3.11
# - uses: isort/isort-action@master
# with:
# requirementsFiles: "requirements.txt requirements.dev.txt"
# - uses: psf/black@stable
# - name: Comment if linting failed
# if: ${{ failure() }}
# uses: thollander/actions-comment-pull-request@v2
# with:
# message: |
# :poop: Code linting failed, use `black` and `isort` to fix it.
name: Python tests

on:
pull_request:


jobs:
test:
name: Unit tests
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up docker
uses: docker-practice/actions-setup-docker@master
- name: Run postgres
run: |
docker run -d -p 5432:5432 -e POSTGRES_HOST_AUTH_METHOD=trust --name db-test postgres:15-alpine
- uses: actions/setup-python@v4
with:
python-version: "3.11"
- name: Install dependencies
run: |
python -m ensurepip
python -m pip install --upgrade --no-cache-dir pip
python -m pip install --upgrade --no-cache-dir -r requirements.txt -r requirements.dev.txt
- name: Migrate DB
run: |
DB_DSN=postgresql://postgres@localhost:5432/postgres alembic upgrade head
- name: Build coverage file
id: pytest
run: |
DB_DSN=postgresql://postgres@localhost:5432/postgres pytest --junitxml=pytest.xml --cov-report=term-missing:skip-covered --cov=achievement_api tests/ | tee pytest-coverage.txt
- name: Print report
if: always()
run: |
cat pytest-coverage.txt
- name: Pytest coverage comment
uses: MishaKav/pytest-coverage-comment@main
if: always()
with:
pytest-coverage-path: ./pytest-coverage.txt
title: Coverage Report
badge-title: Code Coverage
hide-badge: false
hide-report: false
create-new-comment: false
hide-comment: false
report-only-changed-files: false
remove-link-from-badge: false
junitxml-path: ./pytest.xml
junitxml-title: Summary
- name: Fail on pytest errors
if: steps.pytest.outcome == 'failure'
run: exit 1

linting:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v2
with:
python-version: 3.11
- uses: isort/isort-action@master
with:
requirementsFiles: "requirements.txt requirements.dev.txt"
- uses: psf/black@stable
- name: Comment if linting failed
if: failure()
uses: thollander/actions-comment-pull-request@v2
with:
message: |
:poop: Code linting failed, use `black` and `isort` to fix it.

0 comments on commit 008c0c0

Please sign in to comment.