Add hacking check to ensure not to use xrange()

Added hacking check to ensure not to use xrange for python3
compatibility.

Change-Id: I1aa510660a25936dbf1b2fc5971e7571090a42d0
Closes-Bug: #1538118
This commit is contained in:
Tin Lam 2016-03-17 15:57:06 +00:00
parent 392680f122
commit bcb0f3133f
3 changed files with 13 additions and 1 deletions

View File

@ -22,7 +22,7 @@ Manila Specific Commandments
- [M333] 'oslo_' should be used instead of 'oslo.'
- [M336] Must use a dict comprehension instead of a dict constructor
with a sequence of key-value pairs.
- [M337] Ensure to not use xrange().
LOG Translations
----------------

View File

@ -55,6 +55,7 @@ underscore_import_check_multi = re.compile(r"(.)*import (.)*_, (.)*")
custom_underscore_check = re.compile(r"(.)*_\s*=\s*(.)*")
oslo_namespace_imports = re.compile(r"from[\s]*oslo[.](.*)")
dict_constructor_with_list_copy_re = re.compile(r".*\bdict\((\[)?(\(|\[)")
assert_no_xrange_re = re.compile(r"\s*xrange\s*\(")
class BaseASTChecker(ast.NodeVisitor):
@ -243,6 +244,11 @@ def dict_constructor_with_list_copy(logical_line):
yield (0, msg)
def no_xrange(logical_line):
if assert_no_xrange_re.match(logical_line):
yield(0, "M337: Do not use xrange().")
def factory(register):
register(validate_log_translations)
register(check_explicit_underscore_import)
@ -251,3 +257,4 @@ def factory(register):
register(CheckForTransAdd)
register(check_oslo_namespace_imports)
register(dict_constructor_with_list_copy)
register(no_xrange)

View File

@ -238,3 +238,8 @@ class HackingTestCase(test.TestCase):
self.assertEqual(0, len(list(checks.dict_constructor_with_list_copy(
" self._render_dict(xml, data_el, data.__dict__)"))))
def test_no_xrange(self):
self.assertEqual(1, len(list(checks.no_xrange("xrange(45)"))))
self.assertEqual(0, len(list(checks.no_xrange("range(45)"))))