Skip to content

Commit

Permalink
Maintenance; bump versions (#317)
Browse files Browse the repository at this point in the history
  • Loading branch information
prisae authored Feb 16, 2024
1 parent ade673d commit 0063de3
Show file tree
Hide file tree
Showing 12 changed files with 59 additions and 51 deletions.
6 changes: 3 additions & 3 deletions .github/workflows/linkcheck.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,9 @@ jobs:

steps:

# Cancel any previous run of the test job; [pin v0.10.0 (2022-06-27)]
# Cancel any previous run of the test job; [pin v0.12.1 (2024-01-25)]
- name: Cancel Previous Runs
uses: styfle/cancel-workflow-action@bb6001c4ea612bf59c3abfc4756fbceee4f870c7
uses: styfle/cancel-workflow-action@85880fa0301c86cca9da44039ee3bb12d3bedbfa
with:
access_token: ${{ github.token }}

Expand All @@ -33,7 +33,7 @@ jobs:
- name: Setup Python
uses: actions/setup-python@v2
with:
python-version: "3.10"
python-version: "3.11"

- name: Install dependencies
shell: bash -l {0}
Expand Down
31 changes: 15 additions & 16 deletions .github/workflows/linux.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,31 +31,31 @@ jobs:
matrix:
os: [ubuntu, ] # macos, windows] # Only Linux currently.
case:
- python-version: "3.8"
- python-version: "3.9"
name: minimal
os: ubuntu
conda: "'scipy=1.5' 'numpy=1.19' 'numba=0.50'"
- python-version: "3.9"
conda: "'scipy=1.8' 'numba=0.53'"
- python-version: "3.10"
name: full
os: ubuntu
conda: "numba scipy xarray empymod h5py scooby discretize matplotlib" # tqdm
- python-version: "3.9"
- python-version: "3.10"
name: plain
os: ubuntu
conda: "numba scipy"
- python-version: "3.10"
- python-version: "3.11"
name: plain
os: ubuntu
conda: "numba scipy"
- python-version: "3.10"
- python-version: "3.11"
name: full
os: ubuntu
conda: "numba scipy xarray tqdm empymod h5py scooby discretize matplotlib"
- python-version: "3.11"
- python-version: "3.12"
name: plain
os: ubuntu
conda: "numba scipy"
- python-version: "3.11"
- python-version: "3.12"
name: full
os: ubuntu
conda: "numba scipy xarray tqdm empymod h5py scooby discretize matplotlib"
Expand All @@ -67,9 +67,9 @@ jobs:

steps:

# Cancel any previous run of the test job; [pin v0.10.0 (2022-06-27)]
# Cancel any previous run of the test job; [pin v0.12.1 (2024-01-25)]
- name: Cancel Previous Runs
uses: styfle/cancel-workflow-action@bb6001c4ea612bf59c3abfc4756fbceee4f870c7
uses: styfle/cancel-workflow-action@85880fa0301c86cca9da44039ee3bb12d3bedbfa
with:
access_token: ${{ github.token }}

Expand All @@ -91,8 +91,8 @@ jobs:
run: git fetch origin 'refs/tags/*:refs/tags/*'

- name: Setup miniconda
# [pin v2.1.1 (2021-04-01)]
uses: conda-incubator/setup-miniconda@35d1405e78aa3f784fe3ce9a2eb378d5eeb62169
# [pin v3.0.1 (2023-11-29)]
uses: conda-incubator/setup-miniconda@11b562958363ec5770fef326fe8ef0366f8cbf8a
with:
auto-update-conda: true
python-version: ${{ matrix.case.python-version }}
Expand Down Expand Up @@ -120,7 +120,7 @@ jobs:
- name: Test with pytest
shell: bash -l {0}
run: |
pip install --no-build-isolation --no-deps .
python -m pip install .
pytest --cov=emg3d
- name: Coveralls
Expand Down Expand Up @@ -174,7 +174,7 @@ jobs:
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install wheel setuptools-scm
python -m pip install build setuptools-scm
- name: Build source and wheel distributions
if: github.ref == 'refs/heads/main'
Expand All @@ -187,8 +187,7 @@ jobs:
- name: Build source and wheel distributions
run: |
# Build source and wheel packages
python setup.py sdist
python setup.py bdist_wheel
python -m build
echo ""
echo "Generated files:"
ls -lh dist/
Expand Down
12 changes: 6 additions & 6 deletions .github/workflows/macos_windows.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,13 @@ jobs:
fail-fast: false
matrix:
os: [macos, windows]
python: [3.9, ]
python: [3.11, ]

steps:

# Cancel any previous run of the test job; [pin v0.10.0 (2022-06-27)]
# Cancel any previous run of the test job; [pin v0.12.1 (2024-01-25)]
- name: Cancel Previous Runs
uses: styfle/cancel-workflow-action@bb6001c4ea612bf59c3abfc4756fbceee4f870c7
uses: styfle/cancel-workflow-action@85880fa0301c86cca9da44039ee3bb12d3bedbfa
with:
access_token: ${{ github.token }}

Expand All @@ -58,8 +58,8 @@ jobs:
run: git fetch origin 'refs/tags/*:refs/tags/*'

- name: Setup miniconda
# [pin v2.1.1 (2021-04-01)]
uses: conda-incubator/setup-miniconda@35d1405e78aa3f784fe3ce9a2eb378d5eeb62169
# [pin v3.0.1 (2023-11-29)]
uses: conda-incubator/setup-miniconda@11b562958363ec5770fef326fe8ef0366f8cbf8a
with:
auto-update-conda: true
python-version: ${{ matrix.python }}
Expand All @@ -83,5 +83,5 @@ jobs:
- name: Test with pytest
shell: bash -l {0}
run: |
pip install --no-build-isolation --no-deps .
python -m pip install .
pytest
8 changes: 5 additions & 3 deletions .readthedocs.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
# Required
version: 2

build:
os: "ubuntu-22.04"
tools:
python: "3.11"

# Build documentation in the docs/ directory with Sphinx
sphinx:
configuration: docs/conf.py
Expand All @@ -11,10 +16,7 @@ formats: []
# Optionally set the version of Python and requirements required to build your
# docs
python:
version: 3.8
install:
# Temporary workaround to have discretize wheels built.
- requirements: .rtd-requirements.txt
- requirements: requirements-dev.txt
- method: pip
path: .
16 changes: 16 additions & 0 deletions CHANGELOG.rst
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,22 @@ Changelog
""""""""""


latest
------

- Maintenance:

- Bumped the minimum requirements to:

- Python 3.9
- SciPy 1.8
- Numba 0.53

- Testing: added Python 3.12, dropped Python 3.8.

- Fix remaining outdated ``python setup.py`` commands.


v1.8.2 : convert & pip-full
---------------------------

Expand Down
6 changes: 3 additions & 3 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,10 @@ help:
@echo ""

install:
pip install --no-build-isolation --no-deps -e .
python -m pip install --no-build-isolation --no-deps -e .

dev-install:
pip install -r requirements-dev.txt && pip install --no-build-isolation --no-deps -e .
python -m pip install -r requirements-dev.txt && python -m pip install --no-build-isolation --no-deps -e .

pytest:
rm -rf .coverage htmlcov/ .pytest_cache/ && pytest --cov=emg3d && coverage html
Expand All @@ -37,7 +37,7 @@ linkcheck:
cd docs && make linkcheck

clean:
pip uninstall emg3d -y
python -m pip uninstall emg3d -y
rm -rf build/ dist/ .eggs/ emg3d.egg-info/ emg3d/version.py # build
rm -rf */__pycache__/ */*/__pycache__/ # python cache
rm -rf .coverage htmlcov/ .pytest_cache/ # tests and coverage
Expand Down
2 changes: 1 addition & 1 deletion docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -106,5 +106,5 @@
# the check; they "should" be permanent, that is their entire purpose; doi.org
# is responsible for resolving them.
linkcheck_ignore = [
"https://doi.org/10.*",
"https://doi.org/*", # DOIs should be permanent (their entire purpose)
]
2 changes: 1 addition & 1 deletion docs/dev/maintenance.rst
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ release.
:target: https://coveralls.io/github/emsig/emg3d?branch=main
:alt: Coveralls
.. image:: https://app.codacy.com/project/badge/Grade/0412e617e8cd42fea05303fe490b09b5
:target: https://www.codacy.com/gh/emsig/emg3d/dashboard?utm_source=github.com&utm_medium=referral&utm_content=emsig/emg3d&utm_campaign=Badge_Grade
:target: https://app.codacy.com/gh/emsig/emg3d/dashboard?utm_source=github.com&utm_medium=referral&utm_content=emsig/emg3d&utm_campaign=Badge_Grade
:alt: Codacy

Check CI coverage and code quality is good.
Expand Down
2 changes: 1 addition & 1 deletion docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ emg3d Documentation

.. grid-item-card::

:fa:`fas fa-picture-o;fa-4x`
:fa:`image;fa-4x`

Gallery
^^^^^^^
Expand Down
5 changes: 2 additions & 3 deletions docs/manual/installation.rst
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,8 @@ or via ``pip``:
pip install emg3d
Minimum requirements are Python version 3.8 or higher and the modules ``scipy``
and ``numba``. Various other packages are recommended or required for some
advanced functionalities, namely:
Requirements are the modules ``scipy`` and ``numba``. Various other packages
are recommended or required for some advanced functionalities, namely:

- ``xarray``: For the :class:`emg3d.surveys.Survey` and
:class:`emg3d.simulations.Simulation` classes (model many sources and
Expand Down
16 changes: 4 additions & 12 deletions setup.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,8 @@
# -*- coding: utf-8 -*-
import os
import re
import sys
from setuptools import setup

if not sys.version_info[:2] >= (3, 8):
sys.exit(f"emg3d is only meant for Python 3.8 and up.\n"
f"Current version: {sys.version_info[0]}.{sys.version_info[1]}.")

# Get README and remove badges.
with open("README.rst") as f:
readme = re.sub(r"\|.*\|", "", f.read(), flags=re.DOTALL)
Expand All @@ -24,20 +19,17 @@
classifiers=[
"Development Status :: 5 - Production/Stable",
"License :: OSI Approved :: Apache Software License",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
"Programming Language :: Python",
],
entry_points={
"console_scripts": [
"emg3d=emg3d.cli.main:main",
],
},
python_requires=">=3.8",
python_requires=">=3.9",
install_requires=[
"scipy>=1.5",
"numba>=0.50",
"scipy>=1.8",
"numba>=0.53",
],
extras_require={
'full': [
Expand Down
4 changes: 2 additions & 2 deletions tests/test_solver.py
Original file line number Diff line number Diff line change
Expand Up @@ -1115,15 +1115,15 @@ def test_print_one_liner(capsys):
_ = solver.solve(model, sfield, sslsolver=True, semicoarsening=False,
linerelaxation=False, verb=1)
out, _ = capsys.readouterr()
assert '3(5); 0:00:' in out
assert '(5); 0:00:' in out
assert '; CONVERGED' in out

# One-liner.
out, _ = capsys.readouterr()
_ = solver.solve(model, sfield, sslsolver=True, semicoarsening=False,
linerelaxation=False, verb=1)
out, _ = capsys.readouterr()
assert '3(5); 0:00:' in out
assert '(5); 0:00:' in out
assert '; CONVERGED' in out


Expand Down

0 comments on commit 0063de3

Please sign in to comment.