We want to make sure everyone develops using a consistent base, to ensure that these instructions rely on LXD (use whatever is convenient as long as you do not stray away from an Ubuntu LTS base)
Clone the snapcraft repository and its submodules and make it your working directory:
git clone https://github.com/canonical/snapcraft.git --recurse-submodules
cd snapcraft
If you already have LXD setup you can skip this part, if not, run:
sudo snap install lxd
sudo lxd init --auto --storage-backend=dir
sudo adduser "$USER" lxd
newgrp lxd
Setup the environment by running:
./tools/environment-setup.sh
To work inside this environment, run:
lxc exec snapcraft-dev -- sudo -iu ubuntu bash
Import your keys (ssh-import-id
) and add a Host
entry to your ssh config if you are interested in Code's Remote-SSH plugin.
We use a large number of tools for our project. Most of these are installed for you with tox, but you'll need to install:
- Python 3.12 (default on Ubuntu 24.04) with setuptools.
- tox version 3.8 or later
- pyright (also available via snap:
snap install pyright
) - ruff (also available via snap:
snap install ruff
) - ShellCheck (also available via snap:
snap install shellcheck
)
See the Testing guide.
Given that the --debug
option in snapcraft is reserved for project specific debugging, enabling for the logger.debug
calls is achieved by setting the "SNAPCRAFT_ENABLE_DEVELOPER_DEBUG" environment variable to a truthful value. Snapcraft's internal tools, e.g.; snapcraftctl
should pick up this environment variable as well.
To render the documentation as HTML in docs/_build
, run:
tox run -e build-docs
Important
Interactive builds are currently defective and cause an infinite loop. This GitHub issue posits that this is caused by by pages referencing each other.
If you prefer to compose pages interactively, you can host the documentation on a local server:
tox run -e autobuild-docs
You can reach the interactive site at http://127.0.0.1:8080 in a web browser.
The documentation Makefile provided by the Sphinx Starter Pack provides a number of natural language checks such as style guide adherence, inclusive words, and product terminology, however they currently aren't configured correctly for Snapcraft. Instead, you can validate for basic language and syntax using two of the development tests.
To check for syntax errors in documentation, run:
tox run -e lint-docs
For a rudimentary spell check, you can use codespell:
tox run -e lint-codespell
Oftentimes all you want to do is see if a given pull request solves the issue you were having. To make this easier, a snap is published for amd64
on a channel named latest/edge/pr-<PR number>
where PR number
is the number of the pull request.
For feature branches, a snap is published for amd64
on a channel named latest/edge/<branch name>
. For example, a branch named feature/offline-mode
would be available on the channel latest/edge/offline-mode
.
We'd love the help!
- Submit pull requests against snapcraft
- Make sure to read the contribution guide
- Find us under the snapcraft category of the forum https://forum.snapcraft.io
- Discuss with us using IRC in #snapcraft on Freenode.