Exceptions

Exceptions are defined in three different modules in the craft_parts package.

General errors

Exceptions for general errors are defined in the craft_parts.errors module.

Craft parts errors.

exception craft_parts.errors.CallbackRegistrationError(message)[source]

Bases: PartsError

Error in callback function registration.

Parameters:

message (str) – the error message.

exception craft_parts.errors.CopyFileNotFound(name)[source]

Bases: PartsError

An attempt was made to copy a file that doesn’t exist.

Parameters:

name (str) – The file name.

exception craft_parts.errors.CopyTreeError(message)[source]

Bases: PartsError

Failed to copy or link a file tree.

Parameters:

message (str) – The error message.

exception craft_parts.errors.DebError(deb_path, command, exit_code)[source]

Bases: PartsError

A “deb”-related command failed.

Parameters:
  • deb_path (Path)

  • command (list[str])

  • exit_code (int)

exception craft_parts.errors.FeatureError(message, details=None)[source]

Bases: PartsError

A feature is not configured as expected.

Parameters:
  • message (str)

  • details (Optional[str])

exception craft_parts.errors.FileOrganizeError(*, part_name, message)[source]

Bases: PartsError

Failed to organize a file layout.

Parameters:
  • part_name (str) – The name of the part being processed.

  • message (str) – The error message.

exception craft_parts.errors.FilesetConflict(conflicting_files)[source]

Bases: PartsError

Inconsistent stage to prime filtering.

Parameters:

conflicting_files (set[str]) – A set containing the conflicting file names.

exception craft_parts.errors.FilesetError(*, name, message)[source]

Bases: PartsError

An invalid fileset operation was performed.

Parameters:
  • name (str) – The name of the fileset.

  • message (str) – The error message.

exception craft_parts.errors.InvalidAction(message)[source]

Bases: PartsError

An attempt was made to execute an action with invalid parameters.

Parameters:

message (str) – The error message.

exception craft_parts.errors.InvalidApplicationName(name)[source]

Bases: PartsError

The application name contains invalid characters.

Parameters:

name (str) – The invalid application name.

exception craft_parts.errors.InvalidArchitecture(arch_name)[source]

Bases: PartsError

The machine architecture is not supported.

Parameters:

arch_name (str) – The unsupported architecture name.

exception craft_parts.errors.InvalidControlAPICall(*, part_name, scriptlet_name, message)[source]

Bases: PartsError

A control API call was made with invalid parameters.

Parameters:
  • part_name (str) – The name of the part being processed.

  • scriptlet_name (str) – The name of the scriptlet that originated the call.

  • message (str) – The error message.

exception craft_parts.errors.InvalidPartName(part_name)[source]

Bases: PartsError

An operation was requested on a part that’s not in the parts specification.

Parameters:

part_name (str) – The invalid part name.

exception craft_parts.errors.InvalidPlugin(plugin_name, *, part_name)[source]

Bases: PartsError

A request was made to use a plugin that’s not registered.

Parameters:
  • plugin_name (str) – The invalid plugin name.”

  • part_name (str) – The name of the part defining the invalid plugin.

exception craft_parts.errors.OsReleaseCodenameError[source]

Bases: PartsError

Failed to determine the host operating system version codename.

exception craft_parts.errors.OsReleaseIdError[source]

Bases: PartsError

Failed to determine the host operating system identification string.

exception craft_parts.errors.OsReleaseNameError[source]

Bases: PartsError

Failed to determine the host operating system name.

exception craft_parts.errors.OsReleaseVersionIdError[source]

Bases: PartsError

Failed to determine the host operating system version.

exception craft_parts.errors.OverlayPackageNotFound(*, part_name, package_name)[source]

Bases: PartsError

Failed to install an overlay package.

Parameters:
  • part_name (str) – The name of the part being processed.

  • message – the error message.

  • package_name (str)

exception craft_parts.errors.OverlayPermissionError[source]

Bases: PartsError

A project using overlays was processed by a non-privileged user.

exception craft_parts.errors.OverlayPlatformError[source]

Bases: PartsError

A project using overlays was processed on a non-Linux platform.

exception craft_parts.errors.PartDependencyCycle[source]

Bases: PartsError

A dependency cycle has been detected in the parts definition.

exception craft_parts.errors.PartFilesConflict(*, part_name, other_part_name, conflicting_files, partition=None)[source]

Bases: PartsError

Different parts list the same files with different contents.

