
In this change router was redesigned in a way most appropriate for routing concept of zmq.ROUTER socket. DEALER(cli)-ROUTER(proxy)-DEALER(srv) instead of DEALER-ROUTER-DEALER-ROUTER (3 layers instead of 4) The main reason is to use zmq.DEALER identity in message routing. For this reason DealerConsumer was introduced server-side. RouterConsumer is left for peer-to-peer DEALER-ROUTER deployment option. Also handled assertions in receive-methods in order to not stop server when received message with wrong format. Change-Id: If25edf500fa8d220d4233bb13d67121824e841c6 Closes-Bug: #1558601 Related-Bug: #1555007
56 lines
1.8 KiB
Python
56 lines
1.8 KiB
Python
# 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 logging
|
|
import os
|
|
import sys
|
|
|
|
from oslo_messaging.tests.functional.zmq import multiproc_utils
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class StartupOrderTestCase(multiproc_utils.MutliprocTestCase):
|
|
|
|
def setUp(self):
|
|
super(StartupOrderTestCase, self).setUp()
|
|
|
|
self.conf.prog = "test_prog"
|
|
self.conf.project = "test_project"
|
|
|
|
kwargs = {'rpc_response_timeout': 30}
|
|
self.config(**kwargs)
|
|
|
|
log_path = self.conf.rpc_zmq_ipc_dir + "/" + str(os.getpid()) + ".log"
|
|
sys.stdout = open(log_path, "w", buffering=0)
|
|
|
|
def test_call_server_before_client(self):
|
|
self.spawn_servers(3, wait_for_server=True, random_topic=False)
|
|
servers = self.spawned
|
|
client = self.get_client(servers[0].topic)
|
|
for i in range(3):
|
|
reply = client.call_a()
|
|
self.assertIsNotNone(reply)
|
|
self.assertEqual(3, len(client.replies))
|
|
|
|
def test_call_client_dont_wait_for_server(self):
|
|
self.spawn_servers(3, wait_for_server=False, random_topic=False)
|
|
servers = self.spawned
|
|
client = self.get_client(servers[0].topic)
|
|
for i in range(3):
|
|
reply = client.call_a()
|
|
self.assertIsNotNone(reply)
|
|
self.assertEqual(3, len(client.replies))
|