From e5a68327608d6a5e6c0709237517238e0de96c27 Mon Sep 17 00:00:00 2001 From: Todd Gamblin Date: Mon, 25 Jun 2018 09:35:28 -0700 Subject: [PATCH] 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 --- conftest.py | 52 ------------------- lib/spack/spack/cmd/test.py | 2 +- lib/spack/spack/test/conftest.py | 26 ++++++++++ pytest.ini => lib/spack/spack/test/pytest.ini | 2 +- 4 files changed, 28 insertions(+), 54 deletions(-) delete mode 100644 conftest.py rename pytest.ini => lib/spack/spack/test/pytest.ini (88%) diff --git a/conftest.py b/conftest.py deleted file mode 100644 index 6374a387c8..0000000000 --- a/conftest.py +++ /dev/null @@ -1,52 +0,0 @@ -############################################################################## -# Copyright (c) 2013-2018, Lawrence Livermore National Security, LLC. -# Produced at the Lawrence Livermore National Laboratory. -# -# This file is part of Spack. -# Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved. -# LLNL-CODE-647188 -# -# For details, see https://github.com/spack/spack -# Please also see the NOTICE and LICENSE files for our notice and the LGPL. -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU Lesser General Public License (as -# published by the Free Software Foundation) version 2.1, February 1999. -# -# This program is distributed in the hope that it will be useful, but -# WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY OF -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the terms and -# conditions of the GNU Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -############################################################################## - -import pytest - - -# 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) 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.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/pytest.ini b/lib/spack/spack/test/pytest.ini similarity index 88% rename from pytest.ini rename to lib/spack/spack/test/pytest.ini index e8f5e33c71..ccad5f86cc 100644 --- a/pytest.ini +++ b/lib/spack/spack/test/pytest.ini @@ -1,7 +1,7 @@ # content of pytest.ini [pytest] addopts = --durations=20 -ra -testpaths = lib/spack/spack/test +testpaths = . python_files = *.py markers = db: tests that require creating a DB