Skip to content

Latest commit

 

History

History
93 lines (62 loc) · 2.13 KB

README.md

File metadata and controls

93 lines (62 loc) · 2.13 KB

Smoker - Smoke testing the Foreman and friends

Smoker is a smoke testing tool aimed at verifying Foreman's functionality and testing for regressions. Testing plug-ins is also within scope, but it should be optional.

It's written in Python 3 and heavily relies on pytest. To ensure it doesn't rely on anything on the system under test the ideal deployment is on a separate machine.

Running tests

First install the dependencies:

pip install -r requirements.txt

To run, a base URL needs to be passed in:

pytest --base-url https://foreman.example.com

Variables

It is possible to specify the username, password and admin name via variables:

{
  "username": "admin",
  "password": "changeme",
  "name": "Admin User"
}

This can be passed in on the command line:

pytest --variables variables.json

Selenium

To specify the correct driver for Selenium, the --driver parameters is used.

pytest --driver Chrome

This will also need Chrome/Chromium along with the chromedriver. On Fedora:

dnf install chromedriver chromium

Note that Firefox isn't fully supported because it doesn't implement the webdriver logging. geckodriver isn't packaged either.

Markers

Every test can be annotated by pytest markers. They are commonly used to select tests.

To only run Selenium tests:

pytest -m selenium

They can also be used to skip Selenium tests:

pytest -m 'not selenium'

To see all markers:

pytest --markers

Client Tests

The client tests require the input set of containers to exist prior to running. All the required images can be built based on the version of Foreman being tested:

./build_images.sh <version>

The set of clients to test must also be specified in variables.json:

  "clients": [
    "smoker-test/centos8:nightly",
    "smoker-test/centos7:nightly",
    "smoker-test/centos6:nightly"
  ]