From 0db1a275a465614e548d7c17e64a4b0723ae95ba Mon Sep 17 00:00:00 2001 From: Brian Ward Date: Tue, 20 Feb 2024 16:26:22 -0500 Subject: [PATCH] Move to pyproject.toml setup, deduplicate dependencies --- .github/workflows/main.yml | 37 ++++---------- .github/workflows/release.yml | 7 ++- .pre-commit-config.yaml | 1 - MANIFEST.in | 2 - docsrc/env.yml | 10 +--- pyproject.toml | 73 ++++++++++++++++++++++++++-- requirements-optional.txt | 1 - requirements-test.txt | 8 ---- requirements.txt | 4 -- setup.py | 90 ----------------------------------- 10 files changed, 84 insertions(+), 149 deletions(-) delete mode 100644 requirements-optional.txt delete mode 100644 requirements-test.txt delete mode 100644 requirements.txt delete mode 100644 setup.py diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index ecc253f9..64872a15 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -56,12 +56,16 @@ jobs: with: python-version: ${{ matrix.python-version }} - - name: Install dependencies (python) + - name: Install dependencies + run: python -m pip install --upgrade pip wheel build + + - name: Build package run: | - python -m pip install --upgrade pip wheel build - pip install -r requirements.txt - pip install -r requirements-test.txt - pip install codecov + python -m build + python -m pip install .[test] + + - name: Show libraries + run: python -m pip freeze - name: Run flake8, pylint, mypy if: matrix.python-version == '3.11' @@ -70,22 +74,6 @@ jobs: pylint -v cmdstanpy test mypy cmdstanpy - - name: Build wheel - run: python -m build - - - name: Install wheel (Linux, macOS) - if: matrix.os != 'windows-latest' - run: pip install dist/*.whl - - - name: Install wheel (Windows) - if: matrix.os == 'windows-latest' - run: | - $whl = Get-ChildItem -Path dist -Filter *.whl | Select-Object -First 1 - pip install "$whl" - - - name: Show libraries - run: python -m pip freeze - - name: CmdStan installation cacheing id: cache-cmdstan if: ${{ !startswith(needs.get-cmdstan-version.outputs.version, 'git:') }} @@ -118,13 +106,8 @@ jobs: cd run_tests pytest -v ../test --cov=../cmdstanpy - - name: Run model with requirements-optional.txt - run: | - cd run_tests - python -m pip install -r ../requirements-optional.txt - python ../test/example_script.py - - name: Submit codecov run: | + pip install codecov cd run_tests codecov diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index a94dd20c..2a66021d 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -32,9 +32,8 @@ jobs: - name: Install dependencies (python) run: | - python -m pip install --upgrade pip wheel twine codecov "sphinx>5,<6" nbsphinx ipython ipykernel "pydata-sphinx-theme<0.9" requests sphinx-copybutton xarray matplotlib - pip install -r requirements.txt - pip install -e . + python -m pip install --upgrade pip wheel build twine requests + pip install -e .[doc,test] - name: Install CmdStan run: | @@ -80,7 +79,7 @@ jobs: git push -f origin master - name: Build wheel - run: python setup.py sdist bdist_wheel + run: python -m build - name: Install bdist_wheel run: pip install dist/*.whl diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 0556d912..58a42dd8 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -23,7 +23,6 @@ repos: rev: v1.5.0 hooks: - id: mypy - # Copied from setup.cfg exclude: ^test/ additional_dependencies: [ numpy >= 1.22] # local uses the user-installed pylint, this allows dependency checking diff --git a/MANIFEST.in b/MANIFEST.in index f981c388..b3bec1f5 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,6 +1,4 @@ # This file is used to include extra files in source distributions. -# (Source distributions are generated by running `python setup.py sdist`.) -include requirements*.txt include LICENSE.md include cmdstanpy/py.typed diff --git a/docsrc/env.yml b/docsrc/env.yml index b15d9ef4..b3811514 100644 --- a/docsrc/env.yml +++ b/docsrc/env.yml @@ -5,18 +5,12 @@ channels: dependencies: - python=3.9 - ipykernel - - ipython - - ipywidgets - - numpy>=1.15 + - numpy - pandas - xarray - - sphinx>5,<6 - - nbsphinx - - pydata-sphinx-theme>0.7,<0.9 - - sphinx-copybutton - matplotlib-base - pip - cmdstan - tqdm - pip: - - -e ../ + - -e ../.[docs] diff --git a/pyproject.toml b/pyproject.toml index a1f4b649..77d9569e 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,3 +1,68 @@ +[build-system] +requires = ["setuptools"] +build-backend = "setuptools.build_meta" + +[project] +name = "cmdstanpy" +description = "Python interface to CmdStan" +readme = "README.md" +license = { text = "BSD-3-Clause" } +authors = [{ name = "Stan Dev Team" }] +requires-python = ">=3.8" +dependencies = ["pandas", "numpy>=1.21", "tqdm", "stanio>=0.4.0,<2.0.0"] +dynamic = ["version"] +classifiers = [ + "Programming Language :: Python :: 3", + "License :: OSI Approved :: BSD License", + "Operating System :: OS Independent", + "Development Status :: 5 - Production/Stable", + "Intended Audience :: Science/Research", + "Natural Language :: English", + "Programming Language :: Python", + "Topic :: Scientific/Engineering :: Information Analysis", +] + +[project.urls] +"Homepage" = "https://github.com/stan-dev/cmdstanpy" +"Bug Tracker" = "https://github.com/stan-dev/cmdstanpy/issues" + +[project.scripts] +install_cmdstan = "cmdstanpy.install_cmdstan:__main__" +install_cxx_toolchain = "cmdstanpy.install_cxx_toolchain:__main__" + +[tool.setuptools.dynamic] +version = { attr = "cmdstanpy._version.__version__" } + +[tool.setuptools] +packages = ["cmdstanpy", "cmdstanpy.stanfit", "cmdstanpy.utils"] + +[tool.setuptools.package-data] +"cmdstanpy" = ["py.typed"] + +[project.optional-dependencies] +all = ["xarray"] +test = [ + "flake8", + "pylint", + "pytest", + "pytest-cov", + "pytest-order", + "mypy", + "xarray", +] +docs = [ + "sphinx>5,<6", + "pydata-sphinx-theme<0.9", + "nbsphinx", + "ipython", + "ipykernel", + "ipywidgets", + "sphinx-copybutton", + "xarray", + "matplotlib", +] + + [tool.black] line-length = 80 skip-string-normalization = true @@ -23,8 +88,8 @@ strict_equality = true disallow_untyped_calls = true [[tool.mypy.overrides]] -module = [ - 'tqdm.auto', - 'pandas', - ] +module = ['tqdm.auto', 'pandas'] ignore_missing_imports = true + +[tool.coverage.run] +source = ["cmdstanpy"] diff --git a/requirements-optional.txt b/requirements-optional.txt deleted file mode 100644 index 14578525..00000000 --- a/requirements-optional.txt +++ /dev/null @@ -1 +0,0 @@ -xarray diff --git a/requirements-test.txt b/requirements-test.txt deleted file mode 100644 index 021430af..00000000 --- a/requirements-test.txt +++ /dev/null @@ -1,8 +0,0 @@ -flake8 -pylint -pytest -pytest-cov -pytest-order -mypy -tqdm -xarray diff --git a/requirements.txt b/requirements.txt deleted file mode 100644 index 4a86cd26..00000000 --- a/requirements.txt +++ /dev/null @@ -1,4 +0,0 @@ -pandas -numpy>=1.21 -tqdm -stanio~=0.3.0 diff --git a/setup.py b/setup.py deleted file mode 100644 index 500dc555..00000000 --- a/setup.py +++ /dev/null @@ -1,90 +0,0 @@ -#!/usr/bin/env python - -import os -import re -from typing import List - -import setuptools - -HERE = os.path.dirname(__file__) - - -def readme_contents() -> str: - with open(os.path.join(HERE, 'README.md'), 'r') as fd: - src = fd.read() - return src - - -def requirements() -> List[str]: - with open(os.path.join(HERE, 'requirements.txt'), 'r') as fd: - src = fd.read() - return src.splitlines() - - -def requirements_test() -> List[str]: - with open(os.path.join(HERE, 'requirements-test.txt'), 'r') as fd: - src = fd.read() - return src.splitlines() - - -def requirements_optional() -> List[str]: - with open(os.path.join(HERE, 'requirements-optional.txt'), 'r') as fd: - src = fd.read() - return src.splitlines() - - -def get_version() -> str: - version_file = open(os.path.join('cmdstanpy', '_version.py')) - version_contents = version_file.read() - return re.search("__version__ = '(.*?)'", version_contents).group(1) - - -_classifiers = """ -Programming Language :: Python :: 3 -License :: OSI Approved :: BSD License -Operating System :: OS Independent -Development Status :: 5 - Production/Stable -Intended Audience :: Science/Research -Natural Language :: English -Programming Language :: Python -Topic :: Scientific/Engineering :: Information Analysis -""" - -INSTALL_REQUIRES = requirements() - -EXTRAS_REQUIRE = { - 'all': requirements_optional(), - 'tests': requirements_test(), - 'docs': [ - 'sphinx', - 'sphinx-gallery', - 'sphinx_rtd_theme', - 'numpydoc', - 'matplotlib', - ], -} - -setuptools.setup( - name='cmdstanpy', - version=get_version(), - description='Python interface to CmdStan', - long_description=readme_contents(), - long_description_content_type="text/markdown", - author='Stan Dev Team', - url='https://github.com/stan-dev/cmdstanpy', - license_files=['LICENSE.md'], - packages=['cmdstanpy', 'cmdstanpy.stanfit', 'cmdstanpy.utils'], - package_data={ - 'cmdstanpy': ['py.typed'], - }, - entry_points={ - 'console_scripts': [ - 'install_cmdstan=cmdstanpy.install_cmdstan:__main__', - 'install_cxx_toolchain=cmdstanpy.install_cxx_toolchain:__main__', - ] - }, - install_requires=INSTALL_REQUIRES, - python_requires='>=3.8', - extras_require=EXTRAS_REQUIRE, - classifiers=_classifiers.strip().split('\n'), -)