Merge "Cleanup db replicator probetest"

This commit is contained in:
Jenkins 2017-06-12 21:13:15 +00:00 committed by Gerrit Code Review
commit 75c1bea7a5

View File

@ -20,7 +20,7 @@ from swiftclient import client, ClientException
from test.probe.common import kill_server, ReplProbeTest, start_server from test.probe.common import kill_server, ReplProbeTest, start_server
from swift.common import direct_client, utils from swift.common import direct_client, utils
from swift.common.manager import Server from swift.common.manager import Manager
class TestDbUsyncReplicator(ReplProbeTest): class TestDbUsyncReplicator(ReplProbeTest):
@ -85,10 +85,8 @@ class TestDbUsyncReplicator(ReplProbeTest):
# runs in first, db file may be replicated by rsync to other # runs in first, db file may be replicated by rsync to other
# containers. In that case, the db file does not information about # containers. In that case, the db file does not information about
# metadata, so metadata should be synced before replication # metadata, so metadata should be synced before replication
crepl = Server('container-replicator') Manager(['container-replicator']).once(
crepl.spawn(self.configs['container-replicator'][cnode['id'] + 1], number=self.config_number(cnode))
once=True)
crepl.interact()
expected_meta = { expected_meta = {
'x-container-meta-a': '2', 'x-container-meta-a': '2',
@ -124,6 +122,21 @@ class TestDbUsyncReplicator(ReplProbeTest):
self.assertNotIn(resp_headers.get('x-container-object-count'), self.assertNotIn(resp_headers.get('x-container-object-count'),
(None, '0', 0)) (None, '0', 0))
# and after full pass on remaining nodes
for node in cnodes:
Manager(['container-replicator']).once(
number=self.config_number(node))
# ... all is right
for node in cnodes + [cnode]:
resp_headers = direct_client.direct_head_container(
node, cpart, self.account, container)
for header, value in expected_meta.items():
self.assertIn(header, resp_headers)
self.assertEqual(value, resp_headers[header])
self.assertNotIn(resp_headers.get('x-container-object-count'),
(None, '0', 0))
class TestDbRsyncReplicator(TestDbUsyncReplicator): class TestDbRsyncReplicator(TestDbUsyncReplicator):
def setUp(self): def setUp(self):