Parameters:
  • part_name (str) – The name of the part being processed.

  • other_part_name (str) – The name of the conflicting part.

  • conflicting_files (list[str]) – The list of conflicting files.

  • partition (Optional[str]) – Optional name of the partition where the conflict occurred.

exception craft_parts.errors.PartSpecificationError(*, part_name, message)[source]

Bases: PartsError

A part was not correctly specified.

Parameters:
  • part_name (str) – The name of the part being processed.

  • message (str) – The error message.

classmethod from_validation_error(*, part_name, error_list)[source]

Create a PartSpecificationError from a pydantic error list.

Parameters:
  • part_name (str) – The name of the part being processed.

  • error_list (list[ErrorDict]) – A list of dictionaries containing pydantic error definitions.

Return type:

PartSpecificationError

exception craft_parts.errors.PartitionError(brief, *, details=None, resolution=None)[source]

Bases: PartsError

Errors related to partitions.

Parameters:
  • brief (str)

  • details (Optional[str])

  • resolution (Optional[str])

exception craft_parts.errors.PartitionNotFound(partition_name, partitions)[source]

Bases: PartitionUsageError

A partition has been specified that does not exist.

Parameters:
  • partition_name (str) – The name of the partition that does not exist.

  • partitions (Iterable[str]) – Iterable of the names of valid partitions.

exception craft_parts.errors.PartitionUsageError(error_list, partitions, brief=None)[source]

Bases: PartitionError

Error for a list of invalid partition usages.

Parameters:
  • error_list (Iterable[str]) – Iterable of strings describing the invalid usages.

  • partitions (Iterable[str] | None) – Iterable of the names of valid partitions.

  • brief (Optional[str]) – Override brief message.

exception craft_parts.errors.PartitionUsageWarning(warning_list)[source]

Bases: PartitionError, Warning

Warnings for possibly invalid usages of partitions.

Parameters:

warning_list (Iterable[str]) – Iterable of strings describing the misuses.

exception craft_parts.errors.PartsError(brief, details=None, resolution=None, doc_slug=None)[source]

Bases: Exception

Unexpected error.

Parameters:
  • brief (str) – Brief description of error.

  • details (Optional[str]) – Detailed information.

  • resolution (Optional[str]) – Recommendation, if any.

  • doc_slug (Optional[str]) – Reusable documentation slug for consumers adopting the Craft Parts documentation.

property details: str | None

Further details on the error.

exception craft_parts.errors.PluginBuildError(*, part_name, plugin_name, stderr=None)[source]

Bases: UserExecutionError

Plugin build script failed at runtime.

Parameters:
  • part_name (str) – The name of the part being processed.

  • plugin_name (str) – The name of the plugin being processed.

  • stderr (Optional[bytes]) – The contents of the build execution error.

exception craft_parts.errors.PluginCleanError(*, part_name)[source]

Bases: PartsError

Script to clean strict build preparation failed at runtime.

Parameters:

part_name (str) – The name of the part being processed.

exception craft_parts.errors.PluginEnvironmentValidationError(*, part_name, reason)[source]

Bases: PartsError

Plugin environment validation failed at runtime.

Parameters:
  • part_name (str) – The name of the part being processed.

  • reason (str)

exception craft_parts.errors.PluginNotStrict(plugin_name, *, part_name)[source]

Bases: PartsError

A request was made to use a plugin that’s not strict.

Parameters:
  • plugin_name (str) – The plugin name.

  • part_name (str) – The name of the part defining the plugin.

exception craft_parts.errors.PluginPullError(*, part_name)[source]

Bases: PartsError

Plugin pull script failed at runtime.

Parameters:

part_name (str) – The name of the part being processed.

exception craft_parts.errors.ScriptletRunError(*, part_name, scriptlet_name, exit_code, stderr=None)[source]

Bases: UserExecutionError

A scriptlet execution failed.

Parameters:
  • part_name (str) – The name of the part being processed.

  • scriptlet_name (str) – The name of the scriptlet that failed to execute.

  • exit_code (int) – The execution error code.

  • stderr (Optional[bytes]) – The contents of the scriptlet execution error.

exception craft_parts.errors.StageFilesConflict(*, part_name, conflicting_files)[source]

Bases: PartsError

Files from a part conflict with files already being staged.

Parameters:
  • part_name (str) – The name of the part being processed.

  • conflicting_files (list[str]) – The list of confictling files.

exception craft_parts.errors.StagePackageNotFound(*, part_name, package_name)[source]

Bases: PartsError

Failed to install a stage package.

