Changelog

See the Releases page on GitHub for a complete list of commits that are included in each version.

2.2.0 (2025-Jan-16)

  • hookutil.py now available for dependent projects to clean up lxd instances.

  • Dependent projects can now disable lxd mknod interception via LXDProvider’s __init__.

2.1.0 (2025-Jan-10)

  • Require Multipass>=1.14.1

  • Use Multipass-compatible instance names

2.0.4 (2024-Oct-03)

  • requests-unixsocket dependency is replaced with requests-unixsocket2

2.0.3 (2024-Oct-02)

  • Fix a bug where signed aliased snaps couldn’t be injected into the build environment.

1.20.4 (2024-Sep-27)

  • requests-unixsocket dependency is replaced with requests-unixsocket2

  • Fix a bug where signed aliased snaps couldn’t be injected into the build environment.

2.0.2 (2024-Sep-26)

  • Improve multipass version parsing

2.0.1 (2024-Aug-28)

  • Require Multipass>=1.14.1 when launching Ubuntu 24.04 (Noble) VMs, which adds support for the 24.04 buildd image

  • Note

    2.0.1 includes changes from the 1.24.2 release.

1.24.2 (2024-Aug-27)

  • Remove Ubuntu 23.10 (Mantic) support

  • Require Multipass>=1.14.1 when launching Ubuntu 24.04 (Noble) VMs, which adds support for the 24.04 buildd image

2.0.0 (2024-Aug-09)

Breaking changes:

  • Set minimum Python version to 3.10

  • Migrate to Pydantic 2

Removal of deprecated features:

  • string type parameter for lxd.remotes.get_remote_image()

  • parameter build_base in provider.Provider.launched_enviroment()

  • parameter use_snapshots in lxd.launcher.launch()

  • configure_buildd_image_remote() in lxd.remotes

1.25.0 (2024-Jul-24)

  • Use Ubuntu 24.04 buildd image for Multipass

  • Remove Ubuntu 23.10 (Mantic) support

1.24.0 (2024-Jun-18)

  • Add support for Ubuntu 24.10 (Oracular)

1.20.3 (2024-Apr-11)

  • Do not mount cache directories in LXD base instances.

  • Update base compatibility tag from base-v4 to base-v8

1.23.1 (2024-Mar-15)

  • Parse LXD versions with “LTS” suffix

1.20.2 (2024-Mar-15)

  • Parse LXD versions with “LTS” suffix

1.23.0 (2024-Feb-28)

  • Update base compatibility tag to base-v7

  • Use buildd daily for Ubuntu 24.04 (Noble) and Ubuntu devel images

  • Ensure apt installs non-interactively

1.24.1 (2024-Feb-07)

  • Improve detection of installed LXD

  • Update the link to the network troubleshooting docs

1.22.0 (2024-Jan-30)

  • Do not update apt sources for Ubuntu devel images

1.21.0 (2024-Jan-17)

  • Update base compatibility tag to base-v6

  • Add Ubuntu 24.04 (Noble) support

  • Remove Ubuntu 23.04 (Lunar) support

1.19.3 (2023-Dec-01)

  • Update base compatibility tag to base-v5.

  • Do not mount cache directories in LXD base instances.

1.20.1 (2023-Nov-30)

  • Update base compatibility tag to base-v4

  • If an existing base instance is not setup, then it is auto-cleaned. If the process that created the not setup base instance is inactive, then craft-providers will immediately auto-clean the instance.

1.20.0 (2023-Nov-10)

  • Snaps injected from the host will have their base snap injected into the instance.

1.19.2 (2023-Nov-02)

  • Update base compatibility tag from base-v2 to base-v3 This fixes an issue where LXD instances created with craft-providers==1.16.0 may fail to start with craft-providers>=1.17.0.

1.19.1 (2023-Oct-26)

  • Require a disk device in the default LXD profile

1.19.0 (2023-Oct-23)

  • Add Ubuntu 23.10 (Mantic) support

1.18.0 (2023-Sep-28)

  • Check if base instance status before copying

  • Fail quickly when LXD errors do not involve instance creation

  • Add check parameter to execute_run

