summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTodd Gamblin <tgamblin@llnl.gov>2018-06-25 09:35:28 -0700
committerTodd Gamblin <tgamblin@llnl.gov>2018-06-25 23:02:06 -0700
commite5a68327608d6a5e6c0709237517238e0de96c27 (patch)
tree1057d1c66afb5f091db3409a589284bc0ba863cc /lib
parent9a0af8a5ce7d5add2739443673e6a48667b30e8e (diff)
downloadspack-e5a68327608d6a5e6c0709237517238e0de96c27.tar.gz
spack-e5a68327608d6a5e6c0709237517238e0de96c27.tar.bz2
spack-e5a68327608d6a5e6c0709237517238e0de96c27.tar.xz
spack-e5a68327608d6a5e6c0709237517238e0de96c27.zip
refactor: move pytest.ini and top-level conftest.py to lib/spack/spack/test
- removes two files from root of repository - `spack test` still works fine to run tests
Diffstat (limited to 'lib')
-rw-r--r--lib/spack/spack/cmd/test.py2
-rw-r--r--lib/spack/spack/test/conftest.py26
-rw-r--r--lib/spack/spack/test/pytest.ini9
3 files changed, 36 insertions, 1 deletions
diff --git a/lib/spack/spack/cmd/test.py b/lib/spack/spack/cmd/test.py
index 9d4d9e6bc8..bc93981374 100644
--- a/lib/spack/spack/cmd/test.py
+++ b/lib/spack/spack/cmd/test.py
@@ -97,7 +97,7 @@ def test(parser, args, unknown_args):
return
# pytest.ini lives in the root of the spack repository.
- with working_dir(spack.paths.prefix):
+ with working_dir(spack.paths.test_path):
# --list and --long-list print the test output better.
if args.list or args.long_list:
do_list(args, unknown_args)
diff --git a/lib/spack/spack/test/conftest.py b/lib/spack/spack/test/conftest.py
index 71c4a95446..6649fa6a5e 100644
--- a/lib/spack/spack/test/conftest.py
+++ b/lib/spack/spack/test/conftest.py
@@ -53,6 +53,32 @@ from spack.spec import Spec
from spack.version import Version
+# Hooks to add command line options or set other custom behaviors.
+# They must be placed here to be found by pytest. See:
+#
+# https://docs.pytest.org/en/latest/writing_plugins.html
+#
+def pytest_addoption(parser):
+ group = parser.getgroup("Spack specific command line options")
+ group.addoption(
+ '--fast', action='store_true', default=False,
+ help='runs only "fast" unit tests, instead of the whole suite')
+
+
+def pytest_collection_modifyitems(config, items):
+ if not config.getoption('--fast'):
+ # --fast not given, run all the tests
+ return
+
+ slow_tests = ['db', 'network', 'maybeslow']
+ skip_as_slow = pytest.mark.skip(
+ reason='skipped slow test [--fast command line option given]'
+ )
+ for item in items:
+ if any(x in item.keywords for x in slow_tests):
+ item.add_marker(skip_as_slow)
+
+
#
# These fixtures are applied to all tests
#
diff --git a/lib/spack/spack/test/pytest.ini b/lib/spack/spack/test/pytest.ini
new file mode 100644
index 0000000000..ccad5f86cc
--- /dev/null
+++ b/lib/spack/spack/test/pytest.ini
@@ -0,0 +1,9 @@
+# content of pytest.ini
+[pytest]
+addopts = --durations=20 -ra
+testpaths = .
+python_files = *.py
+markers =
+ db: tests that require creating a DB
+ network: tests that require access to the network
+ maybeslow: tests that may be slow (e.g. access a lot the filesystem, etc.)