~jbaker/storm/nose_plugin

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
#!/usr/bin/env python
import optparse
import unittest
import doctest
import new
import sys
import os

import tests


def disable_conftest():
    """Install an empty module on py.test's tests.conftest

    When other runners are stepping by the suite of tests, they shouldn't
    find the py.test specific conftest.py file.
    """
    conftest = new.module("conftest")
    conftest.__file__ = "tests/conftest.py"
    sys.modules["tests.conftest"] = tests.conftest = conftest

def test_with_trial():
    from twisted.scripts import trial
    disable_conftest()
    if not [x for x in sys.argv[1:] if not x.startswith("-")]:
        for dir, dirs, files in os.walk('tests'):
            for file in files:
                if file.endswith('.py'):
                    sys.argv.append(os.path.join(dir, file))
    trial.run()

def test_with_py_test():
    import py
    dirname = os.path.dirname(__file__)
    if not [x for x in sys.argv[1:] if not x.startswith("-")]:
        tests_dir = os.path.join(dirname, "tests/")
        # For timestamp checking when looping:
        storm_dir = os.path.join(dirname, "storm/")
        sys.argv.extend([tests_dir, storm_dir])
    py.test.cmdline.main()

def test_with_unittest():

    usage = "test.py [options] [<test filename>, ...]"

    parser = optparse.OptionParser(usage=usage)

    parser.add_option('--verbose', action='store_true')
    opts, args = parser.parse_args()
    opts.args = args

    disable_conftest()

    runner = unittest.TextTestRunner()

    if opts.verbose:
        runner.verbosity = 2
        
    loader = unittest.TestLoader()
    topdir = os.path.abspath(os.path.dirname(__file__))
    testdir = os.path.dirname(tests.__file__)
    doctest_flags = doctest.ELLIPSIS
    unittests = []
    doctests = []
    for root, dirnames, filenames in os.walk(testdir):
        for filename in filenames:
            filepath = os.path.join(root, filename)
            relpath = filepath[len(topdir)+1:]
            if (filename == "__init__.py" or filename.endswith(".pyc") or
                opts.args and relpath not in opts.args):
                pass
            elif filename.endswith(".py"):
                unittests.append(relpath)
            elif filename.endswith(".txt"):
                doctests.append(relpath)

    class Summary:
        def __init__(self):
            self.total_failures = 0
            self.total_errors = 0
            self.total_tests = 0
        def __call__(self, tests, failures, errors):
            self.total_tests += tests
            self.total_failures += failures
            self.total_errors += errors
            print "(tests=%d, failures=%d, errors=%d)" % \
                  (tests, failures, errors)

    unittest_summary = Summary()
    doctest_summary = Summary()

    if unittests:
        print "Running unittests..."
        for relpath in unittests:
            print "[%s]" % relpath
            modpath = relpath.replace('/', '.')[:-3]
            module = __import__(modpath, None, None, [""])
            test = loader.loadTestsFromModule(module)
            result = runner.run(test)
            unittest_summary(test.countTestCases(),
                             len(result.failures), len(result.errors))
            print

    if doctests:
        print "Running doctests..."
        for relpath in doctests:
            print "[%s]" % relpath
            failures, total = doctest.testfile(relpath,
                                               optionflags=doctest_flags)
            doctest_summary(total, failures, 0)
            print

    print "Total test cases: %d" % unittest_summary.total_tests
    print "Total doctests: %d" % doctest_summary.total_tests
    print "Total failures: %d" % (unittest_summary.total_failures +
                                  doctest_summary.total_failures)
    print "Total errors: %d" % (unittest_summary.total_errors +
                                doctest_summary.total_errors)

    failed = bool(unittest_summary.total_failures or
                  unittest_summary.total_errors or
                  doctest_summary.total_failures or
                  doctest_summary.total_errors)

    sys.exit(failed)

if __name__ == "__main__":
    runner = os.environ.get("STORM_TEST_RUNNER")
    if not runner:
        runner = "unittest"
    runner_func = globals().get("test_with_%s" % runner.replace(".", "_"))
    if not runner_func:
        sys.exit("Test runner not found: %s" % runner)
    runner_func()

# vim:ts=4:sw=4:et