summaryrefslogtreecommitdiff
path: root/testing/tox.ini
diff options
context:
space:
mode:
authordrebs <drebs@riseup.net>2017-09-09 09:26:14 -0300
committerVictor Shyba <victor1984@riseup.net>2017-09-11 16:24:30 -0300
commit8e6cddf794c4b0e44bec6daa4363f2926e238f0a (patch)
treeab34cfd50823764e9e38a6a45be99faffef82ddb /testing/tox.ini
parentf6a409a711df032507cbe3dd1f1129c1b7e19c95 (diff)
[test] add --subdir option and blacklist
Use subdir path to select/deselect benchmark tests. Because of the way pytest and pytest benchamrk select/deselect tests, it makes more sense for this test suite to use a --subdir option to select only a subset of tests and a blacklist of subdirectories that should not be run unless explicitelly asked to. This commit adds a --subdir option, that will deselect all tests no in ./tests/<subdir> when the option is passed to pytest. Also, a blacklist is added so, unless explicitelly added as a --subdir, tests in blacklisted subdirectories will not be run. The reasons for this modification are: - pytest-benchmarks selects/deselects tests based on the type of their fixtures. This means that fixtures have to be instantiated previous to test selection/deselection, something that may cause side effects that we want to avoid. - the usual test suite is run for all benchmarks, while some tests should only be run in specific situations (as is the case of benchmarks and responsiveness tests). It is saner to implement subdir selection than marking all tests with pytest marks and using them to select/deselect.
Diffstat (limited to 'testing/tox.ini')
-rw-r--r--testing/tox.ini49
1 files changed, 29 insertions, 20 deletions
diff --git a/testing/tox.ini b/testing/tox.ini
index 6bc82b8e..a8186f70 100644
--- a/testing/tox.ini
+++ b/testing/tox.ini
@@ -6,11 +6,11 @@ skipsdist=True
basepython = python2.7
commands =
./ensure-pysqlcipher-has-usleep.sh
- py.test -x --ignore=tests/benchmarks --ignore=tests/responsiveness \
- --cov-report=html \
- --cov-report=term \
- --cov=leap.soledad \
- {posargs}
+ py.test -x \
+ --cov-report=html \
+ --cov-report=term \
+ --cov=leap.soledad \
+ {posargs}
usedevelop = True
deps =
coverage
@@ -25,6 +25,12 @@ deps =
requests
service_identity
leap.common
+# used by benchmarks
+ psutil
+ numpy
+ pytest-benchmark
+ elasticsearch
+ certifi
# install soledad from current tree
-e../
-e../[client]
@@ -37,11 +43,12 @@ install_command = pip install {opts} {packages}
[testenv:py34]
basepython = python3.4
-commands = py.test --ignore=tests/benchmarks --ignore=tests/responsiveness \
- --cov-report=html \
- --cov-report=term \
- --cov=leap.soledad \
- {posargs}
+commands =
+ py.test \
+ --cov-report=html \
+ --cov-report=term \
+ --cov=leap.soledad \
+ {posargs}
usedevelop = True
deps =
coverage
@@ -54,6 +61,12 @@ deps =
couchdb
requests
service_identity
+# used by benchmarks
+ psutil
+ numpy
+ pytest-benchmark
+ elasticsearch
+ certifi
# install soledad local packages
-e../
-e../[client]
@@ -66,18 +79,13 @@ install_command = pip3 install {opts} {packages}
[testenv:benchmark]
deps =
{[testenv]deps}
- psutil
- numpy
- pytest-benchmark
- elasticsearch
- certifi
commands =
# we must make sure that installed pysqlcipher was built with the HAVE_USLEEP
# flag, or we might have problems with concurrent db access.
./ensure-pysqlcipher-has-usleep.sh
# run benchmarks twice: once for time and cpu and a second time for memory
- py.test --benchmark-only {posargs}
- py.test --benchmark-only --watch-memory {posargs}
+ py.test --subdir=benchmarks {posargs}
+ py.test --subdir=benchmarks --watch-memory {posargs}
passenv = HOST_HOSTNAME
[testenv:responsiveness]
@@ -85,7 +93,7 @@ deps =
{[testenv:benchmark]deps}
commands =
./ensure-pysqlcipher-has-usleep.sh
- pytest -m responsiveness {posargs}
+ py.test --subdir=responsiveness {posargs}
[testenv:code-check]
changedir = ..
@@ -101,5 +109,6 @@ deps =
{[testenv]deps}
pytest-xdist
install_command = pip install {opts} {packages}
-commands = ./ensure-pysqlcipher-has-usleep.sh
- py.test --ignore=tests/benchmarks {posargs} -n 4
+commands =
+ ./ensure-pysqlcipher-has-usleep.sh
+ py.test {posargs} -n 4