From f9baac12f184edf4010086ca1cce0ac41872f507 Mon Sep 17 00:00:00 2001
From: Stefan Behnel <scoder@users.berlios.de>
Date: Sun, 25 May 2008 18:24:19 +0200
Subject: [PATCH] cleanup for test runner: use optparse to read cmd line
 options

---
 runtests.py | 93 ++++++++++++++++++++++-------------------------------
 1 file changed, 38 insertions(+), 55 deletions(-)

diff --git a/runtests.py b/runtests.py
index c4216ef4..052465a5 100644
--- a/runtests.py
+++ b/runtests.py
@@ -3,7 +3,6 @@
 import os, sys, re, shutil, unittest, doctest
 
 WITH_CYTHON = True
-CLEANUP_WORKDIR = True
 
 from distutils.dist import Distribution
 from distutils.core import Extension
@@ -34,11 +33,12 @@ class ErrorWriter(object):
         return errors
 
 class TestBuilder(object):
-    def __init__(self, rootdir, workdir, selectors, annotate):
+    def __init__(self, rootdir, workdir, selectors, annotate, cleanup_workdir):
         self.rootdir = rootdir
         self.workdir = workdir
         self.selectors = selectors
         self.annotate = annotate
+        self.cleanup_workdir = cleanup_workdir
 
     def build_suite(self):
         suite = unittest.TestSuite()
@@ -75,28 +75,34 @@ class TestBuilder(object):
                 continue
             if context in TEST_RUN_DIRS:
                 test = CythonRunTestCase(
-                    path, workdir, module, self.annotate)
+                    path, workdir, module,
+                    annotate=self.annotate,
+                    cleanup_workdir=self.cleanup_workdir)
             else:
                 test = CythonCompileTestCase(
-                    path, workdir, module, expect_errors, self.annotate)
+                    path, workdir, module,
+                    expect_errors=expect_errors,
+                    annotate=self.annotate,
+                    cleanup_workdir=self.cleanup_workdir)
             suite.addTest(test)
         return suite
 
 class CythonCompileTestCase(unittest.TestCase):
     def __init__(self, directory, workdir, module,
-                 expect_errors=False, annotate=False):
+                 expect_errors=False, annotate=False, cleanup_workdir=True):
         self.directory = directory
         self.workdir = workdir
         self.module = module
         self.expect_errors = expect_errors
         self.annotate = annotate
+        self.cleanup_workdir = cleanup_workdir
         unittest.TestCase.__init__(self)
 
     def shortDescription(self):
         return "compiling " + self.module
 
     def tearDown(self):
-        cleanup_c_files = WITH_CYTHON and CLEANUP_WORKDIR
+        cleanup_c_files = WITH_CYTHON and self.cleanup_workdir
         if os.path.exists(self.workdir):
             for rmfile in os.listdir(self.workdir):
                 if not cleanup_c_files and rmfile[-2:] in (".c", ".h"):
@@ -221,12 +227,22 @@ class CythonRunTestCase(CythonCompileTestCase):
             pass
 
 if __name__ == '__main__':
-    try:
-        sys.argv.remove("--no-cython")
-    except ValueError:
-        WITH_CYTHON = True
-    else:
-        WITH_CYTHON = False
+    from optparse import OptionParser
+    parser = OptionParser()
+    parser.add_option("--no-cython", dest="with_cython",
+                      action="store_false", default=True)
+    parser.add_option("--no-cleanup", dest="cleanup_workdir",
+                      action="store_false", default=True)
+    parser.add_option("-C", "--coverage", dest="coverage",
+                      action="store_true", default=False)
+    parser.add_option("-A", "--annotate-source", dest="annotate_source",
+                      action="store_true", default=False)
+    parser.add_option("-v", "--verbose", dest="verbosity",
+                      action="count", default=0)
+
+    options, cmd_args = parser.parse_args()
+
+    WITH_CYTHON = options.with_cython
 
     if WITH_CYTHON:
         from Cython.Compiler.Main import \
@@ -250,64 +266,31 @@ if __name__ == '__main__':
 
     if WITH_CYTHON:
         from Cython.Compiler.Version import version
-        from Cython.Compiler.Main import \
-            CompilationOptions, \
-            default_options as pyrex_default_options, \
-            compile as cython_compile
         print("Running tests against Cython %s" % version)
     else:
         print("Running tests without Cython.")
     print("Python %s" % sys.version)
     print("")
 
-    try:
-        sys.argv.remove("-C")
-    except ValueError:
-        coverage = None
-    else:
-        import coverage
-        coverage.erase()
-
-    try:
-        sys.argv.remove("--no-cleanup")
-    except ValueError:
-        CLEANUP_WORKDIR = True
-    else:
-        CLEANUP_WORKDIR = False
-
-    try:
-        sys.argv.remove("-a")
-    except ValueError:
-        annotate_source = False
-    else:
-        annotate_source = True
-
-    try:
-        sys.argv.remove("-vv")
-    except ValueError:
-        try:
-            sys.argv.remove("-v")
-        except ValueError:
-            verbosity = 0
-        else:
-            verbosity = 1
-    else:
-        verbosity = 2
-
     import re
-    selectors = [ re.compile(r, re.I|re.U).search for r in sys.argv[1:] ]
+    selectors = [ re.compile(r, re.I|re.U).search for r in cmd_args ]
     if not selectors:
         selectors = [ lambda x:True ]
 
-    tests = TestBuilder(ROOTDIR, WORKDIR, selectors, annotate_source)
+    if options.coverage:
+        import coverage
+        coverage.erase()
+
+    tests = TestBuilder(ROOTDIR, WORKDIR, selectors,
+                        options.annotate_source, options.cleanup_workdir)
     test_suite = tests.build_suite()
 
-    if coverage is not None:
+    if options.coverage:
         coverage.start()
 
-    unittest.TextTestRunner(verbosity=verbosity).run(test_suite)
+    unittest.TextTestRunner(verbosity=options.verbosity).run(test_suite)
 
-    if coverage is not None:
+    if options.coverage:
         coverage.stop()
         ignored_modules = ('Options', 'Version', 'DebugFlags')
         modules = [ module for name, module in sys.modules.items()
-- 
2.26.2