src.asqi.backends.base¶
Classes¶
Base class for protocol classes. |
Module Contents¶
- class src.asqi.backends.base.ContainerBackend¶
Bases:
ProtocolBase class for protocol classes.
Protocol classes are defined as:
class Proto(Protocol): def meth(self) -> int: ...
Such classes are primarily used with static type checkers that recognize structural subtyping (static duck-typing).
For example:
class C: def meth(self) -> int: return 0 def func(x: Proto) -> int: return x.meth() func(C()) # Passes static type check
See PEP 544 for details. Protocol classes decorated with @typing.runtime_checkable act as simple-minded runtime protocols that check only the presence of given attributes, ignoring their type signatures. Protocol classes can be generic, they are defined as:
class GenProto[T](Protocol): def meth(self) -> T: ...
- run(image: str, args: list[str], container_config: asqi.config.ContainerConfig, environment: dict[str, str] | None = None, name: str | None = None, workflow_id: str = '', manifest: asqi.schemas.Manifest | None = None) dict[str, Any]¶
- shutdown(workflow_ids: list[str] | None = None) None¶
- check_images(images: list[str]) dict[str, bool]¶
- pull_images(images: list[str]) None¶
- extract_manifest(image: str, manifest_path: str = ContainerConfig.MANIFEST_PATH) asqi.schemas.Manifest | None¶