mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-13 18:56:17 +03:00
Correct str/bytes mixup in ContainerIO
Image data is expected to be read in bytes mode, not text mode so ContainerIO should return bytes in all methods. The passed in file handler is expected to be opened in bytes mode (as TarIO already does).
This commit is contained in:
parent
d03d390a0d
commit
e817ed0d3e
|
@ -20,7 +20,7 @@ def test_isatty():
|
||||||
def test_seek_mode_0():
|
def test_seek_mode_0():
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = 0
|
mode = 0
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 22, 100)
|
container = ContainerIO.ContainerIO(fh, 22, 100)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
@ -34,7 +34,7 @@ def test_seek_mode_0():
|
||||||
def test_seek_mode_1():
|
def test_seek_mode_1():
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = 1
|
mode = 1
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 22, 100)
|
container = ContainerIO.ContainerIO(fh, 22, 100)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
@ -48,7 +48,7 @@ def test_seek_mode_1():
|
||||||
def test_seek_mode_2():
|
def test_seek_mode_2():
|
||||||
# Arrange
|
# Arrange
|
||||||
mode = 2
|
mode = 2
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 22, 100)
|
container = ContainerIO.ContainerIO(fh, 22, 100)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
@ -61,7 +61,7 @@ def test_seek_mode_2():
|
||||||
|
|
||||||
def test_read_n0():
|
def test_read_n0():
|
||||||
# Arrange
|
# Arrange
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 22, 100)
|
container = ContainerIO.ContainerIO(fh, 22, 100)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
@ -69,12 +69,12 @@ def test_read_n0():
|
||||||
data = container.read()
|
data = container.read()
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert data == "7\nThis is line 8\n"
|
assert data == b"7\nThis is line 8\n"
|
||||||
|
|
||||||
|
|
||||||
def test_read_n():
|
def test_read_n():
|
||||||
# Arrange
|
# Arrange
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 22, 100)
|
container = ContainerIO.ContainerIO(fh, 22, 100)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
@ -82,12 +82,12 @@ def test_read_n():
|
||||||
data = container.read(3)
|
data = container.read(3)
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert data == "7\nT"
|
assert data == b"7\nT"
|
||||||
|
|
||||||
|
|
||||||
def test_read_eof():
|
def test_read_eof():
|
||||||
# Arrange
|
# Arrange
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 22, 100)
|
container = ContainerIO.ContainerIO(fh, 22, 100)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
@ -95,34 +95,34 @@ def test_read_eof():
|
||||||
data = container.read()
|
data = container.read()
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert data == ""
|
assert data == b""
|
||||||
|
|
||||||
|
|
||||||
def test_readline():
|
def test_readline():
|
||||||
# Arrange
|
# Arrange
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 0, 120)
|
container = ContainerIO.ContainerIO(fh, 0, 120)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
data = container.readline()
|
data = container.readline()
|
||||||
|
|
||||||
# Assert
|
# Assert
|
||||||
assert data == "This is line 1\n"
|
assert data == b"This is line 1\n"
|
||||||
|
|
||||||
|
|
||||||
def test_readlines():
|
def test_readlines():
|
||||||
# Arrange
|
# Arrange
|
||||||
expected = [
|
expected = [
|
||||||
"This is line 1\n",
|
b"This is line 1\n",
|
||||||
"This is line 2\n",
|
b"This is line 2\n",
|
||||||
"This is line 3\n",
|
b"This is line 3\n",
|
||||||
"This is line 4\n",
|
b"This is line 4\n",
|
||||||
"This is line 5\n",
|
b"This is line 5\n",
|
||||||
"This is line 6\n",
|
b"This is line 6\n",
|
||||||
"This is line 7\n",
|
b"This is line 7\n",
|
||||||
"This is line 8\n",
|
b"This is line 8\n",
|
||||||
]
|
]
|
||||||
with open(TEST_FILE) as fh:
|
with open(TEST_FILE, "rb") as fh:
|
||||||
container = ContainerIO.ContainerIO(fh, 0, 120)
|
container = ContainerIO.ContainerIO(fh, 0, 120)
|
||||||
|
|
||||||
# Act
|
# Act
|
||||||
|
|
|
@ -82,7 +82,7 @@ class ContainerIO:
|
||||||
else:
|
else:
|
||||||
n = self.length - self.pos
|
n = self.length - self.pos
|
||||||
if not n: # EOF
|
if not n: # EOF
|
||||||
return ""
|
return b""
|
||||||
self.pos = self.pos + n
|
self.pos = self.pos + n
|
||||||
return self.fh.read(n)
|
return self.fh.read(n)
|
||||||
|
|
||||||
|
@ -92,13 +92,13 @@ class ContainerIO:
|
||||||
|
|
||||||
:returns: An 8-bit string.
|
:returns: An 8-bit string.
|
||||||
"""
|
"""
|
||||||
s = ""
|
s = b""
|
||||||
while True:
|
while True:
|
||||||
c = self.read(1)
|
c = self.read(1)
|
||||||
if not c:
|
if not c:
|
||||||
break
|
break
|
||||||
s = s + c
|
s = s + c
|
||||||
if c == "\n":
|
if c == b"\n":
|
||||||
break
|
break
|
||||||
return s
|
return s
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user