Welcome to the sentinelsat
open source project. We invite anyone to participate by contributing code, reporting bugs, fixing bugs, writing documentation and tutorials and discussing the future of this project.
Please search existing issues, open and closed, before creating a new one.
Providing a Short, Self Contained, Correct (Compilable), Example (SSCCE) demonstrating the issue is encouraged.
sentinelsat
is not v1.0
. There may be backwards incompatible changes which you can find in the changelog (CHANGELOG.rst). We invite you to propose changes and features you would like to see in v1.0
.
sentinelsat
is meant to be a Pythonic client to the Copernicus Open Access Hub and other manifestations of the Data Hub System (DHuS).sentinelsat
should interface the functions of DHuS where possible, rather than replicating them in Python.- all code must be Python 3 compliant but we strive for backwards compatibility with Python 2 where possible
If you want to contribute code or documentation the proposed way is:
- Fork the repository.
- Create a branch and make your changes in it.
- Create a pull request.
If you plan on introducing major changes it is a good idea to create an issue first and discuss these changes with other contributors.
sentinelsat
supports Python 2 and Python 3 in the same code base.
We strongly prefer code adhering to PEP8.
Tests are mandatory for new features. We use pytest and Travis-CI. All unit tests must use prerecorded responses to Copernicus Open Access Hub. We use VCR.py to record the responses. We aspire to 100% coverage but regard meaningful tests to be more important than reaching this goal. Test coverage is tracked with Codecov.
We keep a changelog (CHANGELOG.rst) following the keepachangelog template.
Good documentation is important to us. We use Sphinx and host the documentation at sentinelsat.readthedocs.io. All public functions should have docstrings. We use the numpy docstring standard.
We prefer developing with the most recent version of Python. sentinelsat
currently supports Python 2.7 and all versions after 3.4.
First, clone sentinelsat
's git
repo:
git clone https://github.com/sentinelsat/sentinelsat
Development should occur within a virtual environment (venv, conda, etc.) to better isolate development work from your regular Python environments.
sentinelsat
and its dependencies can be installed with pip
. Specifying the [dev]
extra in the command below tells
pip
to also install sentinelsat
's dev dependencies.
cd sentinelsat/
pip install -e .[dev]
sentinelsat
's tests are located in /tests
.
To run the tests
pytest -v
By default, prerecorded responses to Copernicus Open Access Hub queries are used to not be affected by its downtime.
Furthermore, any network accesses are blocked as well (by raising a pytest_socket.SocketBlockedError: A test tried to use socket.socket
exception) to guarantee that all tests are indeed correctly covered by recorded queries.
To allow the tests to run actual queries against the Copernicus Open Access Hub set the environment variables and add --disable-vcr
to pytest
arguments.
export DHUS_USER=<username>
export DHUS_PASSWORD=<password>
pytest -v --disable-vcr
To update the recordings use --vcr-record
with once
, new_episodes
or all
. See vcrpy docs for details.
When you create a pull requests the tests will automatically run on Travis and a coverage report will be created from Codecov.
sentinelsat
uses semantic versioning from the v1.0
release forward. Prior to that the versioning is 0.Major.MinorAndPatch
.
Version numbers need to be adapted in sentinelsat/__init__.py as well as the Github compare link in the Readme.
Documentation is automatically built after each merge in the master
branch using a webhook. The documentation landing page is set to stable
, which defaults to the latest release.
A new Zenodo DOI is created automatically with every Github release using the Zenodo webhook.
A new package is release on PyPi with the following commands.
pip install rstcheck twine
rstcheck README.rst CONTRIBUTE.rst AUTHORS.rst
python setup.py sdist bdist_wheel --universal
twine upload --repository-url https://test.pypi.org/legacy/ dist/*
twine upload dist/*
The GNU General Public License version 3 or later (GPLv3+, see LICENSE) applies to all contributions.