Framework to set up an environment by deploying and configuring the devices in such environment.
Project description
Vitro
Vitro is a Python framework for setting up and operating testbed environments — deploying, configuring, and orchestrating the devices that make up a system under test. It is the second-generation successor to Boardfarm, distilling its lessons into a leaner, plugin-driven core.
Background
The previous generation packaged the framework, a large built-in device library, and test integrations together in a single project. Vitro splits those concerns: the core is a small orchestrator that knows nothing about specific devices or test runners. Device drivers, environment helpers, and reservation systems are contributed externally as plugins. A separate, shared template/operations pool can be layered on top to keep multiple plugins interoperable.
The result is a framework you can adopt for a single testbed without pulling in code for every device anyone has ever supported, while still allowing standardised test resources to be assembled across organisations.
What Vitro gives you
- Two-file environment model. A standardised
environment.json(devices and their roles) merged with a testbed-specificinventory.json(connection details) viajsonmerge. - Pluggable device registry. Plugins contribute device classes via the
vitro_add_deviceshook; Vitro wires them up by type string from the config. - Lifecycle hooks. Boot and configure phases, distinct for servers, devices, and attached devices, with sync and async variants.
- Plugin extension surface (pluggy). Reservation, command-line args, config parsing, environment setup, and shutdown are all hookable.
- Connection helpers. Pexpect-based SSH, serial, and local-command
connections in
vitro.libraries.connections. vitroCLI. A standalone entry point that drives the full reserve → register → boot → configure cycle from a JSON config pair.
Quick start
Install:
pip install vitro
A minimal device plugin lives in your own package. The device class
subclasses VitroDevice and implements lifecycle methods that Vitro
discovers by name; a module-level @hookimpl registers the device type
string with the framework:
# my_plugin/__init__.py
from vitro import hookimpl
from vitro.devices.base_devices import VitroDevice
class MyBox(VitroDevice):
"""Driver for the device type "my_box"."""
def vitro_device_boot(self, config, cmdline_args, device_manager):
"""Boot sequence — connect, verify required tools, etc."""
...
def vitro_device_configure(self, config, cmdline_args, device_manager):
"""Apply post-boot configuration."""
...
@hookimpl
def vitro_add_devices() -> dict[str, type[VitroDevice]]:
"""Tell Vitro about our device type."""
return {"my_box": MyBox}
Register the package as a Vitro plugin via a setuptools entry point:
# pyproject.toml
[project.entry-points."vitro"]
my_plugin = "my_plugin"
With an environment.json that references "type": "my_box" for one or
more devices, and an inventory.json providing their connection details,
run:
vitro --board-name my-testbed \
--env-config environment.json \
--inventory-config inventory.json
Vitro will reserve, register, boot, and configure the devices, then keep
them available for the next stage of your workflow — interactive
exploration, automated tests via pytest-vitro, or any other consumer
of the live device manager.
Where it fits
Vitro is deliberately framework-agnostic. It does not assume a particular test runner, a particular device library, or a particular reservation system. Two companion projects layer on top when useful:
- A pytest bridge (
pytest-vitro) exposes the live device manager as fixtures so you can write tests against booted devices. - A shared template/operations pool (
vitro-commons) can sit between Vitro and your plugins, providing standardised contracts that multiple testbed plugins can conform to. This is the path for sharing tests across organisations.
Both are separate, optional packages — Vitro can be used without either.
Contributing
Contributions are welcome. Please open an issue describing the change you have in mind before sending a substantial pull request.
License
See LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file vitro-0.8.0-py3-none-any.whl.
File metadata
- Download URL: vitro-0.8.0-py3-none-any.whl
- Upload date:
- Size: 46.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bc577fd5cf030c228dbc8a8a91e625ac4bf5642121922d5a9bcc0be4aff21518
|
|
| MD5 |
a86f8a17a018d398ef52aa544db0a4ef
|
|
| BLAKE2b-256 |
723507abf76f95c54540a58afcc50861da9c2e90fc2447a5ffeff4ac8a1cd801
|
Provenance
The following attestation bundles were made for vitro-0.8.0-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on vitro-dev/vitro
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vitro-0.8.0-py3-none-any.whl -
Subject digest:
bc577fd5cf030c228dbc8a8a91e625ac4bf5642121922d5a9bcc0be4aff21518 - Sigstore transparency entry: 1549955377
- Sigstore integration time:
-
Permalink:
vitro-dev/vitro@b4739507cffce0dd1da95ae45dc96c828e21ca61 -
Branch / Tag:
refs/tags/0.8.0 - Owner: https://github.com/vitro-dev
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@b4739507cffce0dd1da95ae45dc96c828e21ca61 -
Trigger Event:
push
-
Statement type: