Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use modern tooling for builds #377

Merged
merged 15 commits into from
Dec 11, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 28 additions & 29 deletions .github/workflows/checks.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,39 +2,38 @@ name: tests

on:
push:
branches: [ develop ]
branches: [main]
pull_request:
branches: [ develop ]
branches: [main]

jobs:
build:

lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python 3.8
uses: actions/setup-python@v4
with:
python-version: 3.8
- name: Install Hatch
run: pipx install hatch
- name: Lint
run: hatch run dev:lint
- name: Type Check
run: hatch run dev:typecheck
tests:
runs-on: ${{ matrix.os }}
strategy:
matrix:
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11"]

python-version: ["3.8", "3.9", "3.10", "3.11", "3.12"]
os: [ubuntu-latest, windows-latest]
steps:
- uses: actions/checkout@v3
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install .[tests]
- name: Lint with flake8
run: |
# stop the build if there are Python syntax errors or undefined names
flake8 delphin --count --select=E9,F63,F7,F82 --show-source --statistics
# exit-zero treats all errors as warnings. PEP-8 says 99 chars is a good width
flake8 delphin --count --exit-zero --extend-ignore E221 --max-line-length=99 --statistics
# E221 = whitespace before operator
# disabled for now: --max-complexity=10
- name: Test with pytest
run: |
pytest .
- name: Type-check with mypy
run: |
mypy delphin --namespace-packages --explicit-package-bases --ignore-missing-imports
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
- name: Install Hatch
run: pipx install hatch
- name: Test
run: hatch run dev:test
68 changes: 68 additions & 0 deletions .github/workflows/publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
name: Build and Publish to PyPI or TestPyPI

# Adapted from https://packaging.python.org/en/latest/guides/publishing-package-distribution-releases-using-github-actions-ci-cd-workflows/

on:
push

jobs:
build:
name: Build distribution
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: "3.x"
- name: Install Hatch
run: pipx install hatch
- name: Build
run: hatch build
- name: Store the distribution packages
uses: actions/upload-artifact@v3
with:
name: python-package-distributions
path: dist/

publish-to-pypi:
name: Publish distributions to PyPI
if: startsWith(github.ref, 'refs/tags/') # only publish to PyPI on tag pushes
needs:
- build
runs-on: ubuntu-latest
environment:
name: pypi
url: https://pypi.org/p/PyDelphin
permissions:
id-token: write # IMPORTANT: mandatory for trusted publishing
steps:
- name: Download the dists
uses: actions/download-artifact@v3
with:
name: python-package-distributions
path: dist/
- name: Publish to PyPI
uses: pypa/gh-action-pypi-publish@release/v1

publish-to-testpypi:
name: Publish distributions to TestPyPI
needs:
- build
runs-on: ubuntu-latest
environment:
name: testpypi
url: https://test.pypi.org/p/PyDelphin
permissions:
id-token: write # IMPORTANT: mandatory for trusted publishing
steps:
- name: Download the dists
uses: actions/download-artifact@v3
with:
name: python-package-distributions
path: dist/
- name: Publish to TestPyPI
uses: pypa/gh-action-pypi-publish@release/v1
with:
repository-url: https://test.pypi.org/legacy/
skip-existing: true
26 changes: 0 additions & 26 deletions .github/workflows/pythonpublish.yml

This file was deleted.

21 changes: 21 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,22 @@
# Change Log

### Unreleased

### Python Versions

