]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-34215: Clarify IncompleteReadError message when "expected" is None (GH-21925...
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Sat, 28 Nov 2020 14:44:34 +0000 (06:44 -0800)
committerGitHub <noreply@github.com>
Sat, 28 Nov 2020 14:44:34 +0000 (16:44 +0200)
Co-Authored-By: Tyler Bell <mrbell321@gmail.com>
(cherry picked from commit 8085f742f4adfbc85f13fc734dfab036aa23acfb)
Co-authored-by: Zackery Spytz <zspytz@gmail.com>
Lib/asyncio/exceptions.py
Lib/test/test_asyncio/test_streams.py
Misc/NEWS.d/next/Library/2020-08-19-20-17-51.bpo-34215._Cv8c-.rst [new file with mode: 0644]

index e03602ef5762345480e36b2e250024b0cbb5ff0e..f07e4486577381616e7e2f7f05747ed7374316a1 100644 (file)
@@ -34,8 +34,9 @@ class IncompleteReadError(EOFError):
     - expected: total number of expected bytes (or None if unknown)
     """
     def __init__(self, partial, expected):
+        r_expected = 'undefined' if expected is None else repr(expected)
         super().__init__(f'{len(partial)} bytes read on a total of '
-                         f'{expected!r} expected bytes')
+                         f'{r_expected} expected bytes')
         self.partial = partial
         self.expected = expected
 
index 12bd536911dbb2bd83458e0032032e967ba9a338..84c031c71b6fdab849ee01d30dfd5ceb0bf3dddb 100644 (file)
@@ -452,12 +452,14 @@ class StreamTests(test_utils.TestCase):
 
     def test_readuntil_eof(self):
         stream = asyncio.StreamReader(loop=self.loop)
-        stream.feed_data(b'some dataAA')
+        data = b'some dataAA'
+        stream.feed_data(data)
         stream.feed_eof()
 
-        with self.assertRaises(asyncio.IncompleteReadError) as cm:
+        with self.assertRaisesRegex(asyncio.IncompleteReadError,
+                                    'undefined expected bytes') as cm:
             self.loop.run_until_complete(stream.readuntil(b'AAA'))
-        self.assertEqual(cm.exception.partial, b'some dataAA')
+        self.assertEqual(cm.exception.partial, data)
         self.assertIsNone(cm.exception.expected)
         self.assertEqual(b'', stream._buffer)
 
diff --git a/Misc/NEWS.d/next/Library/2020-08-19-20-17-51.bpo-34215._Cv8c-.rst b/Misc/NEWS.d/next/Library/2020-08-19-20-17-51.bpo-34215._Cv8c-.rst
new file mode 100644 (file)
index 0000000..4d91678
--- /dev/null
@@ -0,0 +1,2 @@
+Clarify the error message for :exc:`asyncio.IncompleteReadError` when
+``expected`` is ``None``.