ea106e9a09
Some tempest tests were failing because of NoSuchMethod, UnsupportedVersion and other missed endpoint errors. This fix provides new listener per each target and more straight-forward matchmaker target resolution logic. Change-Id: I4bfb42048630a0eab075e462ad1e22ebe9a45820 Closes-Bug: #1501682
70 lines
1.9 KiB
Python
70 lines
1.9 KiB
Python
# Copyright 2015 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.
|
|
|
|
from oslo_messaging._drivers.zmq_driver import zmq_async
|
|
|
|
zmq = zmq_async.import_zmq()
|
|
|
|
|
|
FIELD_TYPE = 'type'
|
|
FIELD_FAILURE = 'failure'
|
|
FIELD_REPLY = 'reply'
|
|
FIELD_LOG_FAILURE = 'log_failure'
|
|
FIELD_ID = 'id'
|
|
FIELD_MSG_ID = 'message_id'
|
|
FIELD_MSG_TYPE = 'msg_type'
|
|
FIELD_REPLY_ID = 'reply_id'
|
|
FIELD_TARGET = 'target'
|
|
|
|
|
|
IDX_REPLY_TYPE = 1
|
|
IDX_REPLY_BODY = 2
|
|
|
|
MULTIPART_IDX_ENVELOPE = 0
|
|
MULTIPART_IDX_BODY = 1
|
|
|
|
|
|
CALL_TYPE = 'call'
|
|
CAST_TYPE = 'cast'
|
|
CAST_FANOUT_TYPE = 'cast-f'
|
|
NOTIFY_TYPE = 'notify'
|
|
NOTIFY_FANOUT_TYPE = 'notify-f'
|
|
|
|
REPLY_TYPE = 'reply'
|
|
ACK_TYPE = 'ack'
|
|
|
|
MESSAGE_TYPES = (CALL_TYPE,
|
|
CAST_TYPE,
|
|
CAST_FANOUT_TYPE,
|
|
NOTIFY_TYPE,
|
|
NOTIFY_FANOUT_TYPE)
|
|
|
|
MULTISEND_TYPES = (CAST_FANOUT_TYPE, NOTIFY_FANOUT_TYPE)
|
|
DIRECT_TYPES = (CALL_TYPE, CAST_TYPE, NOTIFY_TYPE)
|
|
CAST_TYPES = (CAST_TYPE, CAST_FANOUT_TYPE)
|
|
NOTIFY_TYPES = (NOTIFY_TYPE, NOTIFY_FANOUT_TYPE)
|
|
NON_BLOCKING_TYPES = CAST_TYPES + NOTIFY_TYPES
|
|
|
|
|
|
def socket_type_str(socket_type):
|
|
zmq_socket_str = {zmq.DEALER: "DEALER",
|
|
zmq.ROUTER: "ROUTER",
|
|
zmq.PUSH: "PUSH",
|
|
zmq.PULL: "PULL",
|
|
zmq.REQ: "REQ",
|
|
zmq.REP: "REP",
|
|
zmq.PUB: "PUB",
|
|
zmq.SUB: "SUB"}
|
|
return zmq_socket_str[socket_type]
|