From 9dfdd20541cbe3e862428eacea6c4d552ea4120c Mon Sep 17 00:00:00 2001 From: Renat Akhmerov Date: Thu, 23 Jan 2020 17:14:02 +0700 Subject: [PATCH] Move the article about testing from Wiki to the built-in docs * Significant part of the original article is outdated (https://wiki.openstack.org/wiki/Mistral/Testing) so only the actual parts were moved. Partial-Bug: #1779318 Change-Id: Ia5a43db418282041c6e169e301528ef1a35777af --- doc/source/developer/contributor/debug.rst | 65 -------- .../contributor/debugging_and_testing.rst | 144 ++++++++++++++++++ doc/source/developer/contributor/index.rst | 2 +- 3 files changed, 145 insertions(+), 66 deletions(-) delete mode 100644 doc/source/developer/contributor/debug.rst create mode 100644 doc/source/developer/contributor/debugging_and_testing.rst diff --git a/doc/source/developer/contributor/debug.rst b/doc/source/developer/contributor/debug.rst deleted file mode 100644 index ea5416fcf..000000000 --- a/doc/source/developer/contributor/debug.rst +++ /dev/null @@ -1,65 +0,0 @@ -Mistral Debugging Guide -======================= - -To debug using a local engine and executor without dependencies such as -RabbitMQ, make sure your ``/etc/mistral/mistral.conf`` has the following -settings:: - - [DEFAULT] - rpc_backend = fake - - [pecan] - auth_enable = False - -and run the following command in *pdb*, *PyDev* or *PyCharm*:: - - mistral/cmd/launch.py --server all --config-file /etc/mistral/mistral.conf --use-debugger - -.. note:: - - In PyCharm, you also need to enable the Gevent compatibility flag in - Settings -> Build, Execution, Deployment -> Python Debugger -> Gevent - compatible. Without this setting, PyCharm will not show variable values - and become unstable during debugging. - - -Running unit tests in PyCharm ------------------------------ - -In order to be able to conveniently run unit tests, you need to: - -1. Set unit tests as the default runner: - - Settings -> Tools -> Python Integrated Tools -> - Default test runner: Unittests - -2. Enable test detection for all classes: - - Run/Debug Configurations -> Defaults -> Python tests -> Unittests -> uncheck - Inspect only subclasses of unittest.TestCase - -Running examples ----------------- - -To run the examples find them in mistral-extra repository -(https://github.com/openstack/mistral-extra) and follow the instructions on -each example. - - -Tests ------ - -You can run some of the functional tests in non-openstack mode locally. To do -this: - -#. set ``auth_enable = False`` in the ``mistral.conf`` and restart Mistral -#. execute:: - - $ ./run_functional_tests.sh - -To run tests for only one version need to specify it:: - - $ bash run_functional_tests.sh v1 - -More information about automated tests for Mistral can be found on -`Mistral Wiki `_. diff --git a/doc/source/developer/contributor/debugging_and_testing.rst b/doc/source/developer/contributor/debugging_and_testing.rst new file mode 100644 index 000000000..a7b991c7c --- /dev/null +++ b/doc/source/developer/contributor/debugging_and_testing.rst @@ -0,0 +1,144 @@ +===================== +Debugging and Testing +===================== + +To debug using a local engine and executor without dependencies such as +RabbitMQ, make sure your ``/etc/mistral/mistral.conf`` has the following +settings:: + + [DEFAULT] + rpc_backend = fake + + [pecan] + auth_enable = False + +and run the following command in *pdb*, *PyDev* or *PyCharm*:: + + mistral/cmd/launch.py --server all --config-file /etc/mistral/mistral.conf --use-debugger + +.. note:: + + In PyCharm, you also need to enable the Gevent compatibility flag in + Settings -> Build, Execution, Deployment -> Python Debugger -> Gevent + compatible. Without this setting, PyCharm will not show variable values + and become unstable during debugging. + +Running unit tests in PyCharm +============================= + +In order to be able to conveniently run unit tests, you need to: + +1. Set unit tests as the default runner: + + Settings -> Tools -> Python Integrated Tools -> + Default test runner: Unittests + +2. Enable test detection for all classes: + + Run/Debug Configurations -> Defaults -> Python tests -> Unittests -> uncheck + Inspect only subclasses of unittest.TestCase + +Running examples +================ + +To run the examples find them in mistral-extra repository +(https://github.com/openstack/mistral-extra) and follow the instructions on +each example. + + +Automated Tests +=============== + +On Mistral project we have two separate test suites: + +* Unit tests - executed by Jenkins CI job in OpenStack gerrit (python-style + checks and execution of all unit tests) +* Integration tests - executed by Devstack Gate job in OpenStack Gerrit + (integration tests for Mistral after the OpenStack deployment with devstack) + +Where we can find automated tests +================================= + +mistral: + +* Unit tests can be found at + https://github.com/openstack/mistral/tree/master/mistral/tests/unit +* Integration tests can be found at + https://github.com/openstack/mistral-tempest-plugin/tree/master/mistral_tempest_tests/tests + +python-mistralclient: + +* Unit tests can be found at + https://github.com/openstack/python-mistralclient/tree/master/mistralclient/tests/unit +* Integration tests can be found at + https://github.com/openstack/python-mistralclient/tree/master/mistralclient/tests/functional + +How to execute tests manually +============================= + +Almost all existing automated tests can be executed manually on the +developer's desktop (except those which check OpenStack actions). +To do this, you should clone "mistral" repository (or "python-mistralclient") +and run the corresponding commands. + +Cloning a repository: + +.. code-block:: bash + + $ git clone https://git.opendev.org/openstack/mistral.git + $ cd mistral + +Unit tests +---------- + +To run all unit tests: + +.. code-block:: bash + + $ tox + +To run unit tests against a specific python version: + +.. code-block:: bash + + $ tox -e py35 + +To run tests from a specific test class (using a specific python version): + +.. code-block:: bash + + tox -e py35 -- 'DataFlowEngineTest' + +Integration tests +----------------- + +There are several suites of integration tests the mentioned repositories: + +mistral-tempest-plugin: + +* mistral_tempest_tests/tests/api/v2/test_workflows.py - contains the tests + checking Mistral API v2 related to workflows +* mistral_tempest_tests/tests/api/v2/test_actions.py - contains the tests + checking Mistral API v2 related to actions +* and so on + +python-mistralclient: + +* mistralclient/tests/functional/cli/v2/ - contains test suites which check + interaction with Mistral using CLI + +To run integration tests: + +* in OpenStack mode (when auth in Mistral is enabled and Mistral integrates + with OpenStack components) + +.. code-block:: bash + + $ pip install git+http://git.opendev.org/openstack/tempest.git + $ nosetests mistral-tempest-plugin/mistral_tempest_tests/tests/api/v2 + +* in Non-OpenStack mode: + + * set 'auth_enable=false' in the mistral.conf under [pecan] group + * restart Mistral server + * execute: ./run_functional_tests diff --git a/doc/source/developer/contributor/index.rst b/doc/source/developer/contributor/index.rst index 00a3a286e..828f96962 100644 --- a/doc/source/developer/contributor/index.rst +++ b/doc/source/developer/contributor/index.rst @@ -6,6 +6,6 @@ Contributor Documentation :maxdepth: 3 coding_guidelines - debug + debugging_and_testing troubleshooting devstack