Deprecate run_tests.sh

We support tox for testing.
We don't maintain anything else.
In the Pike release we will remove the script.

Change-Id: Ic68858aaf1a519085dff394e6edc8c8fe6aeee6a
This commit is contained in:
Henry Gessau 2016-11-03 20:37:06 -04:00
parent 29669c04dd
commit e8e4e5d7ab
2 changed files with 10 additions and 79 deletions

View File

@ -412,57 +412,9 @@ reasonable to exclude their unit tests from the check.
Running Tests Running Tests
------------- -------------
There are three mechanisms for running tests: run_tests.sh, tox, Before submitting a patch for review you should always ensure all tests pass; a
and nose2. Before submitting a patch for review you should always tox run is triggered by the jenkins gate executed on gerrit for each patch
ensure all test pass; a tox run is triggered by the jenkins gate pushed for review.
executed on gerrit for each patch pushed for review.
With these mechanisms you can either run the tests in the standard
environment or create a virtual environment to run them in.
By default after running all of the tests, any pep8 errors
found in the tree will be reported.
With `run_tests.sh`
~~~~~~~~~~~~~~~~~~~
You can use the `run_tests.sh` script in the root source directory to execute
tests in a virtualenv::
./run_tests -V
With `nose2`
~~~~~~~~~~~~
You can use `nose2`_ to run individual tests, as well as use for debugging
portions of your code::
source .venv/bin/activate
pip install nose2
nose2
There are disadvantages to running nose2 - the tests are run sequentially, so
race condition bugs will not be triggered, and the full test suite will
take significantly longer than tox & testr. The upside is that testr has
some rough edges when it comes to diagnosing errors and failures, and there is
no easy way to set a breakpoint in the Neutron code, and enter an
interactive debugging session while using testr.
Note that nose2's predecessor, `nose`_, does not understand
`load_tests protocol`_ introduced in Python 2.7. This limitation will result in
errors being reported for modules that depend on load_tests
(usually due to use of `testscenarios`_). nose, therefore, is not supported,
while nose2 is.
.. _nose2: http://nose2.readthedocs.org/en/latest/index.html
.. _nose: https://nose.readthedocs.org/en/latest/index.html
.. _load_tests protocol: https://docs.python.org/2/library/unittest.html#load-tests-protocol
.. _testscenarios: https://pypi.python.org/pypi/testscenarios/
With `tox`
~~~~~~~~~~
Neutron, like other OpenStack projects, uses `tox`_ for managing the virtual Neutron, like other OpenStack projects, uses `tox`_ for managing the virtual
environments for running test cases. It uses `Testr`_ for managing the running environments for running test cases. It uses `Testr`_ for managing the running
@ -575,12 +527,6 @@ the dot-separated path you want as an argument to it.
For example, the following would run only a single test or test case:: For example, the following would run only a single test or test case::
$ ./run_tests.sh neutron.tests.unit.test_manager
$ ./run_tests.sh neutron.tests.unit.test_manager.NeutronManagerTestCase
$ ./run_tests.sh neutron.tests.unit.test_manager.NeutronManagerTestCase.test_service_plugin_is_loaded
or::
$ tox -e py27 neutron.tests.unit.test_manager $ tox -e py27 neutron.tests.unit.test_manager
$ tox -e py27 neutron.tests.unit.test_manager.NeutronManagerTestCase $ tox -e py27 neutron.tests.unit.test_manager.NeutronManagerTestCase
$ tox -e py27 neutron.tests.unit.test_manager.NeutronManagerTestCase.test_service_plugin_is_loaded $ tox -e py27 neutron.tests.unit.test_manager.NeutronManagerTestCase.test_service_plugin_is_loaded
@ -598,10 +544,6 @@ need better coverage.
To get a grasp of the areas where tests are needed, you can check To get a grasp of the areas where tests are needed, you can check
current unit tests coverage by running:: current unit tests coverage by running::
$ ./run_tests.sh -c
or by running::
$ tox -ecover $ tox -ecover
Since the coverage command can only show unit test coverage, a coverage Since the coverage command can only show unit test coverage, a coverage
@ -619,11 +561,7 @@ Debugging
--------- ---------
By default, calls to pdb.set_trace() will be ignored when tests By default, calls to pdb.set_trace() will be ignored when tests
are run. For pdb statements to work, invoke run_tests as follows:: are run. For pdb statements to work, invoke tox as follows::
$ ./run_tests.sh -d [test module path]
It's possible to debug tests in a tox environment::
$ tox -e venv -- python -m testtools.run [test module path] $ tox -e venv -- python -m testtools.run [test module path]
@ -649,19 +587,7 @@ overwritten during the next tox run.
Post-mortem Debugging Post-mortem Debugging
~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~
Setting OS_POST_MORTEM_DEBUGGER in the shell environment will ensure TBD: how to do this with tox.
that the debugger .post_mortem() method will be invoked on test failure::
$ OS_POST_MORTEM_DEBUGGER=pdb ./run_tests.sh -d [test module path]
Supported debuggers are pdb, and pudb. Pudb is full-screen, console-based
visual debugger for Python which let you inspect variables, the stack,
and breakpoints in a very visual way, keeping a high degree of compatibility
with pdb::
$ ./.venv/bin/pip install pudb
$ OS_POST_MORTEM_DEBUGGER=pudb ./run_tests.sh -d [test module path]
References References
~~~~~~~~~~ ~~~~~~~~~~

View File

@ -3,6 +3,7 @@
set -eu set -eu
function usage { function usage {
echo "NOTE: This script is deprecated."
echo "Usage: $0 [OPTION]..." echo "Usage: $0 [OPTION]..."
echo "Run Neutron's test suite(s)" echo "Run Neutron's test suite(s)"
echo "" echo ""
@ -94,6 +95,10 @@ LANGUAGE=en_US:en
LC_ALL=C LC_ALL=C
process_options $@ process_options $@
echo "NOTE: this script (run_tests.sh) is deprecated and will be removed in the Pike release."
echo ""
# Make our paths available to other scripts we call # Make our paths available to other scripts we call
export venv_path export venv_path
export venv_dir export venv_dir