[tor-commits] [stem/master] Move remaining run_tests.py helpers

atagar at torproject.org atagar at torproject.org
Mon May 22 18:30:29 UTC 2017


commit bb7975928a07893699b26528989d39bac941b82d
Author: Damian Johnson <atagar at torproject.org>
Date:   Sun May 21 18:57:00 2017 -0700

    Move remaining run_tests.py helpers
    
    Most of the remaining helpers are solely used by run_tests.py. Might as well
    have them in there. I probably originally moved these out when run_tests.py was
    tiny but it's already a moderately sizable module so these don't account for
    much.
---
 run_tests.py      | 85 +++++++++++++++++++++++++++++++++++++++++++++++---
 test/settings.cfg |  2 +-
 test/util.py      | 92 +------------------------------------------------------
 3 files changed, 83 insertions(+), 96 deletions(-)

diff --git a/run_tests.py b/run_tests.py
index f3eabf4..6beb659 100755
--- a/run_tests.py
+++ b/run_tests.py
@@ -37,8 +37,10 @@ from test.output import STATUS, SUCCESS, ERROR, NO_NL, STDERR, println
 from test.util import STEM_BASE
 
 CONFIG = stem.util.conf.config_dict('test', {
-  'integ.test_directory': './test/data',
+  'test.unit_tests': '',
+  'test.integ_tests': '',
   'target.prereq': {},
+  'target.torrc': {},
 })
 
 MOCK_UNAVAILABLE_MSG = """\
@@ -71,6 +73,81 @@ if stem.prereq._is_python_26():
   unittest.TestCase.assertItemsEqual = assertItemsEqual
 
 
+def get_unit_tests(module_prefix = None):
+  """
+  Provides the classes for our unit tests.
+
+  :param str module_prefix: only provide the test if the module starts with
+    this substring
+
+  :returns: an **iterator** for our unit tests
+  """
+
+  if module_prefix and not module_prefix.startswith('test.unit.'):
+    module_prefix = 'test.unit.' + module_prefix
+
+  return _get_tests(CONFIG['test.unit_tests'].splitlines(), module_prefix)
+
+
+def get_integ_tests(module_prefix = None):
+  """
+  Provides the classes for our integration tests.
+
+  :param str module_prefix: only provide the test if the module starts with
+    this substring
+
+  :returns: an **iterator** for our integration tests
+  """
+
+  if module_prefix and not module_prefix.startswith('test.integ.'):
+    module_prefix = 'test.integ.' + module_prefix
+
+  return _get_tests(CONFIG['test.integ_tests'].splitlines(), module_prefix)
+
+
+def _get_tests(modules, module_prefix):
+  for import_name in modules:
+    if import_name:
+      module, module_name = import_name.rsplit('.', 1)  # example: util.conf.TestConf
+
+      if not module_prefix or module.startswith(module_prefix):
+        yield import_name
+      elif module_prefix.startswith(module):
+        # single test for this module
+
+        test_module = module_prefix.rsplit('.', 1)[1]
+        yield '%s.%s' % (import_name, test_module)
+
+
+def get_torrc_entries(target):
+  """
+  Provides the torrc entries used to run the given target.
+
+  :param Target target: target to provide the custom torrc contents of
+
+  :returns: list of :class:`~test.runner.Torrc` entries for the given target
+
+  :raises: **ValueError** if the target.torrc config has entries that don't map
+    to test.runner.Torrc
+  """
+
+  # converts the 'target.torrc' csv into a list of test.runner.Torrc enums
+
+  config_csv = CONFIG['target.torrc'].get(target)
+  torrc_opts = []
+
+  if config_csv:
+    for opt in config_csv.split(','):
+      opt = opt.strip()
+
+      if opt in test.runner.Torrc.keys():
+        torrc_opts.append(test.runner.Torrc[opt])
+      else:
+        raise ValueError("'%s' isn't a test.runner.Torrc enumeration" % opt)
+
+  return torrc_opts
+
+
 def main():
   start_time = time.time()
 
@@ -173,7 +250,7 @@ def main():
     test.output.print_divider('UNIT TESTS', True)
     error_tracker.set_category('UNIT TEST')
 
-    for test_class in test.util.get_unit_tests(args.specific_test):
+    for test_class in get_unit_tests(args.specific_test):
       run_result = _run_test(args, test_class, output_filters, logging_buffer)
       skipped_tests += len(getattr(run_result, 'skipped', []))
 
@@ -205,7 +282,7 @@ def main():
       error_tracker.set_category(target)
 
       try:
-        integ_runner.start(args.attribute_targets, args.tor_path, extra_torrc_opts = test.util.get_torrc_entries(target))
+        integ_runner.start(args.attribute_targets, args.tor_path, extra_torrc_opts = get_torrc_entries(target))
 
         println('Running tests...\n', STATUS)
 
@@ -213,7 +290,7 @@ def main():
         if integ_runner.is_accessible():
           owner = integ_runner.get_tor_controller(True)  # controller to own our main Tor process
 
-        for test_class in test.util.get_integ_tests(args.specific_test):
+        for test_class in get_integ_tests(args.specific_test):
           run_result = _run_test(args, test_class, output_filters, logging_buffer)
           skipped_tests += len(getattr(run_result, 'skipped', []))
 
diff --git a/test/settings.cfg b/test/settings.cfg
index f11b1f5..2b5fafc 100644
--- a/test/settings.cfg
+++ b/test/settings.cfg
@@ -161,9 +161,9 @@ pyflakes.ignore stem/interpreter/__init__.py => undefined name 'raw_input'
 pyflakes.ignore stem/util/conf.py => undefined name 'unicode'
 pyflakes.ignore stem/util/test_tools.py => 'pyflakes' imported but unused
 pyflakes.ignore stem/util/test_tools.py => 'pycodestyle' imported but unused
-pyflakes.ignore test/mocking.py => undefined name 'test'
 pyflakes.ignore test/unit/response/events.py => 'from stem import *' used; unable to detect undefined names
 pyflakes.ignore test/unit/response/events.py => *may be undefined, or defined from star imports: stem
+pyflakes.ignore test/util.py => undefined name 'test'
 
 # Test modules we want to run. Modules are roughly ordered by the dependencies
 # so the lowest level tests come first. This is because a problem in say,
diff --git a/test/util.py b/test/util.py
index 2731f63..3decb89 100644
--- a/test/util.py
+++ b/test/util.py
@@ -6,10 +6,6 @@ Helper functions for our test framework.
 
 ::
 
-  get_unit_tests - provides our unit tests
-  get_integ_tests - provides our integration tests
-
-  get_torrc_entries - provides the torrc entries for a given target
   get_all_combinations - provides all combinations of attributes
   tor_version - provides the version of tor we're testing against
 """
