Do you want to contribute? We would love your help 🤗
Feel free to submit patches, issues, feature requests, pull requests on the GitHub repo.
Please note that ics.py is maintained by volunteers (mostly one volunteer) on their free time. It might take some time for us to have a look at your work.
Please include the following in your bug reports:
- the version of ics.py you are using; run :command:`pip freeze | grep ics`
- the version of Python :command:`python -v`
- the OS you are using
Please also include a (preferably minimal) example of the code or the input that causes problem along with the stacktrace if there is one.
First, before writing your PR, please open an issue, on GitHub to discuss the problem you want to solve and debate on the way you are solving it. This might save you a lot of time if the maintainers are already working on it or have a specific idea on how the problem should be solved.
There are three Python tools required to develop, test, and release ics.py:
- poetry for managing virtualenvs, dependencies, building, and publishing the package.
- tox for running the testsuite and building the documentation.
- bump2version to help with making a release.
Their respective configuration files are :file:`pyproject.toml`, :file:`tox.ini` and :file:`.bumpversion.cfg`. Install the tools via pip:
$ pip install tox poetry bump2version --user
Note
If you want to develop using multiple different Python versions, you might want to consider the poetry installer.
Poetry will automatically manage a virtualenv that you can use for developing. By default, it will be located centrally in your home directory (e.g. in :file:`/home/user/.cache/pypoetry/virtualenvs/`). To make poetry use a :file:`./.venv/` directory within the ics.py folder, use the following config:
$ poetry config virtualenvs.in-project true
Now you are ready to setup your development environment using the following command:
$ poetry install
This will create a new virtualenv and install the dependencies for using ics.py. Furthermore, the current source of the ics.py package will be available similar to running :command:`./setup.py develop`. To access the virtualenv, use :command:`poetry run python` or :command:`poetry shell`. The :file:`poetry.lock` file locks the versions of dependencies in the development environment set up by poetry. This ensures that such an environment is the same for everyone. The file :file:`poetry.lock` is only read by poetry and not included in any distributions. These restrictions don't apply when running :command:`pip install ics`. As tox manages its own environments and doesn't read the lock file, it installs the latest versions of dependencies for testing. More details on the poetry side can be found in the poetry documentation.
If you made some changes and now want to lint your code, run the testsuite, or build the documentation, run tox. You don't have to worry about which versions in which venvs are installed and whether you're directly testing against the sources or against a built package, tox handles all that for you:
$ tox
To run a single task and not the whole testsuite, use the -e
flag:
$ tox -e docs
To get a list of all available tasks, run :command:`tox -av`.
Note
If you want to run any tasks of tox manually, make sure you have all the dependencies of the task listed in :file:`tox.ini`.
For testing with pytest, this can be done through poetry by installing the test
extra: :command:`poetry install -E test`.
Alternatively, you can also let tox set up your development environment or re-use one of its test environments:
$ tox -e py38
$ source .tox/py38/bin/activate
(py38) $ pytest
This also works without having poetry installed.
Please add a test and add a link to it in the PR description proving that the bug is fixed. This will help us merge your PR quickly and above all, this will make sure that we won't re-introduce the bug later by mistake.
We will ask you to provide:
- A few tests showing your feature works as intended (they are also great examples and will prevent regressions)
- Write docstrings on the public API
- Add type annotations where possible
- Think about where and how this will affect documentation and amend the respective section
- Please add yourself to :file:`AUTHORS.rst`
- and state your changes in :file:`CHANGELOG.rst`.
Note
Your PR will most likely be squashed in a single commit, authored
by the maintainer that merged the PR and you will be credited with a
Co-authored-by:
in the commit message (this way GitHub picks up
your contribution).
The title of your PR will become the commit message, please craft it with care.
If you want to publish a new release, use the following steps
# Grab the sources and install the dev tools
git clone https://github.com/ics-py/ics-py.git && cd ics-py
pip install tox poetry bump2version --user
# Make sure all the test run
tox && echo "Ready to make a new release" \
|| echo "Please fix all the tests first"
# Bump the version and make a "0.8.0-dev -> 0.8.0 (release)" commit
bump2version --verbose release
# Build the package
poetry build
# Ensure that the version numbers are consistent
tox --recreate
# Check changelog and amend if necessary
vi CHANGELOG.rst && git commit -i CHANGELOG.rst --amend
# Publish to GitHub
git push && git push --tags
# Publish to PyPi
poetry publish
# Bump the version again to start development of next version
bump2version --verbose minor # 0.8.0 (release) -> 0.9.0-dev
# Start new changelog
vi CHANGELOG.rst && git commit -i CHANGELOG.rst --amend
# Publish to GitHub
git push && git push --tags
Please note that bump2version directly makes a commit with the new version if you don't
pass --no-commit
or --dry-run
,
but that's no problem as you can easily amend any changes you want to make.
Further things to check:
- Check GitHub and PyPi release pages for obvious errors
- Build documentation for the tag v{version} on rtfd.org
- Set the default rtfd version to {version}