diff options
Diffstat (limited to 'Lib/unittest')
| -rw-r--r-- | Lib/unittest/case.py | 44 | ||||
| -rw-r--r-- | Lib/unittest/test/test_case.py | 54 | ||||
| -rw-r--r-- | Lib/unittest/test/test_loader.py | 4 | 
3 files changed, 48 insertions, 54 deletions
| diff --git a/Lib/unittest/case.py b/Lib/unittest/case.py index 3f2f37d32e..881de6ffa5 100644 --- a/Lib/unittest/case.py +++ b/Lib/unittest/case.py @@ -473,7 +473,7 @@ class TestCase(object):                          warnings.warn("TestResult has no addExpectedFailure method, reporting as passes",                                        RuntimeWarning)                          result.addSuccess(self) - +            return result          finally:              result.stopTest(self)              if orig_result is None: @@ -970,48 +970,6 @@ class TestCase(object):          self.fail(self._formatMessage(msg, standardMsg)) -    def assertSameElements(self, expected_seq, actual_seq, msg=None): -        """An unordered sequence specific comparison. - -        Raises with an error message listing which elements of expected_seq -        are missing from actual_seq and vice versa if any. - -        Duplicate elements are ignored when comparing *expected_seq* and -        *actual_seq*. It is the equivalent of ``assertEqual(set(expected), -        set(actual))`` but it works with sequences of unhashable objects as -        well. -        """ -        warnings.warn('assertSameElements is deprecated', -                      DeprecationWarning) -        try: -            expected = set(expected_seq) -            actual = set(actual_seq) -            missing = sorted(expected.difference(actual)) -            unexpected = sorted(actual.difference(expected)) -        except TypeError: -            # Fall back to slower list-compare if any of the objects are -            # not hashable. -            expected = list(expected_seq) -            actual = list(actual_seq) -            try: -                expected.sort() -                actual.sort() -            except TypeError: -                missing, unexpected = unorderable_list_difference(expected, -                                                                  actual) -            else: -                missing, unexpected = sorted_list_difference(expected, actual) -        errors = [] -        if missing: -            errors.append('Expected, but missing:\n    %s' % -                          safe_repr(missing)) -        if unexpected: -            errors.append('Unexpected, but present:\n    %s' % -                          safe_repr(unexpected)) -        if errors: -            standardMsg = '\n'.join(errors) -            self.fail(self._formatMessage(msg, standardMsg)) -      def assertCountEqual(self, first, second, msg=None):          """An unordered sequence comparison asserting that the same elements, diff --git a/Lib/unittest/test/test_case.py b/Lib/unittest/test/test_case.py index c74a539515..147a4da3a3 100644 --- a/Lib/unittest/test/test_case.py +++ b/Lib/unittest/test/test_case.py @@ -386,27 +386,62 @@ class Test_TestCase(unittest.TestCase, TestEquality, TestHashing):          self.assertIsInstance(Foo().id(), str) -    # "If result is omitted or None, a temporary result object is created -    # and used, but is not made available to the caller. As TestCase owns the +    # "If result is omitted or None, a temporary result object is created, +    # used, and is made available to the caller. As TestCase owns the      # temporary result startTestRun and stopTestRun are called.      def test_run__uses_defaultTestResult(self):          events = [] +        defaultResult = LoggingResult(events)          class Foo(unittest.TestCase):              def test(self):                  events.append('test')              def defaultTestResult(self): -                return LoggingResult(events) +                return defaultResult          # Make run() find a result object on its own -        Foo('test').run() +        result = Foo('test').run() +        self.assertIs(result, defaultResult)          expected = ['startTestRun', 'startTest', 'test', 'addSuccess',              'stopTest', 'stopTestRun']          self.assertEqual(events, expected) + +    # "The result object is returned to run's caller" +    def test_run__returns_given_result(self): + +        class Foo(unittest.TestCase): +            def test(self): +                pass + +        result = unittest.TestResult() + +        retval = Foo('test').run(result) +        self.assertIs(retval, result) + + +    # "The same effect [as method run] may be had by simply calling the +    # TestCase instance." +    def test_call__invoking_an_instance_delegates_to_run(self): +        resultIn = unittest.TestResult() +        resultOut = unittest.TestResult() + +        class Foo(unittest.TestCase): +            def test(self): +                pass + +            def run(self, result): +                self.assertIs(result, resultIn) +                return resultOut + +        retval = Foo('test')(resultIn) + +        self.assertIs(retval, resultOut) + +      def testShortDescriptionWithoutDocstring(self):          self.assertIsNone(self.shortDescription()) @@ -1140,7 +1175,6 @@ test case              (self.assert_, (True,)),              (self.failUnlessRaises, (TypeError, lambda _: 3.14 + 'spam')),              (self.failIf, (False,)), -            (self.assertSameElements, ([1, 1, 2, 3], [1, 2, 3])),              (self.assertDictContainsSubset, (dict(a=1, b=2), dict(a=1, b=2, c=3))),              (self.assertRaisesRegexp, (KeyError, 'foo', lambda: {}['foo'])),              (self.assertRegexpMatches, ('bar', 'bar')), @@ -1149,18 +1183,20 @@ test case              with self.assertWarns(DeprecationWarning):                  meth(*args) -    def testDeprecatedFailMethods(self): -        """Test that the deprecated fail* methods get removed in 3.3""" +    # disable this test for now. When the version where the fail* methods will +    # be removed is decided, re-enable it and update the version +    def _testDeprecatedFailMethods(self): +        """Test that the deprecated fail* methods get removed in 3.x"""          if sys.version_info[:2] < (3, 3):              return          deprecated_names = [              'failIfEqual', 'failUnlessEqual', 'failUnlessAlmostEqual',              'failIfAlmostEqual', 'failUnless', 'failUnlessRaises', 'failIf', -            'assertSameElements', 'assertDictContainsSubset', +            'assertDictContainsSubset',          ]          for deprecated_name in deprecated_names:              with self.assertRaises(AttributeError): -                getattr(self, deprecated_name)  # remove these in 3.3 +                getattr(self, deprecated_name)  # remove these in 3.x      def testDeepcopy(self):          # Issue: 5660 diff --git a/Lib/unittest/test/test_loader.py b/Lib/unittest/test/test_loader.py index f7e31a57f1..d1b9ef5a0a 100644 --- a/Lib/unittest/test/test_loader.py +++ b/Lib/unittest/test/test_loader.py @@ -239,7 +239,7 @@ class Test_TestLoader(unittest.TestCase):          try:              loader.loadTestsFromName('sdasfasfasdf')          except ImportError as e: -            self.assertEqual(str(e), "No module named sdasfasfasdf") +            self.assertEqual(str(e), "No module named 'sdasfasfasdf'")          else:              self.fail("TestLoader.loadTestsFromName failed to raise ImportError") @@ -619,7 +619,7 @@ class Test_TestLoader(unittest.TestCase):          try:              loader.loadTestsFromNames(['sdasfasfasdf'])          except ImportError as e: -            self.assertEqual(str(e), "No module named sdasfasfasdf") +            self.assertEqual(str(e), "No module named 'sdasfasfasdf'")          else:              self.fail("TestLoader.loadTestsFromNames failed to raise ImportError") | 
