mirror of
https://projects.torsion.org/witten/borgmatic.git
synced 2025-01-08 00:55:42 +00:00
217 lines
7.3 KiB
Markdown
217 lines
7.3 KiB
Markdown
---
|
|
title: How to develop on borgmatic
|
|
eleventyNavigation:
|
|
key: 🏗️ Develop on borgmatic
|
|
parent: How-to guides
|
|
order: 15
|
|
---
|
|
## Source code
|
|
|
|
To get set up to develop on borgmatic, first [`install
|
|
pipx`](https://torsion.org/borgmatic/docs/how-to/set-up-backups/#installation)
|
|
to make managing your borgmatic environment easier without impacting other
|
|
Python applications on your system.
|
|
|
|
Then, clone borgmatic via HTTPS or SSH:
|
|
|
|
```bash
|
|
git clone https://projects.torsion.org/borgmatic-collective/borgmatic.git
|
|
```
|
|
|
|
Or:
|
|
|
|
```bash
|
|
git clone ssh://git@projects.torsion.org:3022/borgmatic-collective/borgmatic.git
|
|
```
|
|
|
|
Finally, install borgmatic
|
|
"[editable](https://pip.pypa.io/en/stable/topics/local-project-installs/#editable-installs)"
|
|
so that you can run borgmatic actions during development to make sure your
|
|
changes work:
|
|
|
|
```bash
|
|
cd borgmatic
|
|
pipx ensurepath
|
|
pipx install --editable .
|
|
```
|
|
|
|
Or to work on the [Apprise
|
|
hook](https://torsion.org/borgmatic/docs/how-to/monitor-your-backups/#apprise-hook),
|
|
change that last line to:
|
|
|
|
```bash
|
|
pipx install --editable .[Apprise]
|
|
```
|
|
|
|
To get oriented with the borgmatic source code, have a look at the [source
|
|
code reference](https://torsion.org/borgmatic/docs/reference/source-code/).
|
|
|
|
|
|
## 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. You can either install a system package of tox (likely
|
|
called `tox` or `python-tox`) or you can install tox with pipx:
|
|
|
|
```bash
|
|
pipx install tox
|
|
```
|
|
|
|
Finally, to actually run tests, run tox from inside the borgmatic
|
|
sourcedirectory:
|
|
|
|
```bash
|
|
tox
|
|
```
|
|
|
|
### Code formatting
|
|
|
|
If when running tests, you get an error from the
|
|
[Black](https://black.readthedocs.io/en/stable/) code formatter about files
|
|
that would be reformatted, you can ask Black to format them for you via the
|
|
following:
|
|
|
|
```bash
|
|
tox -e black
|
|
```
|
|
|
|
And if you get a complaint from the
|
|
[isort](https://github.com/timothycrosley/isort) Python import orderer, you
|
|
can ask isort to order your imports for you:
|
|
|
|
```bash
|
|
tox -e isort
|
|
```
|
|
|
|
Similarly, if you get errors about spelling mistakes in source code, you can
|
|
ask [codespell](https://github.com/codespell-project/codespell) to correct
|
|
them:
|
|
|
|
```bash
|
|
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 dev-CI parity.
|
|
|
|
If you would like to run the end-to-end tests, first install Docker (or
|
|
Podman; see below) and [Docker
|
|
Compose](https://docs.docker.com/compose/install/). Then run:
|
|
|
|
```bash
|
|
scripts/run-end-to-end-tests
|
|
```
|
|
|
|
This script assumes you have permission to run `docker`. If you don't, then
|
|
you may need to run with `sudo`.
|
|
|
|
|
|
#### Podman
|
|
|
|
<span class="minilink minilink-addedin">New in version 1.7.12</span>
|
|
borgmatic's end-to-end tests optionally support using
|
|
[rootless](https://github.com/containers/podman/blob/main/docs/tutorials/rootless_tutorial.md)
|
|
[Podman](https://podman.io/) 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:
|
|
```bash
|
|
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](https://www.python.org/dev/peps/pep-0008/). 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.
|
|
* In general, spell out words in variable names instead of shortening them.
|
|
So, think `index` instead of `idx`. There are some notable exceptions to
|
|
this though (like `config`).
|
|
* Favor blank lines around logical code groupings, `if` statements,
|
|
`return`s, etc. Readability is more important than packing code tightly.
|
|
* Import fully qualified Python modules instead of importing individual
|
|
functions, classes, or constants. E.g., do `import os.path` instead of
|
|
`from os import path`. (Some exceptions to this are made in tests.)
|
|
* Only use classes and OOP as a last resort, such as when integrating with
|
|
Python libraries that require it.
|
|
* Prefer functional code where it makes sense, e.g. when constructing a
|
|
command (to subsequently execute imperatively).
|
|
|
|
borgmatic uses the [Black](https://black.readthedocs.io/en/stable/) code
|
|
formatter, the [Flake8](http://flake8.pycqa.org/en/latest/) code checker, and
|
|
the [isort](https://github.com/timothycrosley/isort) import orderer, so
|
|
certain code style requirements are enforced when running automated tests. See
|
|
the Black, Flake8, and isort documentation for more information.
|
|
|
|
|
|
## Continuous integration
|
|
|
|
Each commit to
|
|
[main](https://projects.torsion.org/borgmatic-collective/borgmatic/branches)
|
|
triggers [a continuous integration
|
|
build](https://projects.torsion.org/borgmatic-collective/borgmatic/actions)
|
|
which runs the test suite and updates
|
|
[documentation](https://torsion.org/borgmatic/). These builds are also linked
|
|
from the [commits for the main
|
|
branch](https://projects.torsion.org/borgmatic-collective/borgmatic/commits/branch/main).
|
|
|
|
## 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:
|
|
|
|
```bash
|
|
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
|
|
|
|
<span class="minilink minilink-addedin">New in version 1.7.12</span>
|
|
borgmatic's developer build for documentation optionally supports using
|
|
[rootless](https://github.com/containers/podman/blob/main/docs/tutorials/rootless_tutorial.md)
|
|
[Podman](https://podman.io/) 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.
|