6.1 KiB
title | eleventyNavigation | ||||||
---|---|---|---|---|---|---|---|
How to develop on borgmatic |
|
Source code
To get set up to develop on borgmatic, first clone it via HTTPS or SSH:
git clone https://projects.torsion.org/borgmatic-collective/borgmatic.git
Or:
git clone ssh://git@projects.torsion.org:3022/borgmatic-collective/borgmatic.git
Then, install borgmatic "editable" so that you can run borgmatic actions during development to make sure your changes work.
cd borgmatic
pip3 install --user --editable .
Note that this will typically install the borgmatic commands into
~/.local/bin
, which may or may not be on your PATH. There are other ways to
install borgmatic editable as well, for instance into the system Python
install (so without --user
, as root), or even into a
virtualenv. How or where you install
borgmatic is up to you, but generally an editable install makes development
and testing easier.
Automated tests
Assuming you've cloned the borgmatic source code as described above, and
you're in the borgmatic/
working copy, install tox, which is used for
setting up testing environments:
pip3 install --user tox
Finally, to actually run tests, run:
tox
Code formatting
If when running tests, you get an error from the Black code formatter about files that would be reformatted, you can ask Black to format them for you via the following:
tox -e black
And if you get a complaint from the isort Python import orderer, you can ask isort to order your imports for you:
tox -e isort
Similarly, if you get errors about spelling mistakes in source code, you can ask codespell to correct them:
tox -e codespell
End-to-end tests
borgmatic additionally includes some end-to-end tests that integration test
with Borg and supported databases for a few representative scenarios. These
tests don't run by default when running tox
, because they're relatively slow
and depend on containers for runtime dependencies. These tests do run on the
continuous integration (CI) server, and running them on your developer machine
is the closest thing to CI-test parity.
If you would like to run the full test suite, first install Docker (or Podman; see below) and Docker Compose. Then run:
scripts/run-end-to-end-dev-tests
This script assumes you have permission to run docker
. If you don't, then
you may need to run with sudo
.
Podman
New in version 1.7.12 borgmatic's end-to-end tests optionally support using rootless Podman instead of Docker.
Setting up Podman is outside the scope of this documentation, but here are some key points to double-check:
- Install Podman and your desired networking support.
- Configure
/etc/subuid
and/etc/subgid
to map users/groups for the non-root user who will run tests. - Create a non-root Podman socket for that user:
systemctl --user enable --now podman.socket systemctl --user start --now podman.socket
Then you'll be able to run end-to-end tests as per normal, and the test script will automatically use your non-root Podman socket instead of a Docker socket.
Code style
Start with PEP 8. But then, apply the following deviations from it:
- For strings, prefer single quotes over double quotes.
- Limit all lines to a maximum of 100 characters.
- Use trailing commas within multiline values or argument lists.
- For multiline constructs, put opening and closing delimiters on lines separate from their contents.
- Within multiline constructs, use standard four-space indentation. Don't align indentation with an opening delimiter.
borgmatic code uses the Black code formatter, the Flake8 code checker, and the isort import orderer, so certain code style requirements will be enforced when running automated tests. See the Black, Flake8, and isort documentation for more information.
Continuous integration
Each pull request triggers a continuous integration build which runs the test suite. You can view these builds on build.torsion.org, and they're also linked from the commits list on each pull request.
Documentation development
Updates to borgmatic's documentation are welcome. It's formatted in Markdown
and located in the docs/
directory in borgmatic's source, plus the
README.md
file at the root.
To build and view a copy of the documentation with your local changes, run the following from the root of borgmatic's source code:
scripts/dev-docs
This requires Docker (or Podman; see below) to be installed on your system.
This script assumes you have permission to run docker
. If you don't, then
you may need to run with sudo
.
After you run the script, you can point your web browser at http://localhost:8080 to view the documentation with your changes.
To close the documentation server, ctrl-C the script. Note that it does not currently auto-reload, so you'll need to stop it and re-run it for any additional documentation changes to take effect.
Podman
New in version 1.7.12 borgmatic's developer build for documentation optionally supports using rootless Podman instead of Docker.
Setting up Podman is outside the scope of this documentation. But once you
install and configure Podman, then scripts/dev-docs
should automatically use
Podman instead of Docker.