Merge "py3: adapt account/backend.py and utils.py"

This commit is contained in:
Zuul 2018-10-17 04:47:22 +00:00 committed by Gerrit Code Review
commit 56c06557ac
3 changed files with 28 additions and 22 deletions

View File

@ -20,6 +20,8 @@ from uuid import uuid4
import sqlite3 import sqlite3
import six
from swift.common.utils import Timestamp from swift.common.utils import Timestamp
from swift.common.db import DatabaseBroker, utf8encode, zero_like from swift.common.db import DatabaseBroker, utf8encode, zero_like
@ -244,7 +246,7 @@ class AccountBroker(DatabaseBroker):
""" """
Create a container with the given attributes. Create a container with the given attributes.
:param name: name of the container to create :param name: name of the container to create (a native string)
:param put_timestamp: put_timestamp of the container to create :param put_timestamp: put_timestamp of the container to create
:param delete_timestamp: delete_timestamp of the container to create :param delete_timestamp: delete_timestamp of the container to create
:param object_count: number of objects in the container :param object_count: number of objects in the container
@ -384,6 +386,7 @@ class AccountBroker(DatabaseBroker):
put_timestamp, 0) put_timestamp, 0)
""" """
delim_force_gte = False delim_force_gte = False
if six.PY2:
(marker, end_marker, prefix, delimiter) = utf8encode( (marker, end_marker, prefix, delimiter) = utf8encode(
marker, end_marker, prefix, delimiter) marker, end_marker, prefix, delimiter)
if reverse: if reverse:
@ -415,7 +418,7 @@ class AccountBroker(DatabaseBroker):
query_args.append(marker) query_args.append(marker)
# Always set back to False # Always set back to False
delim_force_gte = False delim_force_gte = False
elif marker and marker >= prefix: elif marker and (not prefix or marker >= prefix):
query += ' name > ? AND' query += ' name > ? AND'
query_args.append(marker) query_args.append(marker)
elif prefix: elif prefix:

View File

@ -32,6 +32,8 @@ import random
import mock import mock
import base64 import base64
import six
from swift.account.backend import AccountBroker from swift.account.backend import AccountBroker
from swift.common.utils import Timestamp from swift.common.utils import Timestamp
from test.unit import patch_policies, with_tempdir, make_timestamp_iter from test.unit import patch_policies, with_tempdir, make_timestamp_iter
@ -720,26 +722,23 @@ class TestAccountBroker(unittest.TestCase):
broker.put_container('b', Timestamp(2).internal, broker.put_container('b', Timestamp(2).internal,
Timestamp(0).internal, 0, 0, Timestamp(0).internal, 0, 0,
POLICIES.default.idx) POLICIES.default.idx)
hasha = hashlib.md5( text = '%s-%s' % ('a', "%s-%s-%s-%s" % (
'%s-%s' % ('a', "%s-%s-%s-%s" % (
Timestamp(1).internal, Timestamp(0).internal, 0, 0)) Timestamp(1).internal, Timestamp(0).internal, 0, 0))
).digest() hasha = hashlib.md5(text.encode('ascii')).digest()
hashb = hashlib.md5( text = '%s-%s' % ('b', "%s-%s-%s-%s" % (
'%s-%s' % ('b', "%s-%s-%s-%s" % (
Timestamp(2).internal, Timestamp(0).internal, 0, 0)) Timestamp(2).internal, Timestamp(0).internal, 0, 0))
).digest() hashb = hashlib.md5(text.encode('ascii')).digest()
hashc = \ hashc = ''.join(('%02x' % (ord(a) ^ ord(b) if six.PY2 else a ^ b)
''.join(('%02x' % (ord(a) ^ ord(b)) for a, b in zip(hasha, hashb))) for a, b in zip(hasha, hashb)))
self.assertEqual(broker.get_info()['hash'], hashc) self.assertEqual(broker.get_info()['hash'], hashc)
broker.put_container('b', Timestamp(3).internal, broker.put_container('b', Timestamp(3).internal,
Timestamp(0).internal, 0, 0, Timestamp(0).internal, 0, 0,
POLICIES.default.idx) POLICIES.default.idx)
hashb = hashlib.md5( text = '%s-%s' % ('b', "%s-%s-%s-%s" % (
'%s-%s' % ('b', "%s-%s-%s-%s" % (
Timestamp(3).internal, Timestamp(0).internal, 0, 0)) Timestamp(3).internal, Timestamp(0).internal, 0, 0))
).digest() hashb = hashlib.md5(text.encode('ascii')).digest()
hashc = \ hashc = ''.join(('%02x' % (ord(a) ^ ord(b) if six.PY2 else a ^ b)
''.join(('%02x' % (ord(a) ^ ord(b)) for a, b in zip(hasha, hashb))) for a, b in zip(hasha, hashb)))
self.assertEqual(broker.get_info()['hash'], hashc) self.assertEqual(broker.get_info()['hash'], hashc)
def test_merge_items(self): def test_merge_items(self):
@ -767,7 +766,9 @@ class TestAccountBroker(unittest.TestCase):
sorted([rec['name'] for rec in items])) sorted([rec['name'] for rec in items]))
def test_merge_items_overwrite_unicode(self): def test_merge_items_overwrite_unicode(self):
snowman = u'\N{SNOWMAN}'.encode('utf-8') snowman = u'\N{SNOWMAN}'
if six.PY2:
snowman = snowman.encode('utf-8')
broker1 = AccountBroker(':memory:', account='a') broker1 = AccountBroker(':memory:', account='a')
broker1.initialize(Timestamp('1').internal, 0) broker1.initialize(Timestamp('1').internal, 0)
id1 = broker1.get_info()['id'] id1 = broker1.get_info()['id']
@ -1729,7 +1730,7 @@ class TestAccountBrokerBeforePerPolicyContainerTrack(
0, 0, int(policy)) 0, 0, int(policy))
total_container_count = self.broker.get_info()['container_count'] total_container_count = self.broker.get_info()['container_count']
self.assertEqual(total_container_count, num_containers / 2) self.assertEqual(total_container_count, num_containers // 2)
# trigger migration # trigger migration
policy_info = self.broker.get_policy_stats(do_migrations=True) policy_info = self.broker.get_policy_stats(do_migrations=True)

View File

@ -29,6 +29,8 @@ setenv = VIRTUAL_ENV={envdir}
[testenv:py35] [testenv:py35]
commands = commands =
nosetests {posargs:\ nosetests {posargs:\
test/unit/account/test_backend.py \
test/unit/account/test_utils.py \
test/unit/cli/test_dispersion_report.py \ test/unit/cli/test_dispersion_report.py \
test/unit/cli/test_form_signature.py \ test/unit/cli/test_form_signature.py \
test/unit/cli/test_info.py \ test/unit/cli/test_info.py \