Replace mention of nose with nose2 in devref

Documentation for the nose test runner was previously included in the
testing section of the developer reference.  Due to nose's lack of
support for the load_tests protocol - required to support
testscenarios-based generative testing - the documentation has been
updated to suggest the load_tests-supporting nose2 instead.

Change-Id: I5beb8619d5045372472021ed7eb19bddd0de5862
This commit is contained in:
Maru Newby 2015-01-06 00:42:52 +00:00
parent 706deaeaed
commit 930b4e3d7b

View File

@ -43,7 +43,7 @@ Running unit tests
------------------ ------------------
There are three mechanisms for running tests: run_tests.sh, tox, There are three mechanisms for running tests: run_tests.sh, tox,
and nose. Before submitting a patch for review you should always and nose2. Before submitting a patch for review you should always
ensure all test pass; a tox run is triggered by the jenkins gate ensure all test pass; a tox run is triggered by the jenkins gate
executed on gerrit for each patch pushed for review. executed on gerrit for each patch pushed for review.
@ -63,24 +63,38 @@ tests in a virtualenv::
./run_tests -V ./run_tests -V
With `nose` With `nose2`
~~~~~~~~~~~ ~~~~~~~~~~~
You can use `nose`_ to run individual tests, as well as use for debugging You can use `nose2`_ to run individual tests, as well as use for debugging
portions of your code:: portions of your code::
source .venv/bin/activate source .venv/bin/activate
pip install nose pip install nose2
nosetests nose2
There are disadvantages to running Nose - the tests are run sequentially, so 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 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 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 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 no easy way to set a breakpoint in the Neutron code, and enter an
interactive debugging session while using testr. interactive debugging session while using testr.
It is also possible to use nose2's predecessor, `nose`_, to run the tests::
source .venv/bin/activate
pip install nose
nosetests
nose has one additional disadvantage over nose2 - it does not
understand the `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`_).
.. _nose2: http://nose2.readthedocs.org/en/latest/index.html
.. _nose: https://nose.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` With `tox`
~~~~~~~~~~ ~~~~~~~~~~