In order to capture code coverage on your backend server, you need to run it using our Python test listener agent. Below you’ll find several options depending on your server type.
Table of Contents |
---|
Note |
---|
The below commands assume the token and session id are located in the working directory. If not, you can provide the file locations using the sl.tokenFile and sl.buildSessionIdFile environment variables |
uWSGI
When working with uWSGI, you need to run it with the following flags either in the command line or in the uwsgi configuration file: --enable-threads --single-interpreter --lazy-apps --import python_agent.init
If you need to pass the parameters via the CLI, the command line will be similar to this
Code Block |
---|
uwsgi ... --enable-threads --single-interpreter --import python_agent.init |
If using the uWSGI config file option, the content should look like the sample below
Code Block |
---|
[uwsgi]
...
enable-threads = true
single-interpreter = true
import = python_agent.init |
Gunicorn WSGI
When working with Gunicorn WSGI you need to run it with the following a configuration file which contains an import of the SeaLights Python agent in the post_fork section
Code Block |
---|
...
def post_fork(server, worker):
import python_agent.init
... |
Other servers (Generic solution)
For other servers, run with the SeaLights Python agent and the run flags
Code Block |
---|
sl-python run {--cov-report /path/to/report.xml --labid Lab1} <your server and args...> |
...