| import unittest | |
| class TestHashing(object): | |
| """Used as a mixin for TestCase""" | |
| # Check for a valid __hash__ implementation | |
| def test_hash(self): | |
| for obj_1, obj_2 in self.eq_pairs: | |
| try: | |
| if not hash(obj_1) == hash(obj_2): | |
| self.fail("%r and %r do not hash equal" % (obj_1, obj_2)) | |
| except KeyboardInterrupt: | |
| raise | |
| except Exception, e: | |
| self.fail("Problem hashing %r and %r: %s" % (obj_1, obj_2, e)) | |
| for obj_1, obj_2 in self.ne_pairs: | |
| try: | |
| if hash(obj_1) == hash(obj_2): | |
| self.fail("%s and %s hash equal, but shouldn't" % | |
| (obj_1, obj_2)) | |
| except KeyboardInterrupt: | |
| raise | |
| except Exception, e: | |
| self.fail("Problem hashing %s and %s: %s" % (obj_1, obj_2, e)) | |
| class TestEquality(object): | |
| """Used as a mixin for TestCase""" | |
| # Check for a valid __eq__ implementation | |
| def test_eq(self): | |
| for obj_1, obj_2 in self.eq_pairs: | |
| self.assertEqual(obj_1, obj_2) | |
| self.assertEqual(obj_2, obj_1) | |
| # Check for a valid __ne__ implementation | |
| def test_ne(self): | |
| for obj_1, obj_2 in self.ne_pairs: | |
| self.assertNotEqual(obj_1, obj_2) | |
| self.assertNotEqual(obj_2, obj_1) | |
| class LoggingResult(unittest.TestResult): | |
| def __init__(self, log): | |
| self._events = log | |
| super(LoggingResult, self).__init__() | |
| def startTest(self, test): | |
| self._events.append('startTest') | |
| super(LoggingResult, self).startTest(test) | |
| def startTestRun(self): | |
| self._events.append('startTestRun') | |
| super(LoggingResult, self).startTestRun() | |
| def stopTest(self, test): | |
| self._events.append('stopTest') | |
| super(LoggingResult, self).stopTest(test) | |
| def stopTestRun(self): | |
| self._events.append('stopTestRun') | |
| super(LoggingResult, self).stopTestRun() | |
| def addFailure(self, *args): | |
| self._events.append('addFailure') | |
| super(LoggingResult, self).addFailure(*args) | |
| def addSuccess(self, *args): | |
| self._events.append('addSuccess') | |
| super(LoggingResult, self).addSuccess(*args) | |
| def addError(self, *args): | |
| self._events.append('addError') | |
| super(LoggingResult, self).addError(*args) | |
| def addSkip(self, *args): | |
| self._events.append('addSkip') | |
| super(LoggingResult, self).addSkip(*args) | |
| def addExpectedFailure(self, *args): | |
| self._events.append('addExpectedFailure') | |
| super(LoggingResult, self).addExpectedFailure(*args) | |
| def addUnexpectedSuccess(self, *args): | |
| self._events.append('addUnexpectedSuccess') | |
| super(LoggingResult, self).addUnexpectedSuccess(*args) | |
| class ResultWithNoStartTestRunStopTestRun(object): | |
| """An object honouring TestResult before startTestRun/stopTestRun.""" | |
| def __init__(self): | |
| self.failures = [] | |
| self.errors = [] | |
| self.testsRun = 0 | |
| self.skipped = [] | |
| self.expectedFailures = [] | |
| self.unexpectedSuccesses = [] | |
| self.shouldStop = False | |
| def startTest(self, test): | |
| pass | |
| def stopTest(self, test): | |
| pass | |
| def addError(self, test): | |
| pass | |
| def addFailure(self, test): | |
| pass | |
| def addSuccess(self, test): | |
| pass | |
| def wasSuccessful(self): | |
| return True |