* Removed Python 3.7 support ([#376])
* Added Python 3.12 support ([#376])

### Maintenance

* Migrate to a hatch-based build ([#374])

### Fixed

* Stop using Python's undocumented parse_template re function ([#378])
* Resolved newline and encoding issues for running tests on Windows ([#379])


## [v1.8.1]

**Release date: 2023-05-29**
Expand Down Expand Up @@ -1602,3 +1619,7 @@ information about changes, except for
[#360]: https://github.com/delph-in/pydelphin/issues/360
[#364]: https://github.com/delph-in/pydelphin/issues/364
[#367]: https://github.com/delph-in/pydelphin/issues/367
[#374]: https://github.com/delph-in/pydelphin/issues/374
[#376]: https://github.com/delph-in/pydelphin/issues/376
[#378]: https://github.com/delph-in/pydelphin/issues/378
[#379]: https://github.com/delph-in/pydelphin/issues/379
125 changes: 23 additions & 102 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

The easiest way to contribute to PyDelphin is to try it out and enter
bug reports and feature requests. If you're contributing code, fork
the repository and make pull requests to the `develop` branch.
the repository and make pull requests to the `main` branch.


## Filing issues
Expand All @@ -27,12 +27,12 @@ For bug requests, please provide the following, if possible:
```python
>>> from delphin.__about__ import __version__
>>> __version__ # distribution version
'1.8.0'
'1.8.1'
>>> from delphin import mrs
>>> mrs.__version__ # package version
'1.8.0'
'1.8.1'
```
* Python version (e.g. 3.7, 3.8, etc.)
* Python version (e.g. 3.9, 3.10, etc.)

For feature requests, please provide a use case for the feature.

Expand Down Expand Up @@ -61,80 +61,24 @@ Please follow these guidelines for code and repository changes:
functions. Follow [Google-style docstrings] and use
[reStructuredText] for formatting.

### Creating a Development Environment
### Testing the code

In order to run the tests and build the documentation you'll need to
create a development environment: a virtual environment with the
dependencies installed. First create and activate a virtual
environment from a terminal (the following assumes you have Python 3
installed; the commands may differ depending on your operating system
and choice of shell):

* Linux/macOS

```console
$ python3 -m venv env
$ source env/bin/activate
```

* Windows

```console
> py -3 -m venv env
> .\env\Scripts\Activate.ps1
```

Once activated, you should see `(env)` in the shell prompt. You can
then install PyDelphin's dependencies and run tests with the current
version of Python:
PyDelphin uses [Hatch](https://hatch.pypa.io/) for managing builds and
dependencies. Install Hatch and use the following commands for testing
your code locally:

```console
$ pip install -e .[dev]
$ hatch shell # activate a virtual environment with PyDelphin installed
$ hatch run dev:lint # lint the code
$ hatch run dev:typecheck # type-check the code
$ hatch run dev:test # run unit tests
$ hatch build # build a source distribution and wheel
```

The `-e` option is an "editable" install, meaning that Python will use
the source files directly (via symlinks) instead of copying them into
the virtual environment. The benefit is that you won't have to
reinstall each time you make a change. The `[dev]` extra installs all
dependencies for testing, building documentation, and uploading
releases. If you just want to run the unit tests, the `[tests]` extra
is sufficient.

### Testing

Always run the unit tests before committing. Simply run pytest from
PyDelphin's top directory to run the unit tests:

```console
$ pytest
```

Note that passing the tests for one version of Python may not be
sufficient for the code to be accepted; it must pass the tests against
all supported versions of Python.

The commands for linting (style and type checking) need some
configuration:

```console
$ flake8 delphin --extend-ignore E221
$ mypy delphin --namespace-packages --explicit-package-bases --ignore-missing-imports
```

These tests will be run automatically when a commit is pushed or pull
request is submitted against the `develop` branch, but it's often more
convenient to run it locally before pushing commits.

### Test Coverage

Compute test coverage by installing
[pytest-cov](https://github.com/pytest-dev/pytest-cov) and running:

pytest --cov-report=html --cov=delphin

Note that the codebase doesn't yet have full test coverage.
Contributions of unit tests are very welcome!

Always run the linting, type-checking, and testing commands before
committing. They will be run automatically on pull requests, but its
convenient to make sure everything looks good locally before opening a
pull request.

## Documentation

Expand All @@ -152,35 +96,12 @@ and generated using [Sphinx] on the [Read the Docs] service.
Repository files, such as the README, CHANGELOG, and CONTRIBUTING
files, are written in [Markdown].

For instructions on building the documentation, see [docs/](docs).
To build the documentation, run the following command:

```console
$ hatch run docs:build
```

Do not check in the generated documentation files (e.g., `*.html`);
only documentation source files belong, as the rest will be
generated automatically by [Read the Docs].


# Release Checklist

Do the following tasks prior to releasing on GitHub and PyPI.

- [ ] Create a branch for the release (e.g., `vX.Y.Z`)
- [ ] Merge into the release branch all features and fixes slated for the release
- [ ] Create a pull request for the version
- [ ] Ensure all related [issues] are resolved (check [milestones])
- [ ] Ensure tests pass
- [ ] Ensure the documentation builds without error (see above)
- [ ] Bump the version in `delphin/__about__.py`
- [ ] Update `README.md` if necessary
- [ ] Update `CHANGELOG.md` (header for version with release date)
- [ ] Merge
- [ ] [Make a new release](https://github.com/delph-in/pydelphin/releases/new)
- [ ] Ensure PyPI release was uploaded automatically (see [actions])
- [ ] Announce

[issues]: https://github.com/delph-in/pydelphin/issues
[milestones]: https://github.com/delph-in/pydelphin/milestones
[actions]: https://github.com/delph-in/pydelphin/actions
[Google-style docstrings]: https://google.github.io/styleguide/pyguide.html?showone=Comments#Comments
[Sphinx]: http://www.sphinx-doc.org/
[reStructuredText]: http://docutils.sourceforge.net/
[Read the Docs]: https://readthedocs.org/
[Markdown]: https://github.github.com/gfm/
Loading
Loading