Optionally install Python package and project manager uv, in order to significantly speed up the package installation:
{apt,brew,pip,zypper} install uv alias pip="uv pip"
To start things off, bootstrap the sandbox environment:
git clone https://github.com/crate/crate-python cd crate-python source bootstrap.sh
This command should automatically install all prerequisites for the development sandbox and drop you into the virtualenv, ready for invoking further commands.
All tests will be invoked using the Python interpreter that was used when creating the Python virtualenv. The test runner is zope.testrunner.
Some examples are outlined below. In order to learn about more details, see, for example, useful command-line options for zope-testrunner.
Run all tests:
poe test
Run specific tests:
# Select modules. bin/test -t test_cursor bin/test -t client bin/test -t testing # Select doctests. bin/test -t http.rst
Ignore specific test directories:
bin/test --ignore_dir=testing
The LayerTest
test cases have quite some overhead. Omitting them will save
a few cycles (~70 seconds runtime):
bin/test -t '!LayerTest'
Invoke all tests without integration tests (~10 seconds runtime):
bin/test --layer '!crate.testing.layer.crate' --test '!LayerTest'
Yet ~60 test cases, but only ~1 second runtime:
bin/test --layer '!crate.testing.layer.crate' --test '!LayerTest' \ -t '!test_client_threaded' -t '!test_no_retry_on_read_timeout' \ -t '!test_wait_for_http' -t '!test_table_clustered_by'
To inspect the whole list of test cases, run:
bin/test --list-tests
The CI setup on GitHub Actions (GHA) provides a full test matrix covering
relevant Python versions. You can invoke the software tests against a specific
Python interpreter or multiple Python versions on your workstation using
uv, by supplying the --python
command-line option, or by defining the
UV_PYTHON environment variable prior to invoking source bootstrap.sh
.
Note: Before running the tests, make sure to stop all CrateDB instances which are listening on the default CrateDB transport port to avoid side effects with the test layer.
To use Ruff for code formatting, according to the standards configured in
pyproject.toml
, use:
poe format
To lint the code base using Ruff and mypy, use:
poe lint
Linting and software testing, all together now:
poe check
For conducting TLS connectivity tests, there are a few X.509 certificates at tests/assets/pki/*.pem. In order to renew them, follow the instructions within the README file in this folder.
To create a new release, you must:
- Backport your bug fixes to the latest stable branch x.y (e.g. 0.19)
- For new features, create a new stable branch x.(y+1) (e.g. 0.20)
In the release branch:
- Update
__version__
insrc/crate/client/__init__.py
- Add a section for the new version in the
CHANGES.rst
file - Commit your changes with a message like "prepare release x.y.z"
- Push to origin/<release_branch>
- Create a tag by running
./devtools/create_tag.sh
. This will trigger a Github action which releases the new version to PyPi.
On branch main
:
- Update the release notes to reflect the release
Next:
- Archive docs for old releases (see section below)
Check the versions hosted on ReadTheDocs.
We should only be hosting the docs for latest, stable, and the most recent patch versions for the last two minor releases.
To make changes to the RTD configuration (e.g., to activate or deactivate a release version), please contact the @crate/docs team.
The docs live under the docs
directory.
The docs are written written with ReStructuredText and processed with Sphinx.
Build the docs by running:
./bin/sphinx
The output can then be found in the out/html
directory.
The docs are automatically built from Git by Read the Docs and there is nothing special you need to do to get the live docs to update.