1.17.0 (2023-Sep-22)

  • Use a shared pip cache across instances

  • Remove Ubuntu 22.10 (Kinetic) support

  • Capture details for snap errors

1.16.0 (2023-Aug-25)

  • Improve LXD instance creation process to avoid race conditions. The base instance is now created first and copied to an instance. Retry, timeout, and locking mechanisms prevent multiple processes from creating the same base instance.

  • Add LXD functions check_instance_status(), config_set(), config_get(), and restart()

1.15.0 (2023-Aug-21)

  • Update base compatibility tag from base-v1 to base-v2

  • Use snap refresh --hold inside instances

  • Re-level log messages

  • Add more info-level log messages

  • Update links from linuxcontainers.org to ubuntu.com

  • Set timezone of LXD instances to match host’s timezone

  • Add name and install recommendations to Providers

1.14.1 (2023-Jul-24)

  • Prevent race when two processes try to create the same project at the same time

1.10.1 (2023-Jun-29)

  • Set hostname when launching LXD instances

  • Update Lunar image for Multipass to stable image

  • Pin dependency urllib3<2

1.14.0 (2023-Jun-28)

  • Update Lunar image for Multipass to stable image

  • Install common packages and clean up package cache on bases

  • Push files to any location in Multipass instances

  • CI, linting, and testing overhaul

  • Add Diataxis front page for documentation

  • Improve push_file_io for LXD instances

  • Improve retry-until-timeout logic

  • Refactor base classes

  • Improve operability with Python 3.12

1.13.0 (2023-May-31)

  • Push files to any location in Multipass instances

  • Refactor base setup and warmup

  • Replace timeout for entire base setup with granular per-step timeouts

  • Add option to not install default packages during base setup

  • Install build-essentials and python3 in CentOS and AlmaLinux

  • Update PATH for CentOS

1.12.0 (2023-May-18)

  • Add AlmaLinux 9 base

  • Add stricter typing for base names

  • Refactor CI workflow

  • Refactor Multipass push_file_io

  • Pin dependency urllib3<2

1.11.0 (2023-Apr-19)

  • Move Snap pydantic model from bases.buildd to actions.snap_installer

  • Rename bases.buildd module to bases.ubuntu

  • Determine base alias from base configuration in provider.launched_environment()

  • Add new functions get_base_alias() and get_base_from_alias()

  • Add CentOS 7 base

  • Add default for launched_environment() parameter allow_unstable=False

  • Trim suffixes from snap names when installing snaps.

1.10.0 (2023-Mar-31)

  • Add support for kinetic, lunar, and devel images with Multipass

  • Remove unused import suppressions in init files

  • Update github actions

1.9.0 (2023-Mar-20)

  • Set cloud.cfg to not reset apt’s source list for buildd bases

  • Store LXD instance’s full name in the config’s description

  • Add allow_unstable parameter to Provider.launched_environment()

1.8.1 (2023-Mar-10)

  • Add new base alias BuilddBaseAlias.DEVEL

  • Expire unstable base instances every 14 days

  • Refactor tests such that all base aliases are tested by default

1.8.0 (2023-Mar-01)

  • Track if instances are properly setup when launching. If the instance did not fully complete setup and auto-clean is enabled, the instance will be cleaned and recreated.

  • Add new field setup to instance configuration to track set up status

  • Update base compatibility tag from base-v0 to base-v1

  • Add new BuilddBaseAliases for Lunar and Kinetic

  • Add support for interim Ubuntu releases for LXD

  • Add support for custom LXD image remotes. LXD remotes can now add any remote server to retrieve images from using the RemoteImage class.

  • Add deprecation warning for LXD function configure_buildd_image_remote(). Usage of this function should be replaced with RemoteImage’s add_remote().

  • Rename BuilddBase function setup_instance_config() to update_compatibility_tag()

  • Update brew for macOS CI tests

  • Update readthedocs link in readme

  • Capture subproccess error details when snap removal fails

  • Add default for _run_lxc() parameter check=True

  • Refactor lxd unit and integration tests

  • Enable more pylint checks

  • Use new use_base_instance parameter when launching LXD instances from LXDProvider

