Change shouldFail to avoid Unicode errors when converting Failure to str
authordavid-sarah <david-sarah@jacaranda.org>
Wed, 12 May 2010 06:07:54 +0000 (23:07 -0700)
committerdavid-sarah <david-sarah@jacaranda.org>
Wed, 12 May 2010 06:07:54 +0000 (23:07 -0700)
src/allmydata/test/common.py

index 8f790130f4a9334d321e8bbcf5e9ba26f2f247fa..9f37073a3ccddc292a5cc85831606dec91048abc 100644 (file)
@@ -1090,8 +1090,8 @@ class ShouldFailMixin:
         error message, if any, because Deferred chains frequently make it
         difficult to tell which assertion was tripped.
 
-        The substring= argument, if not None, must appear inside the
-        stringified Failure, or the test will fail.
+        The substring= argument, if not None, must appear in the 'repr'
+        of the message wrapped by this Failure, or the test will fail.
         """
 
         assert substring is None or isinstance(substring, str)
@@ -1100,9 +1100,10 @@ class ShouldFailMixin:
             if isinstance(res, failure.Failure):
                 res.trap(expected_failure)
                 if substring:
-                    self.failUnless(substring in str(res),
+                    message = repr(res.value.args[0])
+                    self.failUnless(substring in message,
                                     "substring '%s' not in '%s'"
-                                    % (substring, str(res)))
+                                    % (substring, message))
             else:
                 self.fail("%s was supposed to raise %s, not get '%s'" %
                           (which, expected_failure, res))