Tests automation utility for EPICS.
WeTest reads YAML files describing tests targeting EPICS PV, executes these tests in CLI with or without a GUI, and generates a report in PDF.
WeTest is implemented in Python 2.7, which therefore needs to be installed on your machine (support for Python 3.x is planned but not yet available).
Usually the Tkinter
module should be included in your python installation,
if it is not the case you will also need to install the corresponding package.
This module is needed for the graphical interface.
For example in Ubuntu:
sudo apt-get install python-tk
For example in CentOS:
sudo yum install tkinter
WeTest is currently successfully running on CentOS 7 and Ubuntu 18.04 (support for Windows is planned but not yet available).
To install virtualenv, if it's not already installed:
sudo pip install virtualenv
And to use virtualenv, first go in the clone repository:
cd WeTest
virtualenv venv # creates the virtual environment in the folder ./venv
source ./venv/bin/activate # activates the environment
To install WeTest go inside the cloned repository folder and type:
pip install .
You can use wetest
as a regular command line utility after that.
To deactivate the environment:
deactivate
To install conda if it's not already installed see: https://docs.conda.io/projects/conda/en/latest/user-guide/install/index.html
Once installed, create a python 2.7 environment for WeTest and activate it:
conda create -yn wetest python=2.7
conda activate wetest
To install WeTest go inside the cloned repository folder and type:
cd WeTest
python setup.py install
You can use wetest
as a regular command line utility after that.
To deactivate the environment:
conda deactivate
WeTest relies on the pyepics
module, and therefore depending on your EPICS installation
you might need to set up the PYEPICS_LIBCA
environment variable manually.
For instance:
export PYEPICS_LIBCA=/opt/epics/bases/base-3.14.12.5/lib/centos7-x86_64/libca.so
You can find full explanation here.
To run Wetest with a scenario file, use either:
wetest <scenario.yaml>
wetest -s <scenario.yaml>
wetest --scenario <scenario.yaml>
Multiple scenarios files can be provided at once in the CLI.
Or you may use the include
block within a scenario file.
You can run WeTest without a scenario file if you provide an EPICS DB directory or files. In this case no test will be executed and only the PV connection status will be monitored.
wetest -d <epics_db_folder>
wetest --db <epics_db_folder> --naming ESS
By default only the PVs found in the tests are monitored. Using the --db
option will add the new PVs to the PV list extracted from the tests.
The --naming
or -n
option enable to check the conformity of the PV name to
the naming convention, and to sort the PVs by sections and subsections.
At the end of the tests execution a PDF report is generated in the current
directory under the name wetest-results.pdf
. You can change this name using
the --pdf-output
option.
wetest <scenario.yaml> -o <another_name.pdf>
wetest <scenario.yaml> --pdf-output <another_location/another_name.pdf>
More CLI options are available, but are not documented here.
Have a look in the doc
directory.
Check the help option to have exhaustive list:
wetest -h
Scenario files are read as YAML files.
As of today the only documentation about the content of scenario files are:
- the powerpoint presentation in the
doc
folder - the YAML schema validation file also in the
doc
folder
A user manual is planned but not yet available.
One may also find interesting example in the test
directory.
Pre-made scenarios are also available in the generic
folder.
These files are meant to be included in another scenario with macros to
activate and customize tests.
Following is yet another summary.
Content expected in a scenario file:
version
: enable to check the compatibility of the file against the installed version of WeTestconfig
: to define a scenario name, PV prefix, default values and whether the tests should be shuffled (unit) or executed in the order defined (functional)tests
: is a list of test, see below for the expected content of a testmacros
: macros can be defined here and will be substituted throughout the fileinclude
: is a list of scenario to execute, macros can be provided to each included scenario, tests are executed last by default, but this can be changed by adding test somewhere in the include list.name
: a name for the suite (report and GUI title), only the topmost file suitename will be used, included files suitename will be ignored. This parameter is also ignored when providing multiple files in the command line.
If a tests
block is defined then a config
block is expected too,
and conversely.
Content expected in a test:
-
name
: test title, displayed CLI in GUI and report -
prefix
: string appended after the config prefix and before the PV name -
use_prefix
: whether or not to use append prefix from config -
delay
: wait time between setting and getting the PVs -
message
: free length description for the test, displayed in GUI and report -
setter
: name of the PV where to write a value -
getter
: name of the PV from where to read a value -
margin
: allows to set a percentage tolerance when checking the value -
delta
: allows to set a constant tolerance when checking the value -
finally
: put back to a known configuration -
ignore
: whether the test should be read or not -
skip
: whether the test should be executed or not -
on_failure
: determines whether to continue, pause or abort if the test fails -
retry
: number of time to try again the test if it failed -
range
: generate a list of values to test, subfields are:start
: starting valuestop
: end valuestep
: space between values from start to stoplin
: number of values linearly spaced between start and stopgeom
: number of values geometrically spaced between start and stopinclude_start
: whether or not to test the start valueinclude_stop
: whether or not to test the stop valuesort
: whether the values should shuffled or ordered
-
values
: custom list of value to test -
commands
: a list of highly customizable tests, available subfields are:name
: command title, displayed CLI in GUI and reportmessage
: free length description for the command, displayed in GUI and reportmargin
: allows to set a percentage tolerance when checking the valuedelta
: allows to set a constant tolerance when checking the valuesetter
: overrides the test setter PV namegetter
: overrides the test getter PV nameget_value
: value expected in the getter PVset_value
: value to put in the setter PVvalue
: same value for setter and getter PVdelay
: overrides the test delayignore
: ignore this command even if test is not ignoredskip
: whether the command should be executed or noton_failure
: continue, pause or abort if the command fails
A test should have one an only one of the three "test kind":
range
, values
or commands
This section is under works.
Aside from a proper user manual, proper non-regression tests are today lacking. Therefore push requests may take some time to be accepted.
Bug notices are welcome and we hope to be able to fix them rapidly.
New feature requests are also welcome but will most probably not be implemented before a will (many other things to fix first).