You can use build
to simply build the source and binary distribution:
python -m pip install build
python -m build
You can use editable installs to develop the project locally (it will install all the dependencies too):
python -m pip install -e .
Or you can install all development dependencies (mypy
, pylint
, pytest
,
etc.) in one go too:
python -m pip install -e .[dev]
If you don't want to install all the dependencies, you can also use nox
to
run the tests and other checks creating its own virtual environments:
python -m pip install .[dev-noxfile]
nox
You can also use nox -R
to reuse the current testing environment to speed up
test at the expense of a higher chance to end up with a dirty test environment.
For a better development test cycle you can install the runtime and test
dependencies and run pytest
manually.
python -m pip install .[dev-pytest] # included in .[dev] too
# And for example
pytest tests/test_*.py
Or you can use nox
:
nox -R -s pytest -- test/test_*.py
The same appliest to pylint
or mypy
for example:
nox -R -s pylint -- test/test_*.py
nox -R -s mypy -- test/test_*.py
To test the generated files using the Cookiecutter templates, the golden testing technique is used to ensure that changes in the templates don't occur unexpectedly.
If a golden test fails, a diff
of the contents will be provided in the test
results.
Failures in the golden tests could indicate two things:
-
The generated files don't match the golden files because an unintended change was introduced. For example, there may be a bug that needs to be fixed so that the generated files match the golden files again.
-
The generated files don't match the golden files because an intended change was introduced. In this case, the golden files need to be updated.
In the latter case, manually updating files is complicated and error-prone, so a simpler (though hacky) way is provided.
To update the golden files, simply run pytest
for the tests using golden
files setting the environment variable UPDATE_GOLDEN
to 1
:
UPDATE_GOLDEN=1 pytest tests/integration/test_cookiecutter_generation.py::test_golden
This will replace the existing golden files (stored in tests_golden/
) with
the newly generated files.
Note that if you rename, or remove golden files, you should also manually
remove the files that were affected. An easy way to make sure there are no old
unused golden files left is to just wipe the whole tests_golden/
directory
before running pytest
to generate the new ones.
Please ensure that all introduced changes are intended before updating the golden files.
To build the documentation, first install the dependencies (if you didn't
install all dev
dependencies):
python -m pip install -e .[dev-mkdocs]
Then you can build the documentation (it will be written in the site/
directory):
mkdocs build
Or you can just serve the documentation without building it using:
mkdocs serve
Your site will be updated live when you change your files (provided that
you used pip install -e .
, beware of a common pitfall of using pip install
without -e
, in that case the API reference won't change unless you do a new
pip install
).
To build multi-version documentation, we use mike. If you want to see how the multi-version sites looks like locally, you can use:
mike deploy my-version
mike set-default my-version
mike serve
mike
works in mysterious ways. Some basic information:
mike deploy
will do amike build
and write the results to your localgh-pages
branch.my-version
is an arbitrary name for the local version you want to preview.mike set-default
is needed so when you serve the documentation, it goes to your newly produced documentation by default.mike serve
will serve the contents of your localgh-pages
branch. Be aware that, unlikemkdocs serve
, changes to the sources won't be shown live, as themike deploy
step is needed to refresh them.
Be careful not to use --push
with mike deploy
, otherwise it will push your
local gh-pages
branch to the origin
remote.
That said, if you want to test the actual website in your fork, you can
always use mike deploy --push --remote your-fork-remote
, and then access the
GitHub pages produced for your fork.
These are the steps to create a new release:
-
Get the latest head you want to create a release from.
-
Update the
RELEASE_NOTES.md
file if it is not complete, up to date, and remove template comments (<!-- ... ->
) and empty sections. Submit a pull request if an update is needed, wait until it is merged, and update the latest head you want to create a release from to get the new merged pull request. -
Create a new signed tag using the release notes and a semver compatible version number with a
v
prefix, for example:git tag -s --cleanup=whitespace -F RELEASE_NOTES.md v0.0.1
-
Push the new tag.
-
A GitHub action will test the tag and if all goes well it will create a GitHub Release, and upload a new package to PyPI automatically.
-
Once this is done, reset the
RELEASE_NOTES.md
with the template:cp .github/RELEASE_NOTES.template.md RELEASE_NOTES.md cp .github/cookiecutter-migrate.template.py cookiecutter/migrate.py
Commit the new release notes and migration script, and create a PR (this step should be automated eventually too).
-
Celebrate!
This project has built-in support for testing across multiple architectures.
Currently, our CI conducts tests on arm64
machines using QEMU emulation. We
also have the flexibility to expand this support to include additional
architectures in the future.
This project contains Dockerfiles that can be used in the CI to test the
python package in non-native machine architectures, e.g., arm64
. The
Dockerfiles exist in the directory .github/containers/nox-cross-arch
, and
follow a naming scheme so that they can be easily used in build matrices in the
CI, in nox-cross-arch
job. The naming scheme is:
<arch>-<os>-python-<python-version>.Dockerfile
E.g.,
arm64-ubuntu-20.04-python-3.11.Dockerfile
If a Dockerfile for your desired target architecture, OS, and python version does not exist here, please add one before proceeding to add your options to the test matrix.