From 14654e5360b72adf1704838b3820c7d1fc860e8e Mon Sep 17 00:00:00 2001 From: Gordon Sim Date: Fri, 6 Oct 2006 16:17:06 +0000 Subject: Decoupled routing from the channel and message classes. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@453657 13f79535-47bb-0310-9956-ffa450edef68 --- cpp/broker/test/RouterTest.cpp | 91 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 91 insertions(+) create mode 100644 cpp/broker/test/RouterTest.cpp (limited to 'cpp/broker/test/RouterTest.cpp') diff --git a/cpp/broker/test/RouterTest.cpp b/cpp/broker/test/RouterTest.cpp new file mode 100644 index 0000000000..284a28f583 --- /dev/null +++ b/cpp/broker/test/RouterTest.cpp @@ -0,0 +1,91 @@ +/* + * + * Copyright (c) 2006 The Apache Software Foundation + * + * Licensed 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. + * + */ +#include "Channel.h" +#include "Exchange.h" +#include "ExchangeRegistry.h" +#include "Message.h" +#include "Router.h" +#include +#include +#include +#include +#include +#include + +using namespace qpid::broker; +using namespace qpid::framing; +using namespace qpid::concurrent; + +struct TestExchange : public Exchange{ + Message::shared_ptr msg; + string routingKey; + FieldTable* args; + + TestExchange() : Exchange("test"), args(0) {} + + void bind(Queue::shared_ptr queue, const string& routingKey, FieldTable* args){ + } + + void unbind(Queue::shared_ptr queue, const string& routingKey, FieldTable* args){ + } + + void route(Message::shared_ptr& msg, const string& routingKey, FieldTable* args){ + this->msg = msg; + this->routingKey = routingKey; + this->args = args; + } +}; + +class RouterTest : public CppUnit::TestCase +{ + CPPUNIT_TEST_SUITE(RouterTest); + CPPUNIT_TEST(test); + CPPUNIT_TEST_SUITE_END(); + + public: + + void test() + { + ExchangeRegistry registry; + TestExchange* exchange = new TestExchange(); + registry.declare(exchange); + + string routingKey("my_routing_key"); + string name("name"); + string value("value"); + Message::shared_ptr msg(new Message(0, "test", routingKey, false, false)); + AMQHeaderBody::shared_ptr header(new AMQHeaderBody(BASIC)); + + dynamic_cast(header->getProperties())->getHeaders().setString(name, value); + msg->setHeader(header); + + Router router(registry); + router(msg); + + CPPUNIT_ASSERT(exchange->msg); + CPPUNIT_ASSERT_EQUAL(msg, exchange->msg); + CPPUNIT_ASSERT_EQUAL(routingKey, exchange->msg->getRoutingKey()); + CPPUNIT_ASSERT_EQUAL(routingKey, exchange->routingKey); + CPPUNIT_ASSERT_EQUAL(value, exchange->args->getString(name)); + } +}; + +// Make this test suite a plugin. +CPPUNIT_PLUGIN_IMPLEMENT(); +CPPUNIT_TEST_SUITE_REGISTRATION(RouterTest); + -- cgit v1.2.1