@@ -18,17 +14,9 @@ import itertools
 import os
 
 import stem
-import stem.util.conf
 import stem.util.enum
 import stem.version
 
-CONFIG = stem.util.conf.config_dict('test', {
-  'target.torrc': {},
-  'integ.test_directory': './test/data',
-  'test.unit_tests': '',
-  'test.integ_tests': '',
-})
-
 # Integration targets fall into two categories:
 #
 # * Run Targets (like RUN_COOKIE and RUN_PTRACE) which customize our torrc.
@@ -75,81 +63,6 @@ with open(os.path.join(STEM_BASE, '.gitignore')) as ignore_file:
       IGNORED_FILE_TYPES.append(line[2:].strip())
 
 
-def get_unit_tests(module_prefix = None):
-  """
-  Provides the classes for our unit tests.
-
-  :param str module_prefix: only provide the test if the module starts with
-    this substring
-
-  :returns: an **iterator** for our unit tests
-  """
-
-  if module_prefix and not module_prefix.startswith('test.unit.'):
-    module_prefix = 'test.unit.' + module_prefix
-
-  return _get_tests(CONFIG['test.unit_tests'].splitlines(), module_prefix)
-
-
-def get_integ_tests(module_prefix = None):
-  """
-  Provides the classes for our integration tests.
-
-  :param str module_prefix: only provide the test if the module starts with
-    this substring
-
-  :returns: an **iterator** for our integration tests
-  """
-
-  if module_prefix and not module_prefix.startswith('test.integ.'):
-    module_prefix = 'test.integ.' + module_prefix
-
-  return _get_tests(CONFIG['test.integ_tests'].splitlines(), module_prefix)
-
-
-def _get_tests(modules, module_prefix):
-  for import_name in modules:
-    if import_name:
-      module, module_name = import_name.rsplit('.', 1)  # example: util.conf.TestConf
-
-      if not module_prefix or module.startswith(module_prefix):
-        yield import_name
-      elif module_prefix.startswith(module):
-        # single test for this module
-
-        test_module = module_prefix.rsplit('.', 1)[1]
-        yield '%s.%s' % (import_name, test_module)
-
-
-def get_torrc_entries(target):
-  """
-  Provides the torrc entries used to run the given target.
-
-  :param Target target: target to provide the custom torrc contents of
-
-  :returns: list of :class:`~test.runner.Torrc` entries for the given target
-
-  :raises: **ValueError** if the target.torrc config has entries that don't map
-    to test.runner.Torrc
-  """
-
-  # converts the 'target.torrc' csv into a list of test.runner.Torrc enums
-
-  config_csv = CONFIG['target.torrc'].get(target)
-  torrc_opts = []
-
-  if config_csv:
-    for opt in config_csv.split(','):
-      opt = opt.strip()
-
-      if opt in test.runner.Torrc.keys():
-        torrc_opts.append(test.runner.Torrc[opt])
-      else:
-        raise ValueError("'%s' isn't a test.runner.Torrc enumeration" % opt)
-
-  return torrc_opts
-
-
 def get_new_capabilities():
   """
   Provides a list of capabilities tor supports but stem doesn't, as discovered
@@ -185,7 +98,7 @@ def get_all_combinations(attr, include_empty = False):
 
   ::
 
-    >>> list(test.mocking.get_all_combinations(['a', 'b', 'c']))
+    >>> list(test.util.get_all_combinations(['a', 'b', 'c']))
     [('a',), ('b',), ('c',), ('a', 'b'), ('a', 'c'), ('b', 'c'), ('a', 'b', 'c')]
 
   :param list attr: attributes to provide combinations for
@@ -231,6 +144,3 @@ def tor_version(tor_path = None):
     TOR_VERSION = stem.version.get_system_tor_version(tor_path)
 
   return TOR_VERSION
-
-
-import test.runner  # needs to be imported at the end to avoid a circular dependency





More information about the tor-commits mailing list