Releases: canonical/charmcraft
2.3.0
New features
- store: add unregister command by @lengau in #1069
- bases: support creating charms use CentOS 7 as base by @syu-w in #1065
- pack: add recursive bundle packing by @lengau in #1060
- pack: include the charm libraries dependencies (CRAFT-1559) by @facundobatista in #1003
- command: add the initial promote-bundle command by @lengau in #1044
Bug Fixes
- Run the charm builder with python in unbuffered mode. by @facundobatista in #989
- refactor: Move charm library helper functions to their own modules (CRAFT-1557) by @lengau in #993
- refactor: get_lib_internals now uses AST (CRAFT-1558) by @facundobatista in #1000
- Remove a verification left over after init command refactor. by @facundobatista in #1031
- refactor: isolate the charm lib internals extractor by @facundobatista in #998
- tools: editorconfig by @lengau in #1026
- Transform the few remaining tests inside classes to regular functions. by @facundobatista in #1033
- Update tox.ini in
charmcraft init
template by @carlcsaposs-canonical in #1010 - Fix typo in CONTRIBUTING.md in
charmcraft init
template by @carlcsaposs-canonical in #1012 - tools: Stricter noise limits for Renovate by @lengau in #1001
- deps: update python-apt by @lengau in #1025
- ci: remove deprecated ubuntu 18.04 GitHub CI by @syu-w in #1043
- charm libraries: allow anonymous fetching by @syu-w in #1037
- move config check from load() to command.run() by @syu-w in #1035
- deps: update requirements url for ubuntu 20.04 by @syu-w in #1048
- requirements: update craft-parts to 1.19.0 by @cmatsuoka in #1049
- plugin: make charm plugin base aware by @syu-w in #1045
- hook: clean charmcraft images when update/remove by @syu-w in #1046
- cli: add how to use exported credentials in help by @syu-w in #1050
- store: check the credentials validity before upload by @syu-w in #1052
- tools: import tox from starbase by @lengau in #1062
- Update charm templates to use ops 2.2.0 and new "import ops" style by @benhoyt in #1055
- parts: CentOS 7 python 3.8 path workaround by @syu-w in #1053
- deps: remove ops dependency by @lengau in #1064
- Don't reference non-existent --all argument in publish-lib help by @benhoyt in #1032
- ci: fix lxd image name too long by @syu-w in #1074
- ci: update sources install_charmcraft by @syu-w in #1076
- ci: only require CHARMCRAFT_AUTH for store spread by @sergiusens in #1075
- store: ensure promote-bundle succeeds if there are no applications by @lengau in #1081
- deps: update dependency versions by @lengau in #1086
- charmlibs: skip non top-level name assignments by @sergiusens in #1085
- tests: check for submodules before running spread by @mr-cal in #1084
- version: import logic from snapcraft by @sergiusens in #1073
- tools: update renovate config by @lengau in #1082
- snap: pick the version from setup.py by @sergiusens in #1087
- spread: only install docker for store tests by @sergiusens in #1088
- ci: fix spread test missing PATH by @syu-w in #1083
- Spread smoke by @sergiusens in #1090
- store: fix issues with promote-bundle command by @lengau in #1089
- snap: ensure cryptography builds correctly on all architectures by @lengau in #1091
Renovate Changes
- Update Default rules by @renovate in #949
- Refine renovate configuration by @lengau in #955
- (tests) Added a comment about credentials in Spread tests to use Charmhub by @facundobatista in #965
- chore(deps): update actions/checkout action to v3 by @renovate in #961
- chore(deps): update patch updates by @renovate in #983
- chore(deps): update actions/setup-python action to v4 by @renovate in #963
- chore(deps): update dependency pytz to v2022.7 by @renovate in #974
- chore(deps): update dependency pydocstyle to v6.2.3 by @renovate in #972
- chore(deps): update actions/download-artifact action to v3 by @renovate in #962
- chore(deps): update patch updates by @renovate in #987
- chore(deps): update dependency exceptiongroup to v1.1.0 by @renovate in #967
- chore(deps): update dependency attrs to v22.2.0 by @renovate in #964
- chore(deps): update dependency filelock to v3.9.0 by @renovate in #968
- chore(deps): update actions/upload-artifact action to v3 by @renovate in #981
- chore(deps): update dependency keyring to v23.13.1 by @renovate in #970
- chore(deps): update dependency pyproject_api to v1.4.0 by @renovate in #973
- chore(deps): update dependency coverage to v7 by @renovate in #977
- chore(deps): update dependency iniconfig to v2 by @renovate in #985
- chore(deps): update dependency importlib-metadata to v6 by @renovate in #979
- chore(deps): update dependency charset-normalizer to v3 by @renovate in #976
- chore(deps): update dependency pyproject_api to v1.5.0 by @renovate in #996
- chore(deps): update internal packages by @renovate in #984
- chore(deps): update dependency pydocstyle to v6.3.0 by @renovate in #995
- chore(deps): update dependency packaging to v23 by @renovate in #986
- chore(deps): update dependency tox to v4.3.5 by @renovate in #997
- chore(deps): update dependency markupsafe to v2.1.2 by @renovate in #994
- chore(templates): update codespell config in templates to use pyproject by @jnsgruk in #999
- chore(deps): update dependency tox to v4.4.2 by @renovate in #1008
- chore(deps): update dependency pathspec to v0.11.0 by @renovate in #1007
- chore(deps): update dependency coverage to v7.1.0 by @renovate in #1006
- chore(deps): update dependency ops to v2 by @renovate in #1009
- chore(deps): update dependency cachetools to v5.3.0 by @renovate in #1005
- chore(deps): update dependency craft-providers to v1.7.1 by @renovate in #1004
- chore(deps): update patch updates by @renovate in #1014
- chore(deps): update dependency humanize to v4.5.0 by @renovate in #1015
- chore(deps): update dependency craft-providers to v1.7.2 by @renovate in #1023
- chore(deps): update patch updates by @renovate in #1022
- chore(deps): update patch updates by @renovate in #1027
- chore(deps): update dependency zipp to v3.15.0 by @renovate in #1016
- chore(deps): update dependency humanize to v4.6.0 by @renovate in #1028
- chore(deps): update dependency black to v23 by @renovate in https://github.com/canonical/charmcraf...
Release 2.2.0
-
Support including collaborations when listing registered names (related issue)
-
Stopped showing repeated branches in Status command results (related issue)
-
Better messages to the user in several situations:
- when pushing a charm library and the lib's patch number is too high
- on a login attempt when already having credentials (related issue)
- improved the help for
--format
option in several commands (related issue)
-
Show (with value hidden) the authentication environment variable in system details in logs (related issue)
-
Support correctly local OCI images with empty
RepoDigests
key -
Lot of internal improvements: integration tests, code restructuring and simplification, and project cleanup in general.
Release 2.1.0
-
Created the profile option for the
init
command; templates provided so far:simple
: (the default if--profile
not used) a basic kubernetes charm with lot of texts helping the developer to navigate their first charm, including unit and integration tests andtox
configuration (related issue)kubernetes
: also a k8s charm but more sintetic, aimed for more experienced developersmachine
: also a sintetic base charm but meant to be deployed in machine-based environments (related issues this and this)
-
Use incremental delays (with very small first ones) during the polling of upload status (related issue)
-
Instrumented the
pack
command so timings can be easily captured (related issue)- provided a
--measure
option to dump measurements to a file - and a tool to visualize those measurements (related issue)
- provided a
-
Several
reactive
plugin improvements:- Fix charm tools version validation (related issue)
- Support arguments to charm build command (related issue)
- Properly check returncode from charm tool (related issue)
-
Support both image id and digest when uploading oci-image resources. (related issue)
-
Isolated charm_builder.py as a generic plugin script (related issue)
-
Better charm's entry point validation (it's a linter now, so it can be ignored or run explicitly)
-
Several internal help messages and web documentation improvements.
Release 2.0.0
-
Started to use the new Craft CLI, which brings to the project better verbosity levels and improved verbosity-related global options
-
Added programmatic outputs to several commands (related issue)
-
Several deprecations were enforced:
- (DN03) The
bases
key in the configuration is now required (related issue) - (DN04) Removed the
--entrypoint
option from thepack
command (usecharm-entrypoint
in the config) (related issue) - (DN05) Removed the
--requirements
option from thepack
command (usecharm-requirements
in the config) (related issue) - (DN06) Removed the long time deprecated
build
command (usepack
instead)
- (DN03) The
-
Now the
--force
option in thepack
command is also used when packing inside an instance -
Do not expose the logpath (from the instance) when running in managed mode (related issue)
-
Validate the entrypoint after build (not before, as it may be created during the build itself) (related issue)
-
Do not modify the charm's project when packing using the reactive plugin (related issue)
Release 1.7.1
- Validate that the charm's entry point exists and is executable after the lifecycle process (as it may be generated during that process)
Release 1.7.0
-
The
22.04
base is now supported (related issue). -
Improved error messages for the JujuMetadata and other linters (related issue).
-
Better support for packing charms using Multipass provider in environments without
snapd
. -
Enhanced the
revisions
and other commands' outputs to show detailed timestamps (related issue). -
The
pack
command now includes by default theactions
directory, if present (related issue). -
A keyring is not longer required in the system when using the
--export
option in thelogin
command (related issue). -
The entrypoint is now always validated to be correct, even if it's the default
src/charm.py
(related issue). -
Produced a specification for Charmcraft Programmatic Outputs.
-
Fixed the user interaction in the
--shell
option for thepack
command (related issue). -
Other minor fixes/improvements:
-
Save temp retrieved file in current directory so it's fine for the case of running inside a strict snap.
-
Pass the project's dir owner id when creating the lxd instance.
-
Re-use the file descriptor already opened by the tempfile to not leak it.
-
Release 1.6.0
-
Several performance related improvements:
- Reuse already installed dependencies from last run if requirements didn't change
- Faster launch of existing containers when packing charms
-
Improved user experience:
- Show lifecycle step progress (related issue)
- The deprecated 'build' command is now hidden and 'pack' appears more prominently in the help messages (related issue)
- Better error messages in a couple of commands
- Fixed interaction with user when asking if to install Multipass in Windows (related issue)
-
Enabled
craftcl
from Craft Parts scriptlets to be able to run the overridden step's built-in handler (related issue) -
Full logs from building container are always retrieved, even after a success
pack
(related issue) -
Updated the
ops
framework version in theinit
template -
Fixed a bug in libraries handling so disk paths are always importable (related issue)
-
Fixed which remote image was used by Multipass provider
-
Save the content of
CHARMCRAFT_IMAGE_INFO
environment variable into the Charm's manifest
Release 1.5.0
-
Added the
--name
option in theupload
command to override the name declared in the metadata -
Improved logging with details of the system where it's being run (operating system, version, desktop, etc) for better debugging
-
Fixed the Framework linter to use the name from metadata in reactive charms
-
Added instructions to install Charmcraft from PyPI.
-
Fixed the
release
command to allow resources with revision0
-
Fixed the process execution inside the isolated container so logs can be properly obtained from it
-
Reworked how Craft Store errors are handled to expose failures correctly
-
Backward compatibility notices (check the Charmcraft deprecations documentation for more info):
-
Deprecated the
build
command, usepack
instead (DN06
) -
Enforced
DN01
: do not support charmhub attributes with underscores anymore -
Enforced
DN02
: the charmcraft.yaml is not longer optional for build command
-
-
Updated Craft Parts to version
1.2.0
, relevant change:- performance improvement by not refreshing already installed snaps
-
Updated Craft Store to version
2.0.1
, relevant changes:-
raise an error when a keyring is not found to explicit that credentials could not be stored
-
do not allow overwriting existing credentials (to avoid the peril of leaving the system with wrong credentials stored)
-
fail properly when cannot parse correctly the credentials given through an environment variable
-
-
Fully adopted the Craft CLI library
Release 1.4.0
-
Several packing related improvements:
-
added two new properties to the default
charm
plugin:charm-python-packages
to list Python packages to install from PyPI before installing requirements (these packages will be installed from sources and built locally at packing time) andcharm-binary-python-packages
very similar to the first one but allowing binary packages to be used -
updated the
craft-parts
library to allow the packing of hook based charms (more information in the Pack a hook based charm with Charmcraft tutorial). -
introduced a new
reactive
plugin to pack charms using the legacycharm
tool (see the Pack a reactive based charm with Charmcraft tutorial for more information) -
created two new linters to verify that mandatory
actions.yaml
andconfig.yaml
files exist and have a proper YAML format -
the building process now ignores the
venv
directory in the project sources
-
-
The store-related functionality is now provided by the
craft-store
library, which uses a new authentication backend that allowed several benefits:-
there is a new
--export
option in thelogin
command to save the obtained credentials to a file -
the content of that file can be given to
charmcraft
through a newCHARMCRAFT_AUTH
environment variable, which allows for easier integration with non-interactive environments (e.g. a CI/CD system) -
added options to the
login
command to restrict the obtained credentials (shorter time to live, applies to specific charms, etc.) -
the
whoami
command now shows the credentials restrictions
A combination of several of these new features can be found in the How to authenticate Charmcraft in remote environments tutorial.
-
-
The
craft-cli
library handles the exposure of messages to the user, improving the UX in general, and in particular:-
added a new
--trace
global option that sets the Emitter level in TRACE, for debugging purposes -
now a proper progress bar is used where uploading files is involved in different commands
-
-
The
CHARMCRAFT_DEVELOPER
environment variable is no longer mandatory to runcharmcraft
from alternative sources (i.e. not from the snap)
Release 1.3.1
- Added a
charm-python-packages
plugin property so any Python package can be installed before the charm packing happens.