testfm

TestFM is a test suite which exercises foreman-maintain tool.


Keywords
foreman-maintain, pytest-ansible, python
License
GPL-3.0
Install
pip install testfm==0.1.4

Documentation

TestFM

https://api.travis-ci.org/SatelliteQE/testfm.svg?branch=master https://requires.io/github/SatelliteQE/testfm/requirements.svg?branch=master

TestFM is a test suite based on pytest-ansible that exercises The Foreman maintenance tool

Quickstart

The following is only a brief setup guide for TestFM. The section on Running the Tests provides a more comprehensive guide to using TestFM.

TestFM requires SSH access to the server system under test, and this SSH access is implemented by pytest-ansible.

Get the source code and install dependencies:

git clone https://github.com/SatelliteQE/testfm.git
pip3 install -r requirements.txt

That’s it! You can now go ahead and start testing The Foreman Maintain. However, there are a few other things you need to do before continuing:

  • Make sure ssh-key is copied to the test system.
  • Make sure foreman maintain is installed on foreman/satellite server.

Running the Tests

Before running any tests, you must add foreman or satellite hostname to the testfm/inventory file (first copy it from`testfm/inventory.sample`).

That done, you can run tests using pytest

pytest --ansible-host-pattern satellite --ansible-user=root  --ansible-inventory testfm/inventory
tests/

It is possible to run a specific subset of tests:

pytest --ansible-host-pattern satellite --ansible-user=root --ansible-inventory testfm/inventory
tests/test_case.py

pytest --ansible-host-pattern satellite --ansible-user=root  --ansible-inventory testfm/inventory
tests/test_case.py::test_case_name

Want to contribute?

Thank you for considering contributing to TestFM! If you have any question or concerns, feel free to reach out to the team.

Recommended

  • Import modules in alphabetical order.
  • Every method and function will have a properly formatted docstring.

In order to ensure you are able to pass the Travis CI build, it is recommended that you run the following commands in the base of your testfm directory

flake8

flake8 will ensure that the changes you made are not in violation of PEP8 standards. If the command gives no output, then you have passed. If not, then address any corrections recommended.

If you have something great, please submit a pull request anyway! The full documentation is available on ReadTheDocs.

Licensing

TestFM is licensed under GNU General Public License v3.0.