glance/doc/source/contributor/minor-code-changes.rst
Brian Rosmaita cf2b3f25aa Update "Disallowed minor code changes" doc
Update contributor docs to reflect the discussion of oslo library
usage at the 10 January 2019 Glance weekly meeting.

Change-Id: Ibb75ce0cbc2b906838a5149dc75bfb27383178a7
2019-01-10 11:46:46 -05:00

109 lines
4.5 KiB
ReStructuredText

Disallowed Minor Code Changes
=============================
There are a few types of code changes that have been proposed recently that
have been rejected by the Glance team, so we want to point them out and explain
our reasoning.
If you feel an exception should be made for some particular change, please put
it on the agenda for the Glance weekly meeting so it can be discussed.
Database migration scripts
--------------------------
Once a database script has been included in a release, spelling or grammar
corrections in comments are forbidden unless you are fixing them as a part of
another stronger bug on the migration script itself. Modifying migration
scripts confuses operators and administrators -- we only want them to notice
serious problems. Their preference must take precedence over fixing spell
errors.
Typographical errors in comments
--------------------------------
Comments are not user-facing. Correcting minor misspellings or grammatical
errors only muddies the history of that part of the code, making ``git blame``
arguably less useful. So such changes are likely to be rejected. (This
prohibition, of course, does not apply to corrections of misleading or unclear
comments, or for example, an incorrect reference to a standards document.)
Misspellings in code
--------------------
Misspellings in function names are unlikely to be corrected for the "historical
clarity" reasons outlined above for comments. Plus, if a function is named
``mispelled()`` and a later developer tries to call ``misspelled()``, the
latter will result in a NameError when it's called, so the later developer will
know to use the incorrectly spelled function name.
Misspellings in variable names are more problematic, because if you have a
variable named ``mispelled`` and a later developer puts up a patch where an
updated value is assigned to ``misspelled``, Python won't complain. The "real"
variable won't be updated, and the patch won't have its intended effect.
Whether such a change is allowed will depend upon the age of the code, how
widely used the variable is, whether it's spelled correctly in other functions,
what the current test coverage is like, and so on. We tend to be very
conservative about making changes that could cause regressions. So whether a
patch that corrects the spelling of a variable name is accepted is a judgment
(or is that "judgement"?) call by reviewers. In proposing your patch, however,
be aware that your reviewers will have these concerns in mind.
Tests
-----
Occasionally someone proposes a patch that converts instances of
``assertEqual(True, whatever)`` to ``assertTrue(whatever)``, or instances of
``assertEqual(False, w)`` to ``assertFalse(w)`` in tests. Note that these are
not type safe changes and they weaken the tests. (See the Python ``unittest``
docs for details.) We tend to be very conservative about our tests and don't
like weakening changes.
We're not saying that such changes can never be made, we're just saying that
each change must be accompanied by an explanation of why the weaker test is
adequate for what's being tested.
Just to make this a bit clearer it can be shown using the following
example, comment out the lines in the runTest method alternatively::
import unittest
class MyTestCase(unittest.TestCase):
def setUp(self):
pass
class Tests(MyTestCase):
def runTest(self):
self.assertTrue('True')
self.assertTrue(True)
self.assertEqual(True, 'True')
To run this use::
python -m testtools.run test.py
Also mentioned within the unittests documentation_.
.. _documentation: https://docs.python.org/3/library/unittest.html#unittest.TestCase.assertTrue
LOG.warn to LOG.warning
-----------------------
Consistently there are proposed changes that will change all {LOG,logging}.
warn to {LOG,logging}.warning across the codebase due to the deprecation in
Python 3. While the deprecation is real, Glance uses oslo_log that provides
alias warn and solves the issue in single place for all projects using it.
These changes are not accepted due to the huge amount of refactoring they
cause for no reason.
Gratuitious use of oslo libraries
---------------------------------
We are big fans of the oslo libraries and all the hard work the Oslo team does
to keep common code reusable and easily consumable. But that doesn't mean that
it's a bug if Glance isn't using an oslo library everywhere you could possibly
use one. We are all for using oslo if it provides any level of benefit for us
and makes sense, but please let's not have these bugs/patches of "Let's use
oslo because it exists".