libvirt Molecule Plugin :: run molecule tests on libvirt
Project description
Molecule libvirt-ng is a Molecule driver for provisioning test VMs via libvirt/QEMU/KVM.
This is a modernized fork of the archived molecule-libvirt plugin, updated for current versions of Molecule and Ansible.
Requirements
Python >= 3.10
Molecule >= 24.2.0
Ansible >= 2.16
A working libvirt/QEMU/KVM setup on the host
libvirt-python (system package or built from source with pkg-config and libvirt headers)
virt-resize from guestfs-tools (for disk resizing)
Required Ansible collections (installed automatically via test_requirements.yml):
community.libvirt
community.crypto
community.general
ansible.posix
ansible.utils
Quickstart
Installation
pip install molecule-libvirt-ng
You also need libvirt-python which requires system libvirt headers:
# Debian/Ubuntu
sudo apt install libvirt-dev pkg-config python3-dev
# RHEL/Fedora
sudo dnf install libvirt-devel pkg-config python3-devel
pip install libvirt-python
Install the required Ansible collections:
ansible-galaxy collection install -r test_requirements.yml
Example
Create a molecule/default/molecule.yml in your Ansible role:
---
driver:
name: libvirt
platforms:
- name: debian12-test
image_url: "https://cloud.debian.org/images/cloud/bookworm/latest/debian-12-genericcloud-amd64.qcow2"
memory_size: 2
vcpu: 2
disk_size: "10G"
qemu_user: "qemu"
provisioner:
name: ansible
verifier:
name: ansible
Then run:
molecule test
Platform Parameters
Required
- image_url
URL to a cloud image (qcow2 format). Defaults to Debian 12 genericcloud.
Optional
- memory_size
RAM in GB. Default: 1.
- vcpu
Number of virtual CPUs. Default: 1.
- disk_size
Disk size (qemu-img format). Default: 15G.
- ssh_port
SSH port on the guest. Default: 22.
- cpu_model
CPU model requested by the guest. Default: qemu64.
- arch
CPU architecture. Default: x86_64.
- timezone
VM timezone. Default: America/Toronto.
- qemu_user
QEMU process user for filesystem ACLs. Varies by distro:
RHEL/Fedora: qemu (default)
Debian/Ubuntu: libvirt-qemu
NixOS: root
- image_volume
Partition to expand with virt-resize. Default: /dev/sda1.
- network_name
Use an existing libvirt network instead of creating a molecule-managed one.
- bridge_name
Use an existing bridge on a remote host. Makes the VM reachable via ARP.
- libvirt_host and libvirt_user
Provision VMs on a remote libvirt host via qemu+ssh://.
Network Parameters
These apply when molecule manages its own network (no network_name or bridge_name):
- molecule_bridge
Bridge interface name. Default: molecule-br0.
- molecule_network_cidr
IP range for the molecule network. Default: 10.10.10.0/24.
Documentation
Read the Molecule documentation at https://molecule.readthedocs.io/.
License
The MIT License.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
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 molecule_libvirt_ng-1.0.2.tar.gz.
File metadata
- Download URL: molecule_libvirt_ng-1.0.2.tar.gz
- Upload date:
- Size: 20.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a8bd8c0ac8a4b3e7240650957ded196cf0da033d6537855834da243f219f34d1
|
|
| MD5 |
cd34a11914efe7c30ea561cc2da47fe3
|
|
| BLAKE2b-256 |
c31d822d8fc1d7484bd319381bed442c595e31c56d649994362c32c939289830
|
File details
Details for the file molecule_libvirt_ng-1.0.2-py3-none-any.whl.
File metadata
- Download URL: molecule_libvirt_ng-1.0.2-py3-none-any.whl
- Upload date:
- Size: 21.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
59e14b0c47825edc812b5e35a7d874c69bca09afb5b6e9f7b99de571cddd00cc
|
|
| MD5 |
5f2ee0e58032f6750db174fc42f260f8
|
|
| BLAKE2b-256 |
dcd21b88e034911c034237e039979f1e962c11df4369c35c7223ee9b4aebcb30
|