1.7.2 (2023-Feb-06)

  • Check LXD id map before starting an existing instance. If the id map does not match, the instance will be auto cleaned or an error will be raised.

  • Add lxc.config_get() method to retrieve config values

1.7.1 (2023-Jan-23)

  • Set LXD id maps after launching or copying an instance

  • Raise BaseConfigurationError for snap refresh failures

1.7.0 (2023-Jan-11)

  • LXD instances launch from a cached base instance rather than a base image. This reduces disk usage and launch time.

  • For the LXD launch function launched_environment, the parameter use_snapshots has been replaced by use_base_instance. use_snapshots still works but logs a deprecation notice.

  • Expire and recreate base instances older than 3 months (90 days)

  • Add lxc.copy() method to copy instances

  • Check for network connectivity after network-related commands fail

  • Add documentation for network connectivity issues inside instances

  • Enable testing for Ubuntu 22.04 images

  • Update MultipassInstance.push_file_io() to work regardless of the host’s working directory

1.6.2 (2022-Dec-08)

  • Disable automatic snap refreshes inside instances.

1.6.1 (2022-Oct-31)

  • Store temporary files in the home directory

  • Fix typos

1.6.0 (2022-Oct-06)

  • Add is_running method to base Executor class

  • Add new classes Provider, LXDProvider, and MultipassProvider

Note: The new Provider classes are used to encapsulate LXD and Multipass,

from installing the provider to creating and managing instances. The code was leveraged from the craft applications (snapcraft, charmcraft, rockcraft, lpcraft), which implemented similar variations of these Provider classes. These classes are not stable and are likely to change. They will be stable and recommended for use in the release of craft-providers 2.0.

1.5.1 (2022-Sep-29)

  • When injecting a snap, assert the snap’s publisher’s account

  • Avoid race condition when multiple processes add a LXD remote at the same time

1.5.0 (2022-Sep-23)

  • Add mount method to Executor base class

  • LXDInstance’s mount method signature has changed - The optional parameter device_name has been deprecated. It now matches MultipassInstance’s signature of mount(host_source, target)

  • Signed snaps injected into a provider are asserted

  • Existing .snap files are not removed before overwriting with a new .snap file

1.4.2 (2022-Sep-09)

  • Set snapd http-proxy and https-proxy

  • Pass on snapd no-CDN configuration

1.4.1 (2022-Aug-30)

  • Fix bug in BuilddBase where hostnames longer than 64 characters may not having trailing hyphens removed.

  • Allow overriding of compatibility tag in Bases

1.4.0 (2022-Aug-22)

  • Use LXD-compatible instance names

  • Add optional list of snaps to install in bases

  • Add optional list of system packages to install in bases

  • Add new temporarily_pull_file function to Executor base class

  • Add exists and delete function to Executor base class

  • Declare more instance paths as PurePath

  • Ensure BuilddBase hostname is valid

  • Move .pylintrc to pyproject.toml

  • Enforce line-too-long

  • Fix for unit tests on non-linux platforms

Note: The provided name for a LXD executor object is converted to comply with

LXD naming conventions for instances. This may cause a compatibility issue for applications that assume the LXD instance name will be identical to the Executor name.

If a provided name already complies with LXD naming conventions, it is not modified.

1.3.1 (2022-Jun-09)

  • Add stdin parameter for LXC commands (default: null)

1.3.0 (2022-May-21)

  • Refactor snap injection logic

  • Always check multipass command execution results

  • Update tests and documentation

1.2.0 (2022-Apr-07)

  • Refactor instance configuration

  • Disable automatic apt actions in instance setup

  • Warm-start existing instances instead of rerunning full setup

  • Don’t reinstall snaps already installed on target

1.1.1 (2022-Mar-30)

  • Fix LXD user permission verification

1.1.0 (2022-Mar-16)

  • Add buildd base alias for Jammy

1.0.5 (2022-Mar-09)

  • Fix uid mapping in lxd host mounts

1.0.4 (2022-Mar-02)

  • Export public API names

  • Declare instance paths as PurePath

  • Address linter issues

  • Update documentation