libvirt

Travis CI Build Status Semantic Release

Formula to setup and configure libvirt.

1. General notes

If you are interested in writing or contributing to formulas, please pay attention to the Writing Formula Section.

If you want to use this formula, please pay attention to the FORMULA file and/or git tag, which contains the currently released version. This formula is versioned according to Semantic Versioning.

See Formula Versioning Section for more details.

More information SALT AS A CLOUD CONTROLLER.

2. Contributing to this repo

Commit message formatting is significant!!

Please see How to contribute for more details.

3. Available states

3.1. libvirt

Meta-state (This is a state that includes other states).

Install libvirt, qemu and extra packages; configure and start the libvirtd service, and creates the certificates for migration.

3.2. libvirt.clean

Meta-state (This is a state that includes other states).

Clean the extra and qemu packages, the server and the python package.

3.3. libvirt.server

Meta-state (This is a state that includes other states).

Install libvirt packages; configure and start the libvirtd service, and creates the certificates for migration.

3.4. libvirt.server.clean

Meta-state (This is a state that includes other states).

Clean the service, the configuration files and the packages. Any generated certificates is not handled.

3.5. libvirt.server.package

This state install the libvirt package only.

3.6. libvirt.server.package.clean

This state remove the libvirt package only and depends on libvirt.server.config.clean.

3.7. libvirt.server.config

Configures libvirtd.conf and /etc/sysconfig, /etc/default, /etc/conf.d daemon files.

3.8. libvirt.server.config.clean

Delete libvirtd.conf and /etc/sysconfig, /etc/default, /etc/conf.d daemon files and depends on libvirt.server.service.clean.

3.9. libvirt.server.service

Starts the libvirtd service

3.10. libvirt.server.service.clean

Disable and stop the libvirtd service.

3.11. libvirt.server.tls

Installs the libvirt certificates to allow virtual machine migration.

3.12. libvirt.qemu

This state install the qemu package only.

3.13. libvirt.qemu.clean

This state remove the qemu package only.

3.14. libvirt.extra

This state install the extra packages only.

3.15. libvirt.extra.clean

This state remove the extra packages only.

3.16. libvirt.python

Installs the python bindings for libvirt

3.17. libvirt.python.clean

This state remove the python bindings package for libvirt only.

4. Testing

Linux testing is done with kitchen-salt.

4.1. Requirements

  • Ruby

  • Docker

$ gem install bundler
$ bundle install
$ bin/kitchen test [platform]

Where [platform] is the platform name defined in kitchen.yml, e.g. debian-9-2019-2-py3.

4.2. bin/kitchen converge

Creates the docker instance and runs the libvirt main state, ready for testing.

4.3. bin/kitchen verify

Runs the inspec tests on the actual instance.

4.4. bin/kitchen destroy

Removes the docker instance.

4.5. bin/kitchen test

Runs all of the stages above in one go: i.e. destroy + converge
verify + destroy.

4.6. bin/kitchen login

Gives you SSH access to the instance for manual testing.