[tor-commits] [stem/master] Simplifying _get_tests()

atagar at torproject.org atagar at torproject.org
Tue Mar 3 17:32:13 UTC 2015


commit 6a9c9a63b81c12679751f4c73e76fcc964680742
Author: Damian Johnson <atagar at torproject.org>
Date:   Tue Mar 3 08:47:27 2015 -0800

    Simplifying _get_tests()
    
    Our module_prefixes fall into two camps...
    
      * It's... well, a module prefix. It'll be a prefix of our import name.
      * It's an exact match for a test. Our import name will be a prefix of it.
    
    No need to strip off the last component and try again. We can do this in one
    pass. One thing I noticed though is that we don't check to see if tests exist.
    We rely on a try/catch for that. Might be able to wrap it into this helper -
    we'll see.
---
 test/util.py |   33 +++++++++------------------------
 1 file changed, 9 insertions(+), 24 deletions(-)

diff --git a/test/util.py b/test/util.py
index 78be64b..35909e5 100644
--- a/test/util.py
+++ b/test/util.py
@@ -108,33 +108,18 @@ def get_integ_tests(module_prefix = None):
 
 
 def _get_tests(modules, module_prefix):
-  # Look for module_prefix in the list of all modules
-  modules_found = 0
   for import_name in modules:
     if import_name:
-      if module_prefix and not import_name.startswith(module_prefix):
-        continue
+      if not module_prefix or import_name.startswith(module_prefix):
+        yield import_name
+      elif module_prefix.startswith(import_name):
+        # might be a single test in this module, check if we match any
+
+        module, test = module_prefix.rsplit('.', 1)
+
+        # TODO: should check if the test exists
 
-      modules_found += 1
-      yield import_name
-
-  # If no modules were found, then it might be that we were given
-  # a method (e.g test.integ.process.some_method).
-  # Delete the method substring and look again in the list of modules
-  if modules_found == 0:
-    module_list = module_prefix.split('.')
-    # At this point all module_prefix should be test.{integ|unit}.something
-    if(len(module_list) > 3):
-      module_prefix = '.'.join(module_list[:-1])
-      class_method = module_list[-1]
-
-      for import_name in modules:
-        if import_name:
-          if module_prefix and not import_name.startswith(module_prefix):
-            continue
-
-          # If found, return module.method
-          yield import_name + '.' + class_method
+        yield module_prefix
 
 
 def get_help_message():





More information about the tor-commits mailing list