From edc5da1bd72326d8428e0c9a3d37c0f5936b32d5 Mon Sep 17 00:00:00 2001 From: christophkloeffel Date: Wed, 10 Apr 2024 18:40:13 +0200 Subject: [PATCH] adds ci workflow --- .github/workflows/ci.yml | 53 ++++++++++++++++++++++++++++++++++++++ Makefile | 22 ++++++++-------- lobster/io.py | 10 +++---- lobster/tools/json/json.py | 1 - requirements.txt | 3 +++ 5 files changed, 72 insertions(+), 17 deletions(-) create mode 100644 .github/workflows/ci.yml create mode 100644 requirements.txt diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 00000000..163a7484 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,53 @@ +name: LOBSTER CI + +on: + push: + branches: ["main"] + pull_request: + branches: ["main"] + +permissions: + contents: read + +jobs: + lint: + name: PyLint + runs-on: ubuntu-20.04 + steps: + - uses: actions/checkout@v4 + - name: Set up Python 3.9 + uses: actions/setup-python@v5 + with: + python-version: "3.9" + - name: Install dependencies + run: | + python -m pip install --upgrade pip + python -m pip install pylint pycodestyle + - name: Style check + run: | + make style + - name: Lint + run: | + make lint -o style + test: + name: Test + strategy: + matrix: + py-version: ["3.8", "3.9", "3.10", "3.11"] + runs-on: ubuntu-20.04 + steps: + - uses: actions/checkout@v4 + - name: Set up Python ${{ matrix.py-version }} + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.py-version }} + - name: Install dependencies + run: | + python -m pip install --upgrade pip + python -m pip install -r requirements.txt + - name: Executing system tests + run: | + make system-tests + - name: Executing unit tests + run: | + make unit-tests diff --git a/Makefile b/Makefile index 05d6a805..fa4eccc7 100644 --- a/Makefile +++ b/Makefile @@ -40,37 +40,37 @@ packages: diff -Naur test_install/lib/python*/site-packages/lobster test_install_monolithic/lib/python*/site-packages/lobster -x "*.pyc" diff -Naur test_install/bin test_install_monolithic/bin -integration_tests: packages +integration-tests: packages (cd integration-tests/projects/basic; make) (cd integration-tests/projects/filter; make) -system_tests: +system-tests: make -B -C test-system/lobster-json make -B -C test-system/lobster-python -unit_tests: +unit-tests: python3 -m unittest discover -s test-unit -v -test: integration_tests system_tests unit_tests +test: integration-tests system-tests unit-tests -upload_main: packages +upload-main: packages python3 -m twine upload --repository pypi packages/*/dist/* python3 -m twine upload --repository pypi packages/*/meta_dist/* -remove_dev: +remove-dev: python3 -m util.release -github_release: +github-release: git push python3 -m util.github_release bump: python3 -m util.bump_version_post_release -full_release: - make remove_dev +full-release: + make remove-dev git push - make upload_main - make github_release + make upload-main + make github-release make bump git push diff --git a/lobster/io.py b/lobster/io.py index dea829a5..48e2fa4f 100644 --- a/lobster/io.py +++ b/lobster/io.py @@ -114,7 +114,7 @@ def lobster_read(mh, filename, level, items, source_info=None): if source_info is not None: item.perform_source_checks(source_info) - + # evaluate source_info filters for f, v in source_info['filters']: if f == 'prefix': @@ -125,9 +125,9 @@ def lobster_read(mh, filename, level, items, source_info=None): if all(filter_conditions): if item.tag.key() in items: mh.error(item.location, - "duplicate definition of %s, " - "previously defined at %s" % - (item.tag.key(), - items[item.tag.key()].location.to_string())) + "duplicate definition of %s, " + "previously defined at %s" % + (item.tag.key(), + items[item.tag.key()].location.to_string())) items[item.tag.key()] = item diff --git a/lobster/tools/json/json.py b/lobster/tools/json/json.py index 27fe011b..b4317dbd 100755 --- a/lobster/tools/json/json.py +++ b/lobster/tools/json/json.py @@ -18,7 +18,6 @@ # . import sys -import os.path import json from pathlib import PurePath from pprint import pprint diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 00000000..ce3b7498 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,3 @@ +trlc>=1.2.2 +requests>=2.31.0 +libcst>=1.1.0