Clean up for qpid tests

Use the config object in the base class, and define a local
base class for managing connections instead of repeating
that code in several places.

Change-Id: I7816a467da449ba172dbaa23e58b511adc1ba40a
This commit is contained in:
Doug Hellmann 2014-02-28 14:06:55 -08:00 committed by Ihar Hrachyshka
parent 66bb4f3cc6
commit 57ebe0d83d
3 changed files with 95 additions and 181 deletions

View File

@ -46,6 +46,10 @@ class ConfFixture(fixtures.Fixture):
self.conf = conf self.conf = conf
_import_opts(self.conf, _import_opts(self.conf,
'oslo.messaging._drivers.impl_rabbit', 'rabbit_opts') 'oslo.messaging._drivers.impl_rabbit', 'rabbit_opts')
_import_opts(self.conf,
'oslo.messaging._drivers.impl_qpid', 'qpid_opts')
_import_opts(self.conf,
'oslo.messaging._drivers.amqp', 'amqp_opts')
_import_opts(self.conf, 'oslo.messaging.rpc.client', '_client_opts') _import_opts(self.conf, 'oslo.messaging.rpc.client', '_client_opts')
_import_opts(self.conf, 'oslo.messaging.transport', '_transport_opts') _import_opts(self.conf, 'oslo.messaging.transport', '_transport_opts')

View File

@ -11,6 +11,9 @@ testscenarios>=0.4
testtools>=0.9.34 testtools>=0.9.34
oslotest oslotest
# for test_qpid
qpid-python
# when we can require tox>= 1.4, this can go into tox.ini: # when we can require tox>= 1.4, this can go into tox.ini:
# [testenv:cover] # [testenv:cover]
# deps = {[testenv]deps} coverage # deps = {[testenv]deps} coverage
@ -19,4 +22,3 @@ coverage>=3.6
# this is required for the docs build jobs # this is required for the docs build jobs
sphinx>=1.1.2,<1.2 sphinx>=1.1.2,<1.2
oslosphinx oslosphinx
qpid-python

View File

