summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2016-04-15 17:52:27 +0200
committerVictor Stinner <victor.stinner@gmail.com>2016-04-15 17:52:27 +0200
commite914d413128e504f4bb4c46315c9afef104388c9 (patch)
tree8170ba652ef5cb511f6849da643a29ac37b5ce7b
parent12bb6f4c7d590e29f7c57d176d4295da4ef4573a (diff)
downloadcpython-git-e914d413128e504f4bb4c46315c9afef104388c9.tar.gz
Issue #26766: Fix _PyBytesWriter_Finish()
Return a bytearray object when bytearray is requested and when the small buffer is used. Fix also test_bytes: bytearray%args must return a bytearray type.
-rw-r--r--Lib/test/test_bytes.py4
-rw-r--r--Objects/bytesobject.c7
2 files changed, 8 insertions, 3 deletions
diff --git a/Lib/test/test_bytes.py b/Lib/test/test_bytes.py
index 966e287afe..a10ad5e893 100644
--- a/Lib/test/test_bytes.py
+++ b/Lib/test/test_bytes.py
@@ -492,7 +492,7 @@ class BaseBytesTest:
b = self.type2test(b'%s / 100 = %d%%')
a = b % (b'seventy-nine', 79)
self.assertEqual(a, b'seventy-nine / 100 = 79%')
- self.assertIs(type(a), bytes)
+ self.assertIs(type(a), self.type2test)
def test_imod(self):
b = self.type2test(b'hello, %b!')
@@ -504,7 +504,7 @@ class BaseBytesTest:
b = self.type2test(b'%s / 100 = %d%%')
b %= (b'seventy-nine', 79)
self.assertEqual(b, b'seventy-nine / 100 = 79%')
- self.assertIs(type(b), bytes)
+ self.assertIs(type(b), self.type2test)
def test_rmod(self):
with self.assertRaises(TypeError):
diff --git a/Objects/bytesobject.c b/Objects/bytesobject.c
index ec03233ba3..701ae9df8a 100644
--- a/Objects/bytesobject.c
+++ b/Objects/bytesobject.c
@@ -4150,7 +4150,12 @@ _PyBytesWriter_Finish(_PyBytesWriter *writer, void *str)
result = PyBytes_FromStringAndSize(NULL, 0);
}
else if (writer->use_small_buffer) {
- result = PyBytes_FromStringAndSize(writer->small_buffer, size);
+ if (writer->use_bytearray) {
+ result = PyByteArray_FromStringAndSize(writer->small_buffer, size);
+ }
+ else {
+ result = PyBytes_FromStringAndSize(writer->small_buffer, size);
+ }
}
else {
result = writer->buffer;