From 854e8468ea035b7d588ca7cc26a96f8f700541e7 Mon Sep 17 00:00:00 2001 From: Aineopintojen-harjoitustyo-Algoritmit-j Date: Sun, 18 Feb 2024 21:53:48 +0200 Subject: Improved developer commands menu. --- .github/workflows/auto.yml | 2 +- dev/__init__.py | 9 +------ dev/commands.py | 66 +++++++++++++++++++++++++++++++++------------- pyproject.toml | 7 +---- 4 files changed, 51 insertions(+), 33 deletions(-) diff --git a/.github/workflows/auto.yml b/.github/workflows/auto.yml index adec8b0..f0c280f 100644 --- a/.github/workflows/auto.yml +++ b/.github/workflows/auto.yml @@ -35,7 +35,7 @@ jobs: # Run coverage xml - name: Run unittests with coverage and generate xml - run: poetry run covxml + run: poetry run dev covxml # xml -> codecov - name: Upload coverage reports to Codecov diff --git a/dev/__init__.py b/dev/__init__.py index 52cc7d9..796c8ef 100644 --- a/dev/__init__.py +++ b/dev/__init__.py @@ -1,8 +1 @@ -from .commands import ( - dev_pylint, - dev_pytest, - dev_coverage, - dev_covhtml, - dev_covxml, - dev_covff, - dev_all) +from .commands import dev_command diff --git a/dev/commands.py b/dev/commands.py index ed9341a..ff94eb2 100644 --- a/dev/commands.py +++ b/dev/commands.py @@ -1,36 +1,66 @@ -import pytest -import pylint from subprocess import run +from sys import argv -def dev_pylint(): - return pylint.run_pylint(argv=["-v", "src/miinaharava"]) +usage = """ +Komentoja kehitykseen: + +poetry run dev + +Komennot: + pytest Ajaa yksikkötestit + pylint Tarkistaa koodin ulkoasun + coverage Tutkii haarakattavuuden + covhtml Tekee coverage haarakattavuusraportin HTML muodossa + covxml Tekee coverage haarakattavuusraportin XML muodossa + covff Tekee haarakattavuusraportin ja avaa sen firefoxilla + all Sama kuin + +""" + +def dev_command(): + if len(argv)==2: + match argv[1]: + case "pytest": + import pytest + return pytest.main(["-v"]) + case "pylint": + return run_pylint() + case "coverage": + return run_coverage() + case "covhtml": + return run_covhtml() + case "covxml": + return run_covxml() + case "covff": + return run_covff() + case "all": + if e := run_covff(): return e + return run_pylint() + print(usage) + return 0 -def dev_pytest(): - return pytest.main(["-v"]) +def run_pylint(): + import pylint + return pylint.run_pylint(argv=["-v", "src/miinaharava"]) -def dev_coverage(): +def run_coverage(): return run( "poetry run python3 -m coverage run --branch -m pytest -v ".split() ).returncode - -def dev_covhtml(): - if e := dev_coverage(): return e + +def run_covhtml(): + if e := run_coverage(): return e return run( "poetry run python3 -m coverage html".split() ).returncode -def dev_covxml(): - if e := dev_coverage(): return e +def run_covxml(): + if e := run_coverage(): return e return run( "poetry run python3 -m coverage xml".split() ).returncode -def dev_covff(): - if e := dev_covhtml(): return e +def run_covff(): + if e := run_covhtml(): return e return run( "firefox htmlcov/index.html".split() ).returncode - -def dev_all(): - if e := dev_covff(): return e - return dev_pylint() diff --git a/pyproject.toml b/pyproject.toml index 8cfad68..a14ef19 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -15,12 +15,7 @@ coverage = "^7.4.0" pylint = "^3.0.3" [tool.poetry.scripts] -pylint = "dev:dev_pylint" -pytest = "dev:dev_pytest" -covhtml = "dev:dev_covhtml" -covxml = "dev:dev_covxml" -covff = "dev:dev_covff" -all = "dev:dev_all" +dev = "dev:dev_command" [build-system] requires = ["poetry-core"] -- cgit v1.2.3