diff options
| author | Gordon Sim <gsim@apache.org> | 2013-09-24 11:26:14 +0000 |
|---|---|---|
| committer | Gordon Sim <gsim@apache.org> | 2013-09-24 11:26:14 +0000 |
| commit | 91f938099f7faab7933df84129ac3df405e2d884 (patch) | |
| tree | 59ceb0d039c1d91f893123ee277a12902989f028 /qpid/cpp/src | |
| parent | f3e17e36a7fec1bffc37b5d9467d3af414eabf3c (diff) | |
| download | qpid-python-91f938099f7faab7933df84129ac3df405e2d884.tar.gz | |
QPID-5156: add tests for assert functionality
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1525859 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src')
| -rw-r--r-- | qpid/cpp/src/tests/assertions.py | 128 | ||||
| -rwxr-xr-x | qpid/cpp/src/tests/swig_python_tests | 2 |
2 files changed, 129 insertions, 1 deletions
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 |
