From f61df08b8d679b4deef66ca149896ab58752197a Mon Sep 17 00:00:00 2001 From: Christian Giese Date: Mon, 8 Jul 2024 11:14:47 +0000 Subject: [PATCH] migrate from travis to GitHub actions + migrate to GitHub actions + update README + update copyright + ... --- .github/workflows/python-publish.yml | 31 ++++++++++++++ .github/workflows/python-test.yml | 60 ++++++++++++++++++++++++++++ .travis.yml | 10 ----- LICENSE | 2 +- README.md | 4 +- README.rst | 4 +- ancp/__init__.py | 2 +- ancp/client.py | 2 +- ancp/subscriber.py | 2 +- bin/client.py | 2 +- docs/source/conf.py | 2 +- setup.py | 9 +++-- tests/test_client.py | 2 +- tests/test_subscriber.py | 2 +- 14 files changed, 108 insertions(+), 26 deletions(-) create mode 100644 .github/workflows/python-publish.yml create mode 100644 .github/workflows/python-test.yml delete mode 100644 .travis.yml diff --git a/.github/workflows/python-publish.yml b/.github/workflows/python-publish.yml new file mode 100644 index 0000000..4a92126 --- /dev/null +++ b/.github/workflows/python-publish.yml @@ -0,0 +1,31 @@ +# This workflows will upload a Python Package using Twine when a release is created +# For more information see: https://help.github.com/en/actions/language-and-framework-guides/using-python-with-github-actions#publishing-to-package-registries + +name: Upload Python Package + +on: + release: + types: [created] + +jobs: + deploy: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + - name: Set up Python + uses: actions/setup-python@v5 + with: + python-version: '3.x' + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install setuptools wheel twine + - name: Build and publish + env: + TWINE_USERNAME: __token__ + TWINE_PASSWORD: ${{ secrets.PYPI_TOKEN }} + run: | + python setup.py sdist bdist_wheel + twine upload dist/* \ No newline at end of file diff --git a/.github/workflows/python-test.yml b/.github/workflows/python-test.yml new file mode 100644 index 0000000..288fe3d --- /dev/null +++ b/.github/workflows/python-test.yml @@ -0,0 +1,60 @@ +# This workflow will install Python dependencies, run tests and lint with a variety of Python versions +# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions + +name: Python 3.X test + +on: + push: + branches: [ master ] + pull_request: + branches: [ master ] + +jobs: + test: + runs-on: ubuntu-latest + strategy: + matrix: + python-version: [ '3.8', '3.9', '3.10' ] + + steps: + - uses: actions/checkout@v4 + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.python-version }} + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install pytest pytest-pep8 pytest-cov python-coveralls flake8 coverage lcov + if [ -f requirements.txt ]; then pip install -r requirements.txt; fi + - name: Install pyrad + run: | + pip install . + - name: Lint with flake8 + run: | + # stop the build if there are Python syntax errors or undefined names + flake8 . --count --select=E9,F63,F7,F82 --show-source --statistics + # exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide + flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics + - name: Run unittest with coverage + run: | + coverage run -m unittest discover + coverage report -m + coverage lcov + - name: Coveralls + uses: coverallsapp/github-action@master + with: + github-token: ${{ secrets.GITHUB_TOKEN }} + flag-name: run-${{ matrix.python-version }} + path-to-lcov: coverage.lcov + parallel: true + + finish: + needs: test + runs-on: ubuntu-latest + steps: + - name: Coveralls Finished + uses: coverallsapp/github-action@master + with: + github-token: ${{ secrets.GITHUB_TOKEN }} + parallel-finished: true \ No newline at end of file diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index 5fdcdb9..0000000 --- a/.travis.yml +++ /dev/null @@ -1,10 +0,0 @@ -language: python -python: - - "2.7" - - "3.5" -# command to install dependencies -install: "pip install pytest future pytest-pep8 pytest-cov python-coveralls" -# command to run tests -script: python -m pytest -v --cov ancp --cov-report term-missing -after_success: - - coveralls diff --git a/LICENSE b/LICENSE index d051534..5e0bbdf 100644 --- a/LICENSE +++ b/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2017 Christian Giese +Copyright (c) 2017 - 2024 Christian Giese Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index 6325c9b..92eafec 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ -[![Build Status](https://travis-ci.org/GIC-de/PyANCP.svg?branch=master)](https://travis-ci.org/GIC-de/PyANCP) -[![Documentation Status](https://readthedocs.org/projects/pyancp/badge/?version=latest)](http://pyancp.readthedocs.io/en/latest/?badge=latest) +[![Test Status](https://github.com/GIC-de/PyANCP/actions/workflows/python-test.yml/badge.svg)](https://github.com/GIC-de/PyANCP/actions/workflows/python-test.yml) [![Coverage Status](https://coveralls.io/repos/github/GIC-de/PyANCP/badge.svg?branch=master)](https://coveralls.io/github/GIC-de/PyANCP?branch=master) +[![Documentation Status](https://readthedocs.org/projects/pyancp/badge/?version=latest)](http://pyancp.readthedocs.io/en/latest/?badge=latest) [![Version](https://img.shields.io/pypi/v/PyANCP.svg)](https://pypi.python.org/pypi/PyANCP) [![Downloads](https://img.shields.io/pypi/dm/PyANCP.svg)](https://pypi.python.org/pypi/PyANCP) [![Python Versions](https://img.shields.io/pypi/pyversions/PyANCP.svg)](https://pypi.python.org/pypi/PyANCP) diff --git a/README.rst b/README.rst index 9a48f69..c6b1856 100644 --- a/README.rst +++ b/README.rst @@ -1,5 +1,5 @@ -.. image:: https://travis-ci.org/GIC-de/PyANCP.svg?branch=master - :target: https://travis-ci.org/GIC-de/PyANCP +.. image:: https://github.com/GIC-de/PyANCP/actions/workflows/python-test.yml/badge.svg + :target: https://github.com/GIC-de/PyANCP/actions/workflows/python-test.yml .. image:: https://coveralls.io/repos/github/GIC-de/PyANCP/badge.svg?branch=master :target: https://coveralls.io/github/GIC-de/PyANCP?branch=master .. image:: https://readthedocs.org/projects/pyancp/badge/?version=latest diff --git a/ancp/__init__.py b/ancp/__init__.py index 5c29c1e..420752e 100644 --- a/ancp/__init__.py +++ b/ancp/__init__.py @@ -1,6 +1,6 @@ """Python ANCP Client """ __author__ = 'Christian Giese (GIC-de)' -__copyright__ = 'Copyright 2017-2021, Christian Giese' +__copyright__ = 'Copyright 2017-2024, Christian Giese' __all__ = ['client', 'subscriber'] \ No newline at end of file diff --git a/ancp/client.py b/ancp/client.py index 19056ed..75ccf6a 100644 --- a/ancp/client.py +++ b/ancp/client.py @@ -1,6 +1,6 @@ """ANCP Client -Copyright (C) 2017-2021, Christian Giese (GIC-de) +Copyright (C) 2017-2024, Christian Giese (GIC-de) SPDX-License-Identifier: MIT """ from __future__ import print_function diff --git a/ancp/subscriber.py b/ancp/subscriber.py index 532d9f9..39601e5 100644 --- a/ancp/subscriber.py +++ b/ancp/subscriber.py @@ -1,6 +1,6 @@ """ANCP Subscribers -Copyright (C) 2017-2021, Christian Giese (GIC-de) +Copyright (C) 2017-2024, Christian Giese (GIC-de) SPDX-License-Identifier: MIT """ from __future__ import print_function diff --git a/bin/client.py b/bin/client.py index 982a05e..e32ef07 100644 --- a/bin/client.py +++ b/bin/client.py @@ -1,7 +1,7 @@ #!/usr/bin/env python """ANCP Client Example -Copyright (C) 2017-2021, Christian Giese (GIC-de) +Copyright (C) 2017-2024, Christian Giese (GIC-de) SPDX-License-Identifier: MIT """ from ancp.client import Client diff --git a/docs/source/conf.py b/docs/source/conf.py index d9abb4e..e21f217 100644 --- a/docs/source/conf.py +++ b/docs/source/conf.py @@ -54,7 +54,7 @@ # General information about the project. project = u'PyANCP' -copyright = u'Copyright 2017-2021, Christian Giese (GIc-de)' +copyright = u'Copyright 2017-2024, Christian Giese (GIc-de)' author = u'Christian Giese' # The version info for the project you're documenting, acts as replacement for diff --git a/setup.py b/setup.py index 0cf71d5..4229a14 100644 --- a/setup.py +++ b/setup.py @@ -3,7 +3,7 @@ """ from setuptools import setup, find_packages -version = '0.1.6' +version = '0.1.7' setup(name='PyANCP', version=version, @@ -13,9 +13,10 @@ description='Python ANCP (RFC 6320) Client and Library', long_description=open('README.rst').read(), classifiers=[ - 'Programming Language :: Python :: 2.7', - 'Programming Language :: Python :: 3.2', - 'Programming Language :: Python :: 3.5', + 'Programming Language :: Python :: 2.7', + 'Programming Language :: Python :: 3.8', + 'Programming Language :: Python :: 3.9', + 'Programming Language :: Python :: 3.10' ], packages=find_packages(), zip_safe=True, diff --git a/tests/test_client.py b/tests/test_client.py index 780854c..a50dc17 100644 --- a/tests/test_client.py +++ b/tests/test_client.py @@ -1,6 +1,6 @@ """ANCP Client Tests -Copyright (C) 2017-2021, Christian Giese (GIC-de) +Copyright (C) 2017-2024, Christian Giese (GIC-de) SPDX-License-Identifier: MIT """ from ancp.client import * diff --git a/tests/test_subscriber.py b/tests/test_subscriber.py index f40e000..728147b 100644 --- a/tests/test_subscriber.py +++ b/tests/test_subscriber.py @@ -1,6 +1,6 @@ """ANCP Subscriber Tests -Copyright (C) 2017-2021, Christian Giese (GIC-de) +Copyright (C) 2017-2024, Christian Giese (GIC-de) SPDX-License-Identifier: MIT """ from ancp.subscriber import *