From 71e573f4ba8a45dd5962f9d180c6236ce85627ca Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Mon, 19 Oct 2015 16:59:14 +0200 Subject: [PATCH] Port swift.common.utils.backward() to Python 3 backward() is written to handle binary files: * Replace literal native strings to literal byte strings: add b'...' prefix * Update unit tests: use byte strings * TemporaryFile(): use the default mode 'w+b', instead of using 'r+w' ('r+w' mode creates a Unicode file on Python 3). Change-Id: Ic91f7e6c605db0b888763080d49f0f501029837f --- swift/common/utils.py | 4 ++-- test/unit/common/test_utils.py | 22 +++++++++++----------- 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/swift/common/utils.py b/swift/common/utils.py index ce28cea9a7..a4647e80bf 100644 --- a/swift/common/utils.py +++ b/swift/common/utils.py @@ -249,7 +249,7 @@ def backward(f, blocksize=4096): f.seek(0, os.SEEK_END) if f.tell() == 0: return - last_row = '' + last_row = b'' while f.tell() != 0: try: f.seek(-blocksize, os.SEEK_CUR) @@ -258,7 +258,7 @@ def backward(f, blocksize=4096): f.seek(-blocksize, os.SEEK_CUR) block = f.read(blocksize) f.seek(-blocksize, os.SEEK_CUR) - rows = block.split('\n') + rows = block.split(b'\n') rows[-1] = rows[-1] + last_row while rows: last_row = rows.pop(-1) diff --git a/test/unit/common/test_utils.py b/test/unit/common/test_utils.py index 568bf657ad..5aafe597c5 100644 --- a/test/unit/common/test_utils.py +++ b/test/unit/common/test_utils.py @@ -955,23 +955,23 @@ class TestUtils(unittest.TestCase): # all of the boundary conditions and typical conditions. # Block boundaries are marked with '<>' characters blocksize = 25 - lines = ['123456789x12345678><123456789\n', # block larger than rest - '123456789x123>\n', # block ends just before \n character - '123423456789\n', - '123456789x\n', # block ends at the end of line - '<123456789x123456789x123\n', - '<6789x123\n', # block ends at the beginning of the line - '6789x1234\n', - '1234><234\n', # block ends typically in the middle of line - '123456789x123456789\n'] + lines = [b'123456789x12345678><123456789\n', # block larger than rest + b'123456789x123>\n', # block ends just before \n character + b'123423456789\n', + b'123456789x\n', # block ends at the end of line + b'<123456789x123456789x123\n', + b'<6789x123\n', # block ends at the beginning of the line + b'6789x1234\n', + b'1234><234\n', # block ends typically in the middle of line + b'123456789x123456789\n'] - with TemporaryFile('r+w') as f: + with TemporaryFile() as f: for line in lines: f.write(line) count = len(lines) - 1 for line in utils.backward(f, blocksize): - self.assertEqual(line, lines[count].split('\n')[0]) + self.assertEqual(line, lines[count].split(b'\n')[0]) count -= 1 # Empty file case