diff options
| author | Bryan Bishop <kanzure@gmail.com> | 2013-08-04 13:00:07 -0500 | 
|---|---|---|
| committer | Bryan Bishop <kanzure@gmail.com> | 2013-08-04 13:00:07 -0500 | 
| commit | 0d97582126b4c177f5a12388b6ff2548ef8acdac (patch) | |
| tree | b04dac745c3c22ac9cea59554d7fe76b4fb2f52c /tests | |
| parent | a818c979e6c7f0f47092a427f4e0e0c70e01e6cc (diff) | |
remove test helpers and meta testing
The meta testing code was really redundant. There are libraries and
tools already made for coverage tests.
Also, it was causing a problem with the unit testing because importing
the unittest module inside of another included module is apparently
broken. Why would that be broken?
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/helpers.py | 87 | ||||
| -rw-r--r-- | tests/test_helpers.py | 84 | ||||
| -rw-r--r-- | tests/tests.py | 8 | 
3 files changed, 0 insertions, 179 deletions
| diff --git a/tests/helpers.py b/tests/helpers.py deleted file mode 100644 index 8d05299..0000000 --- a/tests/helpers.py +++ /dev/null @@ -1,87 +0,0 @@ -# -*- coding: utf-8 -*- - -import sys -import inspect - -import unittest - -def assemble_test_cases(): -    """finds classes that inherit from unittest.TestCase -    because i am too lazy to remember to add them to a -    global list of tests for the suite runner""" -    classes = [] -    clsmembers = inspect.getmembers(sys.modules[__name__], inspect.isclass) -    for (name, some_class) in clsmembers: -        if issubclass(some_class, unittest.TestCase): -            classes.append(some_class) -    return classes - -def load_tests(loader, tests, pattern): -    suite = unittest.TestSuite() -    for test_class in assemble_test_cases(): -        tests = loader.loadTestsFromTestCase(test_class) -        suite.addTests(tests) -    return suite - -def check_has_test(func_name, tested_names): -    """checks if there is a test dedicated to this function""" -    if "test_"+func_name in tested_names: -        return True -    for name in tested_names: -        if "test_"+func_name in name: -            return True -    return False - -def find_untested_methods(): -    """finds all untested functions in this module -    by searching for method names in test case -    method names.""" -    untested = [] -    avoid_funcs = ["main", "run_tests", "run_main", "copy", "deepcopy"] -    test_funcs = [] -    # get a list of all classes in this module -    classes = inspect.getmembers(sys.modules[__name__], inspect.isclass) -    # for each class.. -    for (name, klass) in classes: -        # only look at those that have tests -        if issubclass(klass, unittest.TestCase): -            # look at this class' methods -            funcs = inspect.getmembers(klass, inspect.ismethod) -            # for each method.. -            for (name2, func) in funcs: -                # store the ones that begin with test_ -                if "test_" in name2 and name2[0:5] == "test_": -                    test_funcs.append([name2, func]) -    # assemble a list of all test method names (test_x, test_y, ..) -    tested_names = [funcz[0] for funcz in test_funcs] -    # now get a list of all functions in this module -    funcs = inspect.getmembers(sys.modules[__name__], inspect.isfunction) -    # for each function.. -    for (name, func) in funcs: -        # we don't care about some of these -        if name in avoid_funcs: continue -        # skip functions beginning with _ -        if name[0] == "_": continue -        # check if this function has a test named after it -        has_test = check_has_test(name, tested_names) -        if not has_test: -            untested.append(name) -    return untested - -def report_untested(): -    """ -    This reports about untested functions in the global namespace. This was -    originally in the crystal module, where it would list out the majority of -    the functions. Maybe it should be moved back. -    """ -    untested = find_untested_methods() -    output = "NOT TESTED: [" -    first = True -    for name in untested: -        if first: -            output += name -            first = False -        else: output += ", "+name -    output += "]\n" -    output += "total untested: " + str(len(untested)) -    return output diff --git a/tests/test_helpers.py b/tests/test_helpers.py deleted file mode 100644 index a6ef0a1..0000000 --- a/tests/test_helpers.py +++ /dev/null @@ -1,84 +0,0 @@ -import sys -import inspect - -import unittest - -from helpers import ( -    load_tests, -    check_has_test, -    assemble_test_cases, -    find_untested_methods, -    report_untested, -) - -class TestMetaTesting(unittest.TestCase): -    """test whether or not i am finding at least -    some of the tests in this file""" -    tests = None - -    def setUp(self): -        if self.tests == None: -            self.__class__.tests = assemble_test_cases() - -    def test_assemble_test_cases_count(self): -        "does assemble_test_cases find some tests?" -        self.failUnless(len(self.tests) > 0) - -    def test_assemble_test_cases_inclusion(self): -        "is this class found by assemble_test_cases?" -        # i guess it would have to be for this to be running? -        self.failUnless(self.__class__ in self.tests) - -    def test_assemble_test_cases_others(self): -        "test other inclusions for assemble_test_cases" -        self.failUnless(TestRomStr in self.tests) -        self.failUnless(TestCram in self.tests) - -    def test_check_has_test(self): -        self.failUnless(check_has_test("beaver", ["test_beaver"])) -        self.failUnless(check_has_test("beaver", ["test_beaver_2"])) -        self.failIf(check_has_test("beaver_1", ["test_beaver"])) - -    def test_find_untested_methods(self): -        untested = find_untested_methods() -        # the return type must be an iterable -        self.failUnless(hasattr(untested, "__iter__")) -        #.. basically, a list -        self.failUnless(isinstance(untested, list)) - -    def test_find_untested_methods_method(self): -        """create a function and see if it is found""" -        # setup a function in the global namespace -        global some_random_test_method -        # define the method -        def some_random_test_method(): pass -        # first make sure it is in the global scope -        members = inspect.getmembers(sys.modules[__name__], inspect.isfunction) -        func_names = [functuple[0] for functuple in members] -        self.assertIn("some_random_test_method", func_names) -        # test whether or not it is found by find_untested_methods -        untested = find_untested_methods() -        self.assertIn("some_random_test_method", untested) -        # remove the test method from the global namespace -        del some_random_test_method - -    def test_load_tests(self): -        loader = unittest.TestLoader() -        suite = load_tests(loader, None, None) -        suite._tests[0]._testMethodName -        membership_test = lambda member: \ -            inspect.isclass(member) and issubclass(member, unittest.TestCase) -        tests = inspect.getmembers(sys.modules[__name__], membership_test) -        classes = [x[1] for x in tests] -        for test in suite._tests: -            self.assertIn(test.__class__, classes) - -    def test_report_untested(self): -        untested = find_untested_methods() -        output = report_untested() -        if len(untested) > 0: -            self.assertIn("NOT TESTED", output) -            for name in untested: -                self.assertIn(name, output) -        elif len(untested) == 0: -            self.assertNotIn("NOT TESTED", output) diff --git a/tests/tests.py b/tests/tests.py index 4cbcdf2..3443341 100644 --- a/tests/tests.py +++ b/tests/tests.py @@ -92,14 +92,6 @@ from pokemontools.crystal import (  import unittest -from helpers import ( -    assemble_test_cases, -    load_tests, -    check_has_test, -    find_untested_methods, -    report_untested, -) -  class TestCram(unittest.TestCase):      "this is where i cram all of my unit tests together" | 