Parameters:
  • part_name (str) – The name of the part being processed.

  • package_name (str) – The name of the package.

exception craft_parts.errors.UndefinedPlugin(*, part_name)[source]

Bases: PartsError

The part didn’t define a plugin and the part name is not a valid plugin name.

Parameters:

part_name (str) – The name of the part with no plugin definition.

exception craft_parts.errors.UserExecutionError(*, brief, resolution, stderr=None)[source]

Bases: PartsError, ABC

Plugin build script failed at runtime.

Parameters:
  • part_name – The name of the part being processed.

  • plugin_name – The name of the plugin being processed.

  • brief (str)

  • resolution (str)

  • stderr (Optional[bytes])

property details: str | None

Further details on the error.

Discards all trace lines that come before the last-executed script line

exception craft_parts.errors.XAttributeError(key, path, is_write=False)[source]

Bases: PartsError

Failed to read or write an extended attribute.

Parameters:
  • action – The action being performed.

  • key (str) – The extended attribute key.

  • path (str) – The file path.

  • is_write (bool) – Whether this is an attribute write operation.

exception craft_parts.errors.XAttributeTooLong(key, value, path)[source]

Bases: PartsError

Failed to write an extended attribute because key and/or value is too long.

Parameters:
  • key (str) – The extended attribute key.

  • value (str) – The extended attribute value.

  • path (str) – The file path.

Source handling errors

Exceptions for errors related to source handling are defined in the craft_parts.sources.errors module.

Source handler error definitions.

exception craft_parts.sources.errors.ChecksumMismatch(*, expected, obtained)[source]

Bases: SourceError

A checksum doesn’t match the expected value.

Parameters:
  • expected (str) – The expected checksum.

  • obtained (str) – The actual checksum.

exception craft_parts.sources.errors.HttpRequestError(*, status_code, reason, source)[source]

Bases: SourceError

HTTP error occurred during request processing.

Parameters:
  • status_code (int) – Request status code.

  • reason (str) – Text explaining status code.

  • source (str) – The source defined for the part.

exception craft_parts.sources.errors.IncompatibleSourceOptions(source_type, options)[source]

Bases: SourceError

Source specified options that cannot be used at the same time.

Parameters:
  • source_type (str) – The part’s source type.

  • options (list[str]) – The list of incompatible source options.

exception craft_parts.sources.errors.InvalidRpmPackage(rpm_file)[source]

Bases: SourceError

An rpm package is invalid.

Parameters:

rpm_file (str) – The filename.

exception craft_parts.sources.errors.InvalidSnapPackage(snap_file)[source]

Bases: SourceError

A snap package is invalid.

Parameters:

snap_file (str) – The snap file name.

exception craft_parts.sources.errors.InvalidSourceOption(*, source_type, option)[source]

Bases: SourceError

A source option is not allowed for the given source type.

Parameters:
  • source_type (str) – The part’s source type.

  • option (str) – The invalid source option.

exception craft_parts.sources.errors.InvalidSourceOptions(*, source_type, options)[source]

Bases: SourceError

A source option is not allowed for the given source type.

Parameters:
  • source_type (str) – The part’s source type.

  • options (list[str]) – The invalid source options.

exception craft_parts.sources.errors.InvalidSourceType(source, *, source_type=None)[source]

Bases: SourceError

Failed to determine a source type.

Parameters:
  • source (str) – The source defined for the part.

  • source_type (Optional[str])

exception craft_parts.sources.errors.NetworkRequestError(message, *, source=None)[source]

Bases: SourceError

A network request operation failed.

Parameters:
  • message (str) – The error message.

  • source (Optional[str]) – URL of unreachable source.

exception craft_parts.sources.errors.PullError(*, command, exit_code)[source]

Bases: SourceError

Failed pulling source.

Parameters:
  • command (Sequence) – The command used to pull the source.

  • exit_code (int) – The command exit code.

exception craft_parts.sources.errors.SourceError(brief, details=None, resolution=None, doc_slug=None)[source]

Bases: PartsError

Base class for source handler errors.

Parameters:
  • brief (str)

  • details (Optional[str])

  • resolution (Optional[str])

  • doc_slug (Optional[str])

exception craft_parts.sources.errors.SourceNotFound(source)[source]

Bases: SourceError

Failed to retrieve a source.

Parameters:

source (str) – The source defined for the part.

exception craft_parts.sources.errors.SourceUpdateUnsupported(name)[source]

Bases: SourceError

The source handler doesn’t support updating.

Parameters:

name (str) – The source type.

