Merge "py3: adapt account/backend.py and utils.py"
This commit is contained in:
commit
56c06557ac
@ -20,6 +20,8 @@ from uuid import uuid4
|
||||
|
||||
import sqlite3
|
||||
|
||||
import six
|
||||
|
||||
from swift.common.utils import Timestamp
|
||||
from swift.common.db import DatabaseBroker, utf8encode, zero_like
|
||||
|
||||
@ -244,7 +246,7 @@ class AccountBroker(DatabaseBroker):
|
||||
"""
|
||||
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 delete_timestamp: delete_timestamp of the container to create
|
||||
:param object_count: number of objects in the container
|
||||
@ -384,6 +386,7 @@ class AccountBroker(DatabaseBroker):
|
||||
put_timestamp, 0)
|
||||
"""
|
||||
delim_force_gte = False
|
||||
if six.PY2:
|
||||
(marker, end_marker, prefix, delimiter) = utf8encode(
|
||||
marker, end_marker, prefix, delimiter)
|
||||
if reverse:
|
||||
@ -415,7 +418,7 @@ class AccountBroker(DatabaseBroker):
|
||||
query_args.append(marker)
|
||||
# Always set back to False
|
||||
delim_force_gte = False
|
||||
elif marker and marker >= prefix:
|
||||
elif marker and (not prefix or marker >= prefix):
|
||||
query += ' name > ? AND'
|
||||
query_args.append(marker)
|
||||
elif prefix:
|
||||
|
@ -32,6 +32,8 @@ import random
|
||||
import mock
|
||||
import base64
|
||||
|
||||
import six
|
||||
|
||||
from swift.account.backend import AccountBroker
|
||||
from swift.common.utils import Timestamp
|
||||
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,
|
||||
Timestamp(0).internal, 0, 0,
|
||||
POLICIES.default.idx)
|
||||
hasha = hashlib.md5(
|
||||
'%s-%s' % ('a', "%s-%s-%s-%s" % (
|
||||
text = '%s-%s' % ('a', "%s-%s-%s-%s" % (
|
||||
Timestamp(1).internal, Timestamp(0).internal, 0, 0))
|
||||
).digest()
|
||||
hashb = hashlib.md5(
|
||||
'%s-%s' % ('b', "%s-%s-%s-%s" % (
|
||||
hasha = hashlib.md5(text.encode('ascii')).digest()
|
||||
text = '%s-%s' % ('b', "%s-%s-%s-%s" % (
|
||||
Timestamp(2).internal, Timestamp(0).internal, 0, 0))
|
||||
).digest()
|
||||
hashc = \
|
||||
''.join(('%02x' % (ord(a) ^ ord(b)) for a, b in zip(hasha, hashb)))
|
||||
hashb = hashlib.md5(text.encode('ascii')).digest()
|
||||
hashc = ''.join(('%02x' % (ord(a) ^ ord(b) if six.PY2 else a ^ b)
|
||||
for a, b in zip(hasha, hashb)))
|
||||
self.assertEqual(broker.get_info()['hash'], hashc)
|
||||
broker.put_container('b', Timestamp(3).internal,
|
||||
Timestamp(0).internal, 0, 0,
|
||||
POLICIES.default.idx)
|
||||
hashb = hashlib.md5(
|
||||
'%s-%s' % ('b', "%s-%s-%s-%s" % (
|
||||
text = '%s-%s' % ('b', "%s-%s-%s-%s" % (
|
||||
Timestamp(3).internal, Timestamp(0).internal, 0, 0))
|
||||
).digest()
|
||||
hashc = \
|
||||
''.join(('%02x' % (ord(a) ^ ord(b)) for a, b in zip(hasha, hashb)))
|
||||
hashb = hashlib.md5(text.encode('ascii')).digest()
|
||||
hashc = ''.join(('%02x' % (ord(a) ^ ord(b) if six.PY2 else a ^ b)
|
||||
for a, b in zip(hasha, hashb)))
|
||||
self.assertEqual(broker.get_info()['hash'], hashc)
|
||||
|
||||
def test_merge_items(self):
|
||||
@ -767,7 +766,9 @@ class TestAccountBroker(unittest.TestCase):
|
||||
sorted([rec['name'] for rec in items]))
|
||||
|
||||
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.initialize(Timestamp('1').internal, 0)
|
||||
id1 = broker1.get_info()['id']
|
||||
@ -1729,7 +1730,7 @@ class TestAccountBrokerBeforePerPolicyContainerTrack(
|
||||
0, 0, int(policy))
|
||||
|
||||
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
|
||||
policy_info = self.broker.get_policy_stats(do_migrations=True)
|
||||
|
Loading…
Reference in New Issue
Block a user