From 91f938099f7faab7933df84129ac3df405e2d884 Mon Sep 17 00:00:00 2001 From: Gordon Sim Date: Tue, 24 Sep 2013 11:26:14 +0000 Subject: QPID-5156: add tests for assert functionality git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1525859 13f79535-47bb-0310-9956-ffa450edef68 --- qpid/cpp/src/tests/assertions.py | 128 +++++++++++++++++++++++++++++++++++ qpid/cpp/src/tests/swig_python_tests | 2 +- 2 files changed, 129 insertions(+), 1 deletion(-) create mode 100644 qpid/cpp/src/tests/assertions.py (limited to 'qpid/cpp') diff --git a/qpid/cpp/src/tests/assertions.py b/qpid/cpp/src/tests/assertions.py new file mode 100644 index 0000000000..6a7b4a82ef --- /dev/null +++ b/qpid/cpp/src/tests/assertions.py @@ -0,0 +1,128 @@ +# +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you 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 qpid.tests.messaging.implementation import * +from qpid.tests.messaging import VersionTest + +class AssertionTests (VersionTest): + """ + Tests for assertions with qpidd + """ + def test_queues_alternate_exchange1(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{properties:{alternate-exchange:amq.fanout}}}" % name) + self.ssn.sender("%s; {assert:always, node:{properties:{alternate-exchange:amq.fanout}}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{properties:{alternate-exchange:amq.topic}}}" % name) + assert False, "Expected assertion to fail on alternate-exchange" + except AssertionFailed: None + + def test_queues_alternate_exchange2(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{x-declare:{alternate-exchange:amq.fanout}}}" % name) + self.ssn.sender("%s; {assert:always, node:{x-declare:{alternate-exchange:amq.fanout}}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{alternate-exchange:amq.topic}}}" % name) + assert False, "Expected assertion to fail on alternate-exchange" + except AssertionFailed: None + + def test_queue_type(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always}" % name) + self.ssn.sender("%s; {assert:always, node:{type:queue}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{type:topic}}" % name) + assert False, "Expected assertion to fail on type" + except AssertionFailed: None + + def test_queue_durability(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always}" % name) + self.ssn.sender("%s; {assert:always, node:{durable:False}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{durable:True}}" % name) + assert False, "Expected assertion to fail on durability" + except AssertionFailed: None + + def test_queue_options(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{x-declare:{arguments:{foo:bar,'qpid.last_value_queue_key':abc}}}}" % name) + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{'qpid.last_value_queue_key':abc}}}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{foo:bar}}}}" % name) + assert False, "Expected assertion to fail on unrecognised option" + except AssertionFailed: None + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{'qpid.max_count':10}}}}" % name) + assert False, "Expected assertion to fail on unspecified option" + except AssertionFailed: None + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{'qpid.last_value_key':xyz}}}}" % name) + assert False, "Expected assertion to fail on option with different value" + except AssertionFailed: None + + def test_exchanges_alternate_exchange1(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{type:topic, properties:{alternate-exchange:amq.fanout}}}" % name) + self.ssn.sender("%s; {assert:always, node:{type:topic, properties:{alternate-exchange:amq.fanout}}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{properties:{alternate-exchange:amq.topic}}}" % name) + assert False, "Expected assertion to fail on alternate-exchange" + except AssertionFailed: None + + def test_exchanges_alternate_exchange2(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{type:topic, x-declare:{alternate-exchange:amq.fanout}}}" % name) + self.ssn.sender("%s; {assert:always, node:{type:topic, x-declare:{alternate-exchange:amq.fanout}}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{alternate-exchange:amq.topic}}}" % name) + assert False, "Expected assertion to fail on alternate-exchange" + except AssertionFailed: None + + def test_exchange_type(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{type:topic}}" % name) + self.ssn.sender("%s; {assert:always, node:{type:topic}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{type:queue}}" % name) + assert False, "Expected assertion to fail on type" + except AssertionFailed: None + + def test_exchange_durability(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{type:topic}}" % name) + self.ssn.sender("%s; {assert:always, node:{durable:False}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{durable:True}}" % name) + assert False, "Expected assertion to fail on durability" + except AssertionFailed: None + + def test_exchange_options(self): + name = str(uuid4()) + self.ssn.sender("%s; {create:always, node:{type:topic, x-declare:{arguments:{foo:bar,'qpid.msg_sequence':True}}}}" % name) + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{'qpid.msg_sequence':True}}}}" % name) + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{foo:bar}}}}" % name) + assert False, "Expected assertion to fail on unrecognised option" + except AssertionFailed: None + try: + self.ssn.sender("%s; {assert:always, node:{x-declare:{arguments:{'qpid.ive':True}}}}" % name) + assert False, "Expected assertion to fail on unspecified option" + except AssertionFailed: None + diff --git a/qpid/cpp/src/tests/swig_python_tests b/qpid/cpp/src/tests/swig_python_tests index 6f862ffa2d..8c7d8cfe6d 100755 --- a/qpid/cpp/src/tests/swig_python_tests +++ b/qpid/cpp/src/tests/swig_python_tests @@ -53,7 +53,7 @@ export PYTHONPATH=$PYTHONPATH:$PYTHONPATH_SWIG $QPID_PYTHON_TEST -m qpid.tests.messaging.message -m qpid_tests.broker_0_10.priority -m qpid_tests.broker_0_10.lvq -m qpid_tests.broker_0_10.new_api -b localhost:$QPID_PORT -I $srcdir/failing-amqp0-10-python-tests || FAILED=1 if [[ -a $AMQPC_LIB ]] ; then export QPID_LOAD_MODULE=$AMQPC_LIB - $QPID_PYTHON_TEST --define="protocol_version=amqp1.0" -m qpid_tests.broker_1_0 -m qpid_tests.broker_0_10.new_api -b localhost:$QPID_PORT -I $srcdir/failing-amqp1.0-python-tests || FAILED=1 + $QPID_PYTHON_TEST --define="protocol_version=amqp1.0" -m qpid_tests.broker_1_0 -m qpid_tests.broker_0_10.new_api -m assertions -b localhost:$QPID_PORT -I $srcdir/failing-amqp1.0-python-tests || FAILED=1 fi stop_broker if [[ $FAILED -eq 1 ]]; then -- cgit v1.2.1