exception craft_parts.sources.errors.VCSError(message)[source]

Bases: SourceError

A version control system command failed.

Parameters:

message (str)

Package handling errors

Exceptions for errors related to package handling are defined in the craft_parts.packages.errors module.

Exceptions raised by the packages handling subsystem.

exception craft_parts.packages.errors.BuildPackageNotFound(package)[source]

Bases: PackagesError

A package listed in ‘build-packages’ was not found.

Parameters:

package (str) – The name of the missing package.

exception craft_parts.packages.errors.BuildPackagesNotInstalled(*, packages)[source]

Bases: PackagesError

Could not install all requested build packages.

Parameters:

packages (Sequence[str]) – The packages to install.

exception craft_parts.packages.errors.ChiselError(*, slices, output)[source]

Bases: PackagesError

A “chisel”-related command failed.

Parameters:
  • slices (list[str])

  • output (str)

exception craft_parts.packages.errors.FileProviderNotFound(*, file_path)[source]

Bases: PackagesError

A file is not provided by any package.

Parameters:

file_path (str) – The file path.

exception craft_parts.packages.errors.PackageBackendNotSupported(backend)[source]

Bases: PartsError

Requested package resolved not supported on this host.

Parameters:

backend (str)

exception craft_parts.packages.errors.PackageBroken(package_name, *, deps)[source]

Bases: PackagesError

Package has unmet dependencies.

Parameters:
  • package_name (str) – The name of the package with unmet dependencies.

  • deps (Sequence[str]) – The list of unmet dependencies.

exception craft_parts.packages.errors.PackageFetchError(message)[source]

Bases: PackagesError

Failed to fetch package from remote repository.

Parameters:

message (str) – The error message.

exception craft_parts.packages.errors.PackageListRefreshError(message)[source]

Bases: PackagesError

Failed to refresh the list of available packages.

Parameters:

message (str) – The error message.

exception craft_parts.packages.errors.PackageNotFound(package_name)[source]

Bases: PackagesError

Requested package doesn’t exist in the remote repository.

Parameters:

package_name (str) – The name of the missing package.

exception craft_parts.packages.errors.PackagesDownloadError(*, packages)[source]

Bases: PackagesError

Failed to download packages from remote repository.

Parameters:

packages (Sequence[str]) – The packages to download.

exception craft_parts.packages.errors.PackagesError(brief, details=None, resolution=None, doc_slug=None)[source]

Bases: PartsError

Base class for package handler errors.

Parameters:
  • brief (str)

  • details (Optional[str])

  • resolution (Optional[str])

  • doc_slug (Optional[str])

exception craft_parts.packages.errors.PackagesNotFound(packages)[source]

Bases: PackagesError

Requested package doesn’t exist in the remote repository.

Parameters:
  • package_name – The names of the missing packages.

  • packages (Sequence[str])

exception craft_parts.packages.errors.SnapDownloadError(*, snap_name, snap_channel)[source]

Bases: PackagesError

Failed to download a snap.

Parameters:
  • snap_name (str) – The snap name.

  • snap_channel (str) – The snap channel.

exception craft_parts.packages.errors.SnapGetAssertionError(*, assertion_params)[source]

Bases: PackagesError

Failed to retrieve snap assertion.

Parameters:

assertion_params (Sequence[str]) – The snap assertion parameters.

exception craft_parts.packages.errors.SnapInstallError(*, snap_name, snap_channel)[source]

Bases: PackagesError

Failed to install a snap.

Parameters:
  • snap_name (str) – The snap name.

  • snap_channel (str) – The snap channel.

exception craft_parts.packages.errors.SnapRefreshError(*, snap_name, snap_channel)[source]

Bases: PackagesError

Failed to refresh a snap.

Parameters:
  • snap_name (str) – The snap name.

  • snap_channel (str) – The snap channel.

exception craft_parts.packages.errors.SnapUnavailable(*, snap_name, snap_channel)[source]

Bases: PackagesError

Failed to install or refresh a snap.

Parameters:
  • snap_name (str) – The snap name.

  • snap_channel (str) – The snap channel.

exception craft_parts.packages.errors.SnapdConnectionError(*, snap_name, url)[source]

Bases: PackagesError

Failed to connect to snapd.

Parameters:
  • snap_name (str) – The snap name.

  • url (str) – The failed connection URL.

exception craft_parts.packages.errors.UnpackError(package)[source]

Bases: PackagesError

Error unpacking stage package.

Parameters:

package (str) – The package that failed to unpack.