Merge "[zmq] Refactor make zmq_address.target_to_key a universal method"

This commit is contained in:
Jenkins 2017-01-12 15:48:56 +00:00 committed by Gerrit Code Review
commit be9d3f4182
6 changed files with 74 additions and 10 deletions

View File

@ -114,18 +114,15 @@ class DealerPublisherDirectStatic(DealerPublisherDirect):
conf, matchmaker, zmq.DEALER) conf, matchmaker, zmq.DEALER)
def acquire_connection(self, request): def acquire_connection(self, request):
target_key = zmq_address.target_to_key(
request.target, zmq_names.socket_type_str(zmq.ROUTER))
if request.msg_type in zmq_names.MULTISEND_TYPES: if request.msg_type in zmq_names.MULTISEND_TYPES:
hosts = self.routing_table.get_fanout_hosts(request.target) hosts = self.routing_table.get_fanout_hosts(request.target)
target_key = zmq_address.prefix_str(
request.target.topic,
zmq_names.socket_type_str(zmq.ROUTER))
return self.fanout_sockets.get_cached_socket(target_key, hosts, return self.fanout_sockets.get_cached_socket(target_key, hosts,
immediate=False) immediate=False)
else: else:
hosts = self.routing_table.get_all_round_robin_hosts( hosts = self.routing_table.get_all_round_robin_hosts(
request.target) request.target)
target_key = zmq_address.target_to_key(
request.target, zmq_names.socket_type_str(zmq.ROUTER))
return self.sockets_manager.get_cached_socket(target_key, hosts) return self.sockets_manager.get_cached_socket(target_key, hosts)
def _finally_unregister(self, socket, request): def _finally_unregister(self, socket, request):

View File

@ -72,8 +72,8 @@ class RoutingTableAdaptor(object):
return target_key return target_key
def get_fanout_hosts(self, target): def get_fanout_hosts(self, target):
target_key = zmq_address.prefix_str( target_key = zmq_address.target_to_key(
target.topic, zmq_names.socket_type_str(self.listener_type)) target, zmq_names.socket_type_str(self.listener_type))
LOG.debug("Processing target %s for fanout." % target_key) LOG.debug("Processing target %s for fanout." % target_key)

View File

@ -246,7 +246,7 @@ class MatchmakerDummy(MatchmakerBase):
return self.get_hosts(target, listener_type) return self.get_hosts(target, listener_type)
def get_hosts_fanout(self, target, listener_type): def get_hosts_fanout(self, target, listener_type):
key = zmq_address.prefix_str(target.topic, listener_type) key = zmq_address.target_to_key(target, listener_type)
hosts = list(self._cache[key]) hosts = list(self._cache[key])
LOG.debug("[Dummy] get_hosts_fanout for target %(target)s: %(hosts)s", LOG.debug("[Dummy] get_hosts_fanout for target %(target)s: %(hosts)s",

View File

@ -224,7 +224,7 @@ class MatchmakerRedisBase(zmq_matchmaker_base.MatchmakerBase):
return self._retry_method(target, listener_type, self.get_hosts) return self._retry_method(target, listener_type, self.get_hosts)
def get_hosts_fanout(self, target, listener_type): def get_hosts_fanout(self, target, listener_type):
key = zmq_address.prefix_str(target.topic, listener_type) key = zmq_address.target_to_key(target, listener_type)
hosts = list(self._smembers(key)) hosts = list(self._smembers(key))
LOG.debug("[Redis] get_hosts_fanout for target %(target)s: %(hosts)s", LOG.debug("[Redis] get_hosts_fanout for target %(target)s: %(hosts)s",

View File

@ -33,7 +33,7 @@ def prefix_str(key, listener_type):
def target_to_key(target, listener_type=None): def target_to_key(target, listener_type=None):
key = target.topic key = target.topic
if target.server: if target.server and not target.fanout:
# FIXME(ozamiatin): Workaround for Cinder. # FIXME(ozamiatin): Workaround for Cinder.
# Remove split when Bug #1630975 is being fixed. # Remove split when Bug #1630975 is being fixed.
key += "/" + target.server.split('@')[0] key += "/" + target.server.split('@')[0]

View File

@ -0,0 +1,67 @@
# Copyright 2016 Mirantis, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import testscenarios
import testtools
import oslo_messaging
from oslo_messaging._drivers.zmq_driver import zmq_address
from oslo_messaging._drivers.zmq_driver import zmq_async
from oslo_messaging._drivers.zmq_driver import zmq_names
from oslo_messaging.tests import utils as test_utils
zmq = zmq_async.import_zmq()
load_tests = testscenarios.load_tests_apply_scenarios
class TestZmqAddress(test_utils.BaseTestCase):
scenarios = [
('router', {'listener_type': zmq_names.socket_type_str(zmq.ROUTER)}),
('dealer', {'listener_type': zmq_names.socket_type_str(zmq.DEALER)})
]
@testtools.skipIf(zmq is None, "zmq not available")
def test_target_to_key_topic_only(self):
target = oslo_messaging.Target(topic='topic')
key = zmq_address.target_to_key(target, self.listener_type)
self.assertEqual(self.listener_type + '/topic', key)
@testtools.skipIf(zmq is None, "zmq not available")
def test_target_to_key_topic_server_round_robin(self):
target = oslo_messaging.Target(topic='topic', server='server')
key = zmq_address.target_to_key(target, self.listener_type)
self.assertEqual(self.listener_type + '/topic/server', key)
@testtools.skipIf(zmq is None, "zmq not available")
def test_target_to_key_topic_fanout(self):
target = oslo_messaging.Target(topic='topic', fanout=True)
key = zmq_address.target_to_key(target, self.listener_type)
self.assertEqual(self.listener_type + '/topic', key)
@testtools.skipIf(zmq is None, "zmq not available")
def test_target_to_key_topic_server_fanout(self):
target = oslo_messaging.Target(topic='topic', server='server',
fanout=True)
key = zmq_address.target_to_key(target, self.listener_type)
self.assertEqual(self.listener_type + '/topic', key)
@testtools.skipIf(zmq is None, "zmq not available")
def test_target_to_key_topic_server_fanout_no_prefix(self):
target = oslo_messaging.Target(topic='topic', server='server',
fanout=True)
key = zmq_address.target_to_key(target)
self.assertEqual('topic', key)