diff options
| author | Gordon Sim <gsim@apache.org> | 2006-09-22 09:53:47 +0000 |
|---|---|---|
| committer | Gordon Sim <gsim@apache.org> | 2006-09-22 09:53:47 +0000 |
| commit | 924764a6a8dbcb0a2dd7a432221987302b389af8 (patch) | |
| tree | 06f5fdf4845fd07fbbbbec24f8de324b37666bef /qpid/python/tests/basic.py | |
| parent | 69717c3785632ae8c1f85a5e8ee07def87be2ef6 (diff) | |
| download | qpid-python-924764a6a8dbcb0a2dd7a432221987302b389af8.tar.gz | |
Added tests for basic_cancel and for handling of invalid channel ids.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@448881 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/python/tests/basic.py')
| -rw-r--r-- | qpid/python/tests/basic.py | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/qpid/python/tests/basic.py b/qpid/python/tests/basic.py index c3a2414eac..75d49ec805 100644 --- a/qpid/python/tests/basic.py +++ b/qpid/python/tests/basic.py @@ -113,3 +113,27 @@ class BasicTests(TestBase): except Closed, e: self.assertConnectionException(530, e.args[0]) + def test_basic_cancel(self): + """ + Test compliance of the basic.cancel method + """ + channel = self.channel + #setup, declare a queue: + channel.queue_declare(queue="test-queue-4", exclusive=True) + channel.basic_consume(consumer_tag="my-consumer", queue="test-queue-4") + channel.basic_publish(routing_key="test-queue-4", content=Content("One")) + + #cancel should stop messages being delivered + channel.basic_cancel(consumer_tag="my-consumer") + channel.basic_publish(routing_key="test-queue-4", content=Content("Two")) + myqueue = self.client.queue("my-consumer") + msg = myqueue.get(timeout=1) + self.assertEqual("One", msg.content.body) + try: + msg = myqueue.get(timeout=1) + self.fail("Got message after cancellation: " + msg) + except Empty: None + + #cancellation of non-existant consumers should be handled without error + channel.basic_cancel(consumer_tag="my-consumer") + channel.basic_cancel(consumer_tag="this-never-existed") |
