From 8b82aef0397d65de0c7278476e4f409fcc636306 Mon Sep 17 00:00:00 2001 From: Alan Conway Date: Fri, 28 Sep 2007 16:21:34 +0000 Subject: * src/tests/ClientSessionTest.cpp: Suspend/resume tests. * broker/SessionManager.cpp, broker/SessionHandler.cpp: Implement suspend/resume * client/ScopedAssociation.h, SessionCore.h, SessionHandler.h: Simplified relationships. - Removed ScopedAssociation. - SessionHandler: is now a member of SessionCore. - SessionCore: shared_ptr ownership by Session(s) and ConnectionImpl. - Using framing::FrameHandler interfaces. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@580403 13f79535-47bb-0310-9956-ffa450edef68 --- cpp/src/tests/ClientSessionTest.cpp | 24 ++++++++++++++++++++++++ cpp/src/tests/InProcessBroker.h | 4 +++- 2 files changed, 27 insertions(+), 1 deletion(-) (limited to 'cpp/src/tests') diff --git a/cpp/src/tests/ClientSessionTest.cpp b/cpp/src/tests/ClientSessionTest.cpp index 1d59fbed33..2495a06fa4 100644 --- a/cpp/src/tests/ClientSessionTest.cpp +++ b/cpp/src/tests/ClientSessionTest.cpp @@ -60,6 +60,8 @@ class ClientSessionTest : public CppUnit::TestCase CPPUNIT_TEST(testQueueQuery); CPPUNIT_TEST(testTransfer); CPPUNIT_TEST(testDispatcher); + CPPUNIT_TEST(testSuspendResume); + CPPUNIT_TEST(testSuspendResumeErrors); CPPUNIT_TEST_SUITE_END(); boost::shared_ptr broker; @@ -139,6 +141,28 @@ public: } void testSuspendResume() { + session = connection.newSession(60); + session.suspend(); + try { + session.exchangeQuery_(name="amq.fanout"); + CPPUNIT_FAIL("Expected session suspended exception"); + } catch(...) {} + connection.resume(session); + session.exchangeQuery_(name="amq.fanout"); + // FIXME aconway 2007-09-25: build up session state and confirm + //it survives the resume + } + + void testSuspendResumeErrors() { + session.suspend(); // session has 0 timeout. + try { + session.exchangeQuery_(name="amq.fanout"); + CPPUNIT_FAIL("Expected suspended session exception"); + } catch(...) {} + try { + connection.resume(session); + CPPUNIT_FAIL("Expected no such session exception."); + } catch(...) {} } }; diff --git a/cpp/src/tests/InProcessBroker.h b/cpp/src/tests/InProcessBroker.h index 531ebd8fa7..2a9f12771b 100644 --- a/cpp/src/tests/InProcessBroker.h +++ b/cpp/src/tests/InProcessBroker.h @@ -24,6 +24,7 @@ #include "qpid/broker/Connection.h" #include "qpid/client/Connector.h" #include "qpid/client/Connection.h" +#include "qpid/log/Statement.h" #include #include @@ -101,7 +102,8 @@ class InProcessBroker : public client::Connector { ) : sender(sender_), conversation(conversation_), in(ih) {} void send(framing::AMQFrame& frame) { - //std::cout << (sender == CLIENT ? "C->S: " : "S->C: ") << frame << std::endl; + QPID_LOG(debug, + (sender==CLIENT ? "CLIENT: " : "BROKER: ") << frame); conversation.push_back(TaggedFrame(sender, frame)); in->received(frame); } -- cgit v1.2.1