123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- from contextlib import contextmanager
- import os
- from unittest import TestSuite, TextTestRunner, defaultTestLoader
- from django.test import TestCase
- from django.test.runner import DiscoverRunner
- @contextmanager
- def change_cwd(directory):
- current_dir = os.path.abspath(os.path.dirname(__file__))
- new_dir = os.path.join(current_dir, directory)
- old_cwd = os.getcwd()
- os.chdir(new_dir)
- try:
- yield
- finally:
- os.chdir(old_cwd)
- class DiscoverRunnerTest(TestCase):
- def test_dotted_test_module(self):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.tests_sample"],
- ).countTestCases()
- self.assertEqual(count, 4)
- def test_dotted_test_class_vanilla_unittest(self):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.tests_sample.TestVanillaUnittest"],
- ).countTestCases()
- self.assertEqual(count, 1)
- def test_dotted_test_class_django_testcase(self):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.tests_sample.TestDjangoTestCase"],
- ).countTestCases()
- self.assertEqual(count, 1)
- def test_dotted_test_method_django_testcase(self):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.tests_sample.TestDjangoTestCase.test_sample"],
- ).countTestCases()
- self.assertEqual(count, 1)
- def test_pattern(self):
- count = DiscoverRunner(
- pattern="*_tests.py",
- ).build_suite(["test_discovery_sample"]).countTestCases()
- self.assertEqual(count, 1)
- def test_file_path(self):
- with change_cwd(".."):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample/"],
- ).countTestCases()
- self.assertEqual(count, 5)
- def test_empty_label(self):
- """
- If the test label is empty, discovery should happen on the current
- working directory.
- """
- with change_cwd("."):
- suite = DiscoverRunner().build_suite([])
- self.assertEqual(
- suite._tests[0].id().split(".")[0],
- os.path.basename(os.getcwd()),
- )
- def test_empty_test_case(self):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.tests_sample.EmptyTestCase"],
- ).countTestCases()
- self.assertEqual(count, 0)
- def test_discovery_on_package(self):
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.tests"],
- ).countTestCases()
- self.assertEqual(count, 1)
- def test_ignore_adjacent(self):
- """
- When given a dotted path to a module, unittest discovery searches
- not just the module, but also the directory containing the module.
- This results in tests from adjacent modules being run when they
- should not. The discover runner avoids this behavior.
- """
- count = DiscoverRunner().build_suite(
- ["test_discovery_sample.empty"],
- ).countTestCases()
- self.assertEqual(count, 0)
- def test_testcase_ordering(self):
- with change_cwd(".."):
- suite = DiscoverRunner().build_suite(["test_discovery_sample/"])
- self.assertEqual(
- suite._tests[0].__class__.__name__,
- 'TestDjangoTestCase',
- msg="TestDjangoTestCase should be the first test case")
- self.assertEqual(
- suite._tests[1].__class__.__name__,
- 'TestZimpleTestCase',
- msg="TestZimpleTestCase should be the second test case")
- # All others can follow in unspecified order, including doctests
- self.assertIn('DocTestCase', [t.__class__.__name__ for t in suite._tests[2:]])
- def test_duplicates_ignored(self):
- """
- Tests shouldn't be discovered twice when discovering on overlapping paths.
- """
- single = DiscoverRunner().build_suite(["django.contrib.gis"]).countTestCases()
- dups = DiscoverRunner().build_suite(
- ["django.contrib.gis", "django.contrib.gis.tests.geo3d"]).countTestCases()
- self.assertEqual(single, dups)
- def test_reverse(self):
- """
- Reverse should reorder tests while maintaining the grouping specified
- by ``DiscoverRunner.reorder_by``.
- """
- runner = DiscoverRunner(reverse=True)
- suite = runner.build_suite(
- test_labels=('test_discovery_sample', 'test_discovery_sample2'))
- self.assertIn('test_discovery_sample2', next(iter(suite)).id(),
- msg="Test labels should be reversed.")
- suite = runner.build_suite(test_labels=('test_discovery_sample2',))
- suite = tuple(suite)
- self.assertIn('DjangoCase', suite[0].id(),
- msg="Test groups should not be reversed.")
- self.assertIn('SimpleCase', suite[4].id(),
- msg="Test groups order should be preserved.")
- self.assertIn('DjangoCase2', suite[0].id(),
- msg="Django test cases should be reversed.")
- self.assertIn('SimpleCase2', suite[4].id(),
- msg="Simple test cases should be reversed.")
- self.assertIn('UnittestCase2', suite[8].id(),
- msg="Unittest test cases should be reversed.")
- self.assertIn('test_2', suite[0].id(),
- msg="Methods of Django cases should be reversed.")
- self.assertIn('test_2', suite[4].id(),
- msg="Methods of simple cases should be reversed.")
- self.assertIn('test_2', suite[8].id(),
- msg="Methods of unittest cases should be reversed.")
- def test_overrideable_test_suite(self):
- self.assertEqual(DiscoverRunner().test_suite, TestSuite)
- def test_overrideable_test_runner(self):
- self.assertEqual(DiscoverRunner().test_runner, TextTestRunner)
- def test_overrideable_test_loader(self):
- self.assertEqual(DiscoverRunner().test_loader, defaultTestLoader)
|