Former-commit-id:a02aeb236c
[formerly9f19e3f712
] [formerly06a8b51d6d
[formerly 64fa9254b946eae7e61bbc3f513b7c3696c4f54f]] Former-commit-id:06a8b51d6d
Former-commit-id:3360eb6c5f
224 lines
11 KiB
Python
224 lines
11 KiB
Python
#
|
|
# 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.client import Client, Closed
|
|
from qpid.queue import Empty
|
|
from qpid.content import Content
|
|
from qpid.testlib import TestBase
|
|
|
|
class QueryTests(TestBase):
|
|
"""Tests for various query methods introduced in 0-10 and available in 0-9 for preview"""
|
|
|
|
def test_exchange_query(self):
|
|
"""
|
|
Test that the exchange_query method works as expected
|
|
"""
|
|
channel = self.channel
|
|
#check returned type for the standard exchanges
|
|
self.assertEqual("direct", channel.exchange_query(name="amq.direct").type)
|
|
self.assertEqual("topic", channel.exchange_query(name="amq.topic").type)
|
|
self.assertEqual("fanout", channel.exchange_query(name="amq.fanout").type)
|
|
self.assertEqual("headers", channel.exchange_query(name="amq.match").type)
|
|
self.assertEqual("direct", channel.exchange_query(name="").type)
|
|
#declare an exchange
|
|
channel.exchange_declare(exchange="my-test-exchange", type= "direct", durable=False)
|
|
#check that the result of a query is as expected
|
|
response = channel.exchange_query(name="my-test-exchange")
|
|
self.assertEqual("direct", response.type)
|
|
self.assertEqual(False, response.durable)
|
|
self.assertEqual(False, response.not_found)
|
|
#delete the exchange
|
|
channel.exchange_delete(exchange="my-test-exchange")
|
|
#check that the query now reports not-found
|
|
self.assertEqual(True, channel.exchange_query(name="my-test-exchange").not_found)
|
|
|
|
def test_binding_query_direct(self):
|
|
"""
|
|
Test that the binding_query method works as expected with the direct exchange
|
|
"""
|
|
self.binding_query_with_key("amq.direct")
|
|
|
|
def test_binding_query_topic(self):
|
|
"""
|
|
Test that the binding_query method works as expected with the direct exchange
|
|
"""
|
|
self.binding_query_with_key("amq.topic")
|
|
|
|
def binding_query_with_key(self, exchange_name):
|
|
channel = self.channel
|
|
#setup: create two queues
|
|
channel.queue_declare(queue="used-queue", exclusive=True)
|
|
channel.queue_declare(queue="unused-queue", exclusive=True)
|
|
|
|
channel.queue_bind(exchange=exchange_name, queue="used-queue", routing_key="used-key")
|
|
|
|
# test detection of any binding to specific queue
|
|
response = channel.binding_query(exchange=exchange_name, queue="used-queue")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
|
|
# test detection of specific binding to any queue
|
|
response = channel.binding_query(exchange=exchange_name, routing_key="used-key")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.key_not_matched)
|
|
|
|
# test detection of specific binding to specific queue
|
|
response = channel.binding_query(exchange=exchange_name, queue="used-queue", routing_key="used-key")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
self.assertEqual(False, response.key_not_matched)
|
|
|
|
# test unmatched queue, unspecified binding
|
|
response = channel.binding_query(exchange=exchange_name, queue="unused-queue")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
|
|
# test unspecified queue, unmatched binding
|
|
response = channel.binding_query(exchange=exchange_name, routing_key="unused-key")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.key_not_matched)
|
|
|
|
# test matched queue, unmatched binding
|
|
response = channel.binding_query(exchange=exchange_name, queue="used-queue", routing_key="unused-key")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
self.assertEqual(True, response.key_not_matched)
|
|
|
|
# test unmatched queue, matched binding
|
|
response = channel.binding_query(exchange=exchange_name, queue="unused-queue", routing_key="used-key")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
self.assertEqual(False, response.key_not_matched)
|
|
|
|
# test unmatched queue, unmatched binding
|
|
response = channel.binding_query(exchange=exchange_name, queue="unused-queue", routing_key="unused-key")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
self.assertEqual(True, response.key_not_matched)
|
|
|
|
#test exchange not found
|
|
self.assertEqual(True, channel.binding_query(exchange="unknown-exchange").exchange_not_found)
|
|
|
|
#test queue not found
|
|
self.assertEqual(True, channel.binding_query(exchange=exchange_name, queue="unknown-queue").queue_not_found)
|
|
|
|
|
|
def test_binding_query_fanout(self):
|
|
"""
|
|
Test that the binding_query method works as expected with fanout exchange
|
|
"""
|
|
channel = self.channel
|
|
#setup
|
|
channel.queue_declare(queue="used-queue", exclusive=True)
|
|
channel.queue_declare(queue="unused-queue", exclusive=True)
|
|
channel.queue_bind(exchange="amq.fanout", queue="used-queue")
|
|
|
|
# test detection of any binding to specific queue
|
|
response = channel.binding_query(exchange="amq.fanout", queue="used-queue")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
|
|
# test unmatched queue, unspecified binding
|
|
response = channel.binding_query(exchange="amq.fanout", queue="unused-queue")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
|
|
#test exchange not found
|
|
self.assertEqual(True, channel.binding_query(exchange="unknown-exchange").exchange_not_found)
|
|
|
|
#test queue not found
|
|
self.assertEqual(True, channel.binding_query(exchange="amq.fanout", queue="unknown-queue").queue_not_found)
|
|
|
|
def test_binding_query_header(self):
|
|
"""
|
|
Test that the binding_query method works as expected with headers exchanges
|
|
"""
|
|
channel = self.channel
|
|
#setup
|
|
channel.queue_declare(queue="used-queue", exclusive=True)
|
|
channel.queue_declare(queue="unused-queue", exclusive=True)
|
|
channel.queue_bind(exchange="amq.match", queue="used-queue", arguments={"x-match":"all", "a":"A"} )
|
|
|
|
# test detection of any binding to specific queue
|
|
response = channel.binding_query(exchange="amq.match", queue="used-queue")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
|
|
# test detection of specific binding to any queue
|
|
response = channel.binding_query(exchange="amq.match", arguments={"x-match":"all", "a":"A"})
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.args_not_matched)
|
|
|
|
# test detection of specific binding to specific queue
|
|
response = channel.binding_query(exchange="amq.match", queue="used-queue", arguments={"x-match":"all", "a":"A"})
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
self.assertEqual(False, response.args_not_matched)
|
|
|
|
# test unmatched queue, unspecified binding
|
|
response = channel.binding_query(exchange="amq.match", queue="unused-queue")
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
|
|
# test unspecified queue, unmatched binding
|
|
response = channel.binding_query(exchange="amq.match", arguments={"x-match":"all", "b":"B"})
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.args_not_matched)
|
|
|
|
# test matched queue, unmatched binding
|
|
response = channel.binding_query(exchange="amq.match", queue="used-queue", arguments={"x-match":"all", "b":"B"})
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(False, response.queue_not_matched)
|
|
self.assertEqual(True, response.args_not_matched)
|
|
|
|
# test unmatched queue, matched binding
|
|
response = channel.binding_query(exchange="amq.match", queue="unused-queue", arguments={"x-match":"all", "a":"A"})
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
self.assertEqual(False, response.args_not_matched)
|
|
|
|
# test unmatched queue, unmatched binding
|
|
response = channel.binding_query(exchange="amq.match", queue="unused-queue", arguments={"x-match":"all", "b":"B"})
|
|
self.assertEqual(False, response.exchange_not_found)
|
|
self.assertEqual(False, response.queue_not_found)
|
|
self.assertEqual(True, response.queue_not_matched)
|
|
self.assertEqual(True, response.args_not_matched)
|
|
|
|
#test exchange not found
|
|
self.assertEqual(True, channel.binding_query(exchange="unknown-exchange").exchange_not_found)
|
|
|
|
#test queue not found
|
|
self.assertEqual(True, channel.binding_query(exchange="amq.match", queue="unknown-queue").queue_not_found)
|
|
|