@ -20,7 +20,6 @@ import time
import qpid import qpid
import testscenarios import testscenarios
from oslo.config import cfg
from oslo import messaging from oslo import messaging
from oslo.messaging._drivers import impl_qpid as qpid_driver from oslo.messaging._drivers import impl_qpid as qpid_driver
from tests import utils as test_utils from tests import utils as test_utils
@ -60,128 +59,11 @@ def _is_qpidd_service_running():
return qpid_running return qpid_running
class TestQpidInvalidTopologyVersion(test_utils.BaseTestCase): class _QpidBaseTestCase(test_utils.BaseTestCase):
"""Unit test cases to test invalid qpid topology version."""
scenarios = [
('direct', dict(consumer_cls=qpid_driver.DirectConsumer,
publisher_cls=qpid_driver.DirectPublisher)),
('topic', dict(consumer_cls=qpid_driver.TopicConsumer,
publisher_cls=qpid_driver.TopicPublisher)),
('fanout', dict(consumer_cls=qpid_driver.FanoutConsumer,
publisher_cls=qpid_driver.FanoutPublisher)),
]
def setUp(self): def setUp(self):
super(TestQpidInvalidTopologyVersion, self).setUp() super(_QpidBaseTestCase, self).setUp()
self.messaging_conf.transport_driver = 'qpid'
self.qpid_opts = [
cfg.BoolOpt('amqp_durable_queues',
default=False,
deprecated_name='rabbit_durable_queues',
deprecated_group='DEFAULT',
help='Use durable queues in amqp.'),
cfg.BoolOpt('amqp_auto_delete',
default=False,
help='Auto-delete queues in amqp.'),
cfg.IntOpt('qpid_topology_version',
default=-1,
help='qpid topology version'),
cfg.StrOpt('control_exchange',
default='openstack',
help='AMQP exchange to connect to if using Qpid'),
]
self.qpid_conf = cfg.ConfigOpts()
self.qpid_conf.register_opts(self.qpid_opts)
self.fake_qpid = not _is_qpidd_service_running()
if self.fake_qpid:
self.session = get_fake_qpid_session()
else:
self.broker = QPID_BROKER
# create connection from the qpid.messaging
self.connection = qpid.messaging.Connection(self.broker)
self.connection.open()
self.session = self.connection.session()
def tearDown(self):
self.qpid_conf.unregister_opts(self.qpid_opts)
super(TestQpidInvalidTopologyVersion, self).tearDown()
if self.fake_qpid:
_fake_session.flush_exchanges()
else:
self.connection.close()
def test_invalid_topology_version(self):
def consumer_callback(msg):
pass
msgid_or_topic = 'test'
# not using self.assertRaises because
# 1. qpid driver raises Exception(msg) for invalid topology version
# 2. flake8 - H202 assertRaises Exception too broad
exception_msg = ("Invalid value for qpid_topology_version: %d" %
self.qpid_conf.qpid_topology_version)
recvd_exc_msg = ''
try:
self.consumer_cls(self.qpid_conf, self.session, msgid_or_topic,
consumer_callback)
except Exception as e:
recvd_exc_msg = e.message
self.assertEqual(exception_msg, recvd_exc_msg)
recvd_exc_msg = ''
try:
self.publisher_cls(self.qpid_conf, self.session, msgid_or_topic)
except Exception as e:
recvd_exc_msg = e.message
self.assertEqual(exception_msg, recvd_exc_msg)
class TestQpidDirectConsumerPublisher(test_utils.BaseTestCase):
"""Unit test cases to test DirectConsumer and Direct Publisher."""
_n_qpid_topology = [
('v1', dict(qpid_topology=1)),
('v2', dict(qpid_topology=2)),
]
_n_msgs = [
('single', dict(no_msgs=1)),
('multiple', dict(no_msgs=10)),
]
@classmethod
def generate_scenarios(cls):
cls.scenarios = testscenarios.multiply_scenarios(cls._n_qpid_topology,
cls._n_msgs)
def setUp(self):
super(TestQpidDirectConsumerPublisher, self).setUp()
self.qpid_opts = [
cfg.BoolOpt('amqp_durable_queues',
default=False,
deprecated_name='rabbit_durable_queues',
deprecated_group='DEFAULT',
help='Use durable queues in amqp.'),
cfg.BoolOpt('amqp_auto_delete',
default=False,
help='Auto-delete queues in amqp.'),
cfg.IntOpt('qpid_topology_version',
default=self.qpid_topology,
help='qpid topology version'),
]
self.qpid_conf = cfg.ConfigOpts()
self.qpid_conf.register_opts(self.qpid_opts)
self.fake_qpid = not _is_qpidd_service_running() self.fake_qpid = not _is_qpidd_service_running()
if self.fake_qpid: if self.fake_qpid:
@ -206,17 +88,87 @@ class TestQpidDirectConsumerPublisher(test_utils.BaseTestCase):
# the actual received messages # the actual received messages
self._expected = [] self._expected = []
self._messages = [] self._messages = []
self.initialized = True
def tearDown(self): def tearDown(self):
self.qpid_conf.unregister_opts(self.qpid_opts) super(_QpidBaseTestCase, self).tearDown()
super(TestQpidDirectConsumerPublisher, self).tearDown()
if self.initialized:
if self.fake_qpid: if self.fake_qpid:
_fake_session.flush_exchanges() _fake_session.flush_exchanges()
else: else:
self.con_receive.close() self.con_receive.close()
self.con_send.close() self.con_send.close()
class TestQpidInvalidTopologyVersion(_QpidBaseTestCase):
"""Unit test cases to test invalid qpid topology version."""
scenarios = [
('direct', dict(consumer_cls=qpid_driver.DirectConsumer,
publisher_cls=qpid_driver.DirectPublisher)),
('topic', dict(consumer_cls=qpid_driver.TopicConsumer,
publisher_cls=qpid_driver.TopicPublisher)),
('fanout', dict(consumer_cls=qpid_driver.FanoutConsumer,
publisher_cls=qpid_driver.FanoutPublisher)),
]
def setUp(self):
super(TestQpidInvalidTopologyVersion, self).setUp()
self.config(qpid_topology_version=-1)
def test_invalid_topology_version(self):
def consumer_callback(msg):
pass
msgid_or_topic = 'test'
# not using self.assertRaises because
# 1. qpid driver raises Exception(msg) for invalid topology version
# 2. flake8 - H202 assertRaises Exception too broad
exception_msg = ("Invalid value for qpid_topology_version: %d" %
self.messaging_conf.conf.qpid_topology_version)
recvd_exc_msg = ''
try:
self.consumer_cls(self.messaging_conf.conf,
self.session_receive,
msgid_or_topic,
consumer_callback)
except Exception as e:
recvd_exc_msg = e.message
self.assertEqual(exception_msg, recvd_exc_msg)
recvd_exc_msg = ''
try:
self.publisher_cls(self.messaging_conf.conf,
self.session_send,
msgid_or_topic)
except Exception as e:
recvd_exc_msg = e.message
self.assertEqual(exception_msg, recvd_exc_msg)
class TestQpidDirectConsumerPublisher(_QpidBaseTestCase):
"""Unit test cases to test DirectConsumer and Direct Publisher."""
_n_qpid_topology = [
('v1', dict(qpid_topology=1)),
('v2', dict(qpid_topology=2)),
]
_n_msgs = [
('single', dict(no_msgs=1)),
('multiple', dict(no_msgs=10)),
]
@classmethod
def generate_scenarios(cls):
cls.scenarios = testscenarios.multiply_scenarios(cls._n_qpid_topology,
cls._n_msgs)
def consumer_callback(self, msg): def consumer_callback(self, msg):
# This function will be called by the DirectConsumer # This function will be called by the DirectConsumer
# when any message is received. # when any message is received.
@ -232,11 +184,11 @@ class TestQpidDirectConsumerPublisher(test_utils.BaseTestCase):
self.msgid = str(random.randint(1, 100)) self.msgid = str(random.randint(1, 100))
# create a DirectConsumer and DirectPublisher class objects # create a DirectConsumer and DirectPublisher class objects
self.dir_cons = qpid_driver.DirectConsumer(self.qpid_conf, self.dir_cons = qpid_driver.DirectConsumer(self.messaging_conf.conf,
self.session_receive, self.session_receive,
self.msgid, self.msgid,
self.consumer_callback) self.consumer_callback)
self.dir_pub = qpid_driver.DirectPublisher(self.qpid_conf, self.dir_pub = qpid_driver.DirectPublisher(self.messaging_conf.conf,
self.session_send, self.session_send,
self.msgid) self.msgid)
@ -267,7 +219,7 @@ class TestQpidDirectConsumerPublisher(test_utils.BaseTestCase):
TestQpidDirectConsumerPublisher.generate_scenarios() TestQpidDirectConsumerPublisher.generate_scenarios()
class TestQpidTopicAndFanout(test_utils.BaseTestCase): class TestQpidTopicAndFanout(_QpidBaseTestCase):
"""Unit Test cases to test TopicConsumer and """Unit Test cases to test TopicConsumer and
TopicPublisher classes of the qpid driver TopicPublisher classes of the qpid driver
and FanoutConsumer and FanoutPublisher classes and FanoutConsumer and FanoutPublisher classes
@ -312,48 +264,13 @@ class TestQpidTopicAndFanout(test_utils.BaseTestCase):
cls._exchange_class) cls._exchange_class)
def setUp(self): def setUp(self):
self.qpid_opts = [
cfg.BoolOpt('amqp_durable_queues',
default=False,
deprecated_name='rabbit_durable_queues',
deprecated_group='DEFAULT',
help='Use durable queues in amqp.'),
cfg.BoolOpt('amqp_auto_delete',
default=False,
help='Auto-delete queues in amqp.'),
cfg.IntOpt('qpid_topology_version',
default=self.qpid_topology,
help='qpid topology version'),
cfg.StrOpt('control_exchange',
default='openstack',
help='AMQP exchange to connect to if using Qpid'),
]
super(TestQpidTopicAndFanout, self).setUp() super(TestQpidTopicAndFanout, self).setUp()
self.qpid_conf = cfg.ConfigOpts()
self.qpid_conf.register_opts(self.qpid_opts)
self._fake_qpid = not _is_qpidd_service_running()
if self._fake_qpid:
self.session_receive = get_fake_qpid_session()
self.session_send = get_fake_qpid_session()
else:
self.broker = QPID_BROKER
# connection for the Consumer.
self.con_receive = qpid.messaging.Connection(self.broker)
self.con_receive.open()
# session to receive the messages
self.session_receive = self.con_receive.session()
# connection for sending the message
self.con_send = qpid.messaging.Connection(self.broker)
self.con_send.open()
# session to send the messages
self.session_send = self.con_send.session()
# to store the expected messages and the # to store the expected messages and the
# actual received messages # actual received messages
#
# NOTE(dhellmann): These are dicts, where the base class uses
# lists.
self._expected = {} self._expected = {}
self._messages = {} self._messages = {}
@ -363,15 +280,6 @@ class TestQpidTopicAndFanout(test_utils.BaseTestCase):
self._sender_threads = [] self._sender_threads = []
self._receiver_threads = [] self._receiver_threads = []
def tearDown(self):
self.qpid_conf.unregister_opts(self.qpid_opts)
super(TestQpidTopicAndFanout, self).tearDown()
if self._fake_qpid:
_fake_session.flush_exchanges()
else:
self.con_receive.close()
self.con_send.close()
def consumer_callback(self, msg): def consumer_callback(self, msg):
"""callback function called by the ConsumerBase class of """callback function called by the ConsumerBase class of
qpid driver. qpid driver.
@ -432,7 +340,7 @@ class TestQpidTopicAndFanout(test_utils.BaseTestCase):
def test_qpid_topic_and_fanout(self): def test_qpid_topic_and_fanout(self):
for receiver_id in range(self.no_receivers): for receiver_id in range(self.no_receivers):
consumer = self.consumer_cls(self.qpid_conf, consumer = self.consumer_cls(self.messaging_conf.conf,
self.session_receive, self.session_receive,
self.receive_topic, self.receive_topic,
self.consumer_callback) self.consumer_callback)
@ -444,7 +352,7 @@ class TestQpidTopicAndFanout(test_utils.BaseTestCase):
self._receiver_threads.append(thread) self._receiver_threads.append(thread)
for sender_id in range(self.no_senders): for sender_id in range(self.no_senders):
publisher = self.publisher_cls(self.qpid_conf, publisher = self.publisher_cls(self.messaging_conf.conf,
self.session_send, self.session_send,
self.topic) self.topic)
self._senders.append(publisher) self._senders.append(publisher)