From ab447e50998f992992b5f83994f713cbaa767d18 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alexandru=20S=C4=83vulescu?= Date: Mon, 16 May 2022 22:41:05 +0200 Subject: [PATCH] pypi publishing (#28) * adapt setup.py for versioning using setuptools_scm * add CI for Pypi publishing --- .github/workflows/python-publish.yml | 31 +++++++++++++++++++++ requirements.txt | 13 --------- setup.py | 41 +++++++++++++++++++--------- 3 files changed, 59 insertions(+), 26 deletions(-) create mode 100644 .github/workflows/python-publish.yml delete mode 100644 requirements.txt diff --git a/.github/workflows/python-publish.yml b/.github/workflows/python-publish.yml new file mode 100644 index 0000000..7fffef8 --- /dev/null +++ b/.github/workflows/python-publish.yml @@ -0,0 +1,31 @@ +name: Upload Python Package + +on: + release: + types: [published] + +permissions: + contents: read + +jobs: + deploy: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + - name: Set up Python + uses: actions/setup-python@v3 + with: + python-version: '3.x' + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install build + - name: Build package + run: python -m build + - name: Publish package + uses: pypa/gh-action-pypi-publish@release/v1 + with: + user: __token__ + password: ${{ secrets.PYPI_API_TOKEN }} diff --git a/requirements.txt b/requirements.txt deleted file mode 100644 index ebf8ec8..0000000 --- a/requirements.txt +++ /dev/null @@ -1,13 +0,0 @@ -# core -requests -pyyaml -docopt -jinja2 -pyvirtualdisplay - -# for running models -pyqt5 -ipython -matplotlib -scipy -2to3 \ No newline at end of file diff --git a/setup.py b/setup.py index d285ee1..37ff596 100644 --- a/setup.py +++ b/setup.py @@ -1,29 +1,42 @@ #!/usr/bin/env python # -*- coding: utf-8 -*- -import pathlib from setuptools import setup, find_packages -import pkg_resources +install_requires = [ + # core + 'requests', + 'pyyaml', + 'docopt', + 'jinja2', + 'pyvirtualdisplay', -def get_install_requires(): - install_requires = [] - with pathlib.Path('requirements.txt').open() as requirements_txt: - install_requires = [ - str(requirement) - for requirement - in pkg_resources.parse_requirements(requirements_txt) - ] - return install_requires + # for running models + 'pyqt5', + 'ipython', + 'matplotlib', + 'scipy', + '2to3', +] + +with open('README.md', 'r', encoding='utf-8') as f: + long_description = f.read() def setup_package(): setup( name='nrn-modeldb-ci', - version='0.0.1', + description='NEURON ModelDB CI tools', + url='https://github.com/neuronsimulator/nrn-modeldb-ci', + author='EPFL Blue Brain Project & Yale', + author_email='alexandru.savulescu@epfl.ch', + license='BSD-3-Clause', packages=find_packages(), - install_requires=get_install_requires(), + use_scm_version=True, + include_package_data=True, + install_requires=install_requires, + setup_requires=['setuptools_scm'], entry_points=dict( console_scripts=[ 'runmodels = modeldb.commands:runmodels', @@ -34,6 +47,8 @@ def setup_package(): 'diffreports2html = modeldb.commands:diffreports2html', ] ), + long_description=long_description, + long_description_content_type="text/markdown", )