This document decribes the parameters that may be present for configuring a
tests set. It has a YAML format and should be defined in
TESTS_SET/config.yml
file. It is optional, and if it missing, default values
are considered.
A tests set can have one of the following settings:
bridge_networks
: a list of bridge network descriptors that the scenarios within this tests set might use; check below more information about Networks.network
: describes the network device used for this scenario; available values are described in Networks; this value is optional, and if missing,host
is considered the default.networks
: additional networks that are automatically assigned to all tasks within this tests set. If missing, no aditional networks are being assigned.defaults
: consists of a dictionary that specify a set of default settings for the tasks that are being initiated within this tests set; more about this in Defaults section.init_tasks
: a list of tasks as described in Tasks that should be run before running any scenario within this tests set; this value is optional, and if it is missing, no initial tasks are executedcleanup_tasks
: a list of tasks as described in Tasks that should be run after all the scenarios within the tests set are executed; optional, and if missing no cleanup task is run
Currently supporting networking modes are host
and bridge
. The host
mode
does not require any explicit configuration, therefore it must not be specified
within the networks
node of the tests set. However, a bridge
needs to be
explictely specified in order to be created and configured properly.
Each bridged network should consist of the following settings:
name
: the name of the bridge, mandatorysubnet
: the subnet that should be used, mandatory (example:192.168.52.0/24
)gateway
: the gateway that should be used, mandatory (example:192.168.52.1
)device
: the name of the device, optional, and if missing thename
of the bridge is assumed
An example of a bridge that uses the 192.168.52.0/24
network is:
- name: osbr
subnet: 192.168.52.0/24
gateway: 192.168.52.1
device: osbr0
The purpose of defaults is to minimize the length of scenarios by unifying
common settings under the defaults
node of the test set. Defaults can be used
to specify default settings for a specific task type. For example, for all the
scenarios within a specific tests set, you may always want to start the
OpenSIPS tasks with the same IP and port. This is where defaults become handy.
They are organized as a dictionary, where each key is the name of the task type, that points to a new dictionary containing the default settings for that specific task type. So the format is similar to:
defaults:
type1:
key1: value1
key2: value2
type2:
key1: value1
key2: value2
Check out Example of defining default IP and port for all OpenSIPS tasks.
Extra variables can be passed from command line, and then can be used as essential
template variables either in config.yml
or define.yml
or even directly in scenario.yml
.
It can be useful, for example, when you want to pass secrets from your github workflow,
retrieved from vault storage, github environment secrets, etc, as Task env variable.
defaults:
opensips:
ip: 192.168.52.52
port: 5060
args:
- -p
- envsubst
env:
DB_HOST: {{ db_host }}
DB_PASSWORD: {{ db_password }}
sipssert -E db_host=${{ secrets.MYSQL_DB_HOST }} \
-E db_password=${{ secrets.MYSQL_DB_PASSWORD }}
You can pass such a way some dynamic variables from your workflow, which values can depend on environment.
An example of a tests set that defines the osbr0 network and uses it by default, as well as setting OpenSIPS IP within that network can be described below:
bridge_networks:
- name: osbr0
subnet: 192.168.52.0/24
gateway: 192.168.52.1
network: osbr0
defaults:
opensips:
ip: 192.168.52.52
port: 5060
All the subsequent instances of opensips
within this tests set will have
OpenSIPS listening on ip 192.168.52.52
port 5060.