File: hacking.rst

package info (click to toggle)
python-neutron-lib 3.21.1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 7,660 kB
  • sloc: python: 22,829; sh: 137; makefile: 24
file content (101 lines) | stat: -rw-r--r-- 3,794 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
==============
Hacking Checks
==============

The ``neutron_lib.hacking`` package implements a number of public
`flake8 checks <https://github.com/pycqa/flake8>`__ intended to help
adopters validate their compliance with the latest hacking standards.

To adopt neutron-lib's hacking checks:

#. Update your project's ``tox.ini`` to include hacking checks from
   neutron-lib. More specifically, copy hacking checks under
   "Checks for neutron and related projects" in
   ``[flake8.local-plugin] extension`` in neutron-lib ``tox.ini``
   to ``[flake8.local-plugin] extension`` in your project's ``tox.ini``.

   For example in your ``tox.ini``::

     [flake8:local-plugins]
     extension =
       # Checks from neutron-lib
       N521 = neutron_lib.hacking.checks:use_jsonutils
       N524 = neutron_lib.hacking.checks:check_no_contextlib_nested
       N529 = neutron_lib.hacking.checks:no_mutable_default_args
       N530 = neutron_lib.hacking.checks:check_neutron_namespace_imports
       N532 = neutron_lib.hacking.translation_checks:check_log_warn_deprecated
       N534 = neutron_lib.hacking.translation_checks:check_raised_localized_exceptions
       N536 = neutron_lib.hacking.checks:assert_equal_none
       N537 = neutron_lib.hacking.translation_checks:no_translate_logs

   Under certain circumstances, adopters may need to ignore specific
   neutron-lib hacking checks temporarily. You can ignore such checks
   just by commenting out them (hopefully with a proper reason).

   If your project has its own hacking checks, you can add more rules
   to ``[flake8.local-plugin] extension`` along with hacking checks
   from neutron-lib.

   .. note::

      The above configuration assumes hacking 2.x.
      If your project uses hacking 1.x, see :ref:`hacking1_support` below.

#. Update your project's ``tox.ini`` enable any flake8 extensions neutron-lib's
   ``tox.ini`` does. These are hacking checks otherwise disabled by default
   that neutron-lib expects to run.

   For example in neutron-lib's ``tox.ini``::

    [flake8]
    # H904: Delay string interpolations at logging calls
    enable-extensions=H904

   In the example above, adopters should also add ``H904`` to the
   ``enable-extensions`` in their ``tox.ini``.

#. Actively adopt neutron-lib hacking checks by running and monitoring
   the neutron-lib `periodic job <http://grafana.openstack.org/dashboard/
   db/neutron-lib-failure-rate?panelId=4&fullscreen>`_ (as per `stadium guidelines
   <https://review.opendev.org/389397/>`_ and
   watching for announcements. Announcements regarding neutron-lib adopter
   hacking checks will be communicated via openstack-discuss email list
   and `neutron meetings <https://wiki.openstack.org/wiki/Network/Meetings>`_.

.. _hacking1_support:

Hacking 1.x support
-------------------

If your project uses hacking 1.x, you need a different way to consume hacking
checks from neutron-lib.

.. warning::

   hacking 1.x support is deprecated and will be dropped once all neutron
   related projects migrate to hacking 2.x.

Update your project's ``tox.ini`` to use
``neutron_lib.hacking.checks.factory`` for its ``local-check-factory``.

For example in your ``tox.ini``::

    [hacking]
    local-check-factory = neutron_lib.hacking.checks.factory

If your project needs to register additional project specific hacking
checks, you can define your own factory function that calls neutron-lib's
``factory`` function.

For example in your project's python source::

    def my_factory(register):
        # register neutron-lib checks
        neutron_lib_checks.factory(register)
        # register project specific checks
        register(my_project_check)

And use your project's own factory in ``tox.ini``::

    [hacking]
    local-check-factory = myproject.mypkg.my_factory