2015-04-27 14:39:44 -04:00
|
|
|
Heat style commandments
|
2012-03-14 09:25:54 +11:00
|
|
|
=======================
|
|
|
|
|
2015-04-27 14:39:44 -04:00
|
|
|
- Step 1: Read the OpenStack style commandments
|
2018-03-12 13:56:01 -04:00
|
|
|
https://docs.openstack.org/hacking/
|
2013-07-12 17:08:32 +01:00
|
|
|
- Step 2: Read on
|
2012-03-14 09:25:54 +11:00
|
|
|
|
2015-04-27 14:39:44 -04:00
|
|
|
Heat specific commandments
|
2013-07-12 17:08:32 +01:00
|
|
|
--------------------------
|
2012-03-14 09:25:54 +11:00
|
|
|
|
2013-07-12 17:08:32 +01:00
|
|
|
None so far
|
2012-03-14 09:25:54 +11:00
|
|
|
|
2015-04-27 14:39:44 -04:00
|
|
|
Creating unit tests
|
2012-03-14 09:25:54 +11:00
|
|
|
-------------------
|
|
|
|
For every new feature, unit tests should be created that both test and
|
2015-04-27 14:39:44 -04:00
|
|
|
(implicitly) document the usage of said features. If submitting a patch for a
|
2012-03-14 09:25:54 +11:00
|
|
|
bug that had no unit test, a new passing unit test should be added. If a
|
|
|
|
submitted bug fix does have a unit test, be sure to add a new one that fails
|
|
|
|
without the patch and passes with the patch.
|
2012-03-16 11:47:07 -04:00
|
|
|
|
2013-02-27 10:26:46 -07:00
|
|
|
For more information on creating unit tests and utilizing the testing
|
2014-06-22 02:00:59 -06:00
|
|
|
infrastructure in OpenStack Heat, please read heat/tests/testing-overview.txt.
|
2013-02-27 10:26:46 -07:00
|
|
|
|
|
|
|
|
2015-04-27 14:39:44 -04:00
|
|
|
Running tests
|
2013-02-27 10:26:46 -07:00
|
|
|
-------------
|
2018-06-13 07:48:10 +00:00
|
|
|
The testing system is based on a combination of tox and stestr. The canonical
|
|
|
|
approach to running tests is to simply run the command ``tox``. This will
|
2013-07-12 17:08:32 +01:00
|
|
|
create virtual environments, populate them with dependencies and run all of
|
2013-02-27 10:26:46 -07:00
|
|
|
the tests that OpenStack CI systems run. Behind the scenes, tox is running
|
2018-06-13 07:48:10 +00:00
|
|
|
``stestr run``, but is set up such that you can supply any additional
|
|
|
|
stestr arguments that are needed to tox. For example, you can run:
|
|
|
|
``tox -- --analyze-isolation`` to cause tox to tell stestr to add
|
|
|
|
``--analyze-isolation`` to its argument list.
|
2013-02-27 10:26:46 -07:00
|
|
|
|
|
|
|
It is also possible to run the tests inside of a virtual environment
|
|
|
|
you have created, or it is possible that you have all of the dependencies
|
2018-06-13 07:48:10 +00:00
|
|
|
installed locally already. In this case, you can interact with the ``stestr``
|
|
|
|
command directly. Running ``stestr run`` will run the entire test suite in
|
|
|
|
as many threads as you have CPU cores (this is the default incantation tox
|
|
|
|
uses), number of threads can be adjusted with ``--concurrency N`` argument.
|
|
|
|
``testr run --serial`` will run tests in serial process.
|
|
|
|
More information about stestr can be found at:
|
|
|
|
http://stestr.readthedocs.io
|
2013-02-27 10:26:46 -07:00
|
|
|
|
2017-02-04 09:46:51 +01:00
|
|
|
Note that unit tests use a database if available. See
|
|
|
|
``tools/test-setup.sh`` on how to set up the databases the same way as
|
|
|
|
done in the OpenStack CI systems.
|
2016-01-18 05:01:11 -08:00
|
|
|
|
|
|
|
Heat Specific Commandments
|
|
|
|
--------------------------
|
|
|
|
|
2024-01-17 01:12:45 +09:00
|
|
|
- [HE301] Use LOG.warning() rather than LOG.warn().
|
|
|
|
- [HE302] Python 3: do not use dict.iteritems.
|
|
|
|
- [HE303] Python 3: do not use dict.iterkeys.
|
|
|
|
- [HE304] Python 3: do not use dict.itervalues.
|
2016-01-18 05:01:11 -08:00
|
|
|
|