diff options
author | Gordon Sim <gsim@apache.org> | 2010-01-20 15:54:59 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2010-01-20 15:54:59 +0000 |
commit | b994b686b50801cf34f1833478c7736359c54b87 (patch) | |
tree | 2f86b10ca31732b061ce15354eaa5003f026050e /cpp/src | |
parent | 2a029cd38ae548cc3a1399f6e68959085546ffd6 (diff) | |
download | qpid-python-b994b686b50801cf34f1833478c7736359c54b87.tar.gz |
Provide access to a sessions connection.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@901247 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src')
-rw-r--r-- | cpp/src/qpid/client/ConnectionAccess.h | 1 | ||||
-rw-r--r-- | cpp/src/qpid/client/SessionBase_0_10.cpp | 8 | ||||
-rw-r--r-- | cpp/src/tests/ClientSessionTest.cpp | 22 |
3 files changed, 31 insertions, 0 deletions
diff --git a/cpp/src/qpid/client/ConnectionAccess.h b/cpp/src/qpid/client/ConnectionAccess.h index b662fd5d8b..3a763f692f 100644 --- a/cpp/src/qpid/client/ConnectionAccess.h +++ b/cpp/src/qpid/client/ConnectionAccess.h @@ -34,6 +34,7 @@ namespace client { struct ConnectionAccess { static void setVersion(Connection& c, const framing::ProtocolVersion& v) { c.version = v; } static boost::shared_ptr<ConnectionImpl> getImpl(Connection& c) { return c.impl; } + static void setImpl(Connection& c, boost::shared_ptr<ConnectionImpl> i) { c.impl = i; } }; }} // namespace qpid::client diff --git a/cpp/src/qpid/client/SessionBase_0_10.cpp b/cpp/src/qpid/client/SessionBase_0_10.cpp index 1a345d534e..e114b7aacc 100644 --- a/cpp/src/qpid/client/SessionBase_0_10.cpp +++ b/cpp/src/qpid/client/SessionBase_0_10.cpp @@ -20,6 +20,7 @@ */ #include "qpid/client/SessionBase_0_10.h" #include "qpid/client/Connection.h" +#include "qpid/client/ConnectionAccess.h" #include "qpid/client/SessionImpl.h" #include "qpid/client/Future.h" #include "qpid/framing/all_method_bodies.h" @@ -74,4 +75,11 @@ SessionId SessionBase_0_10::getId() const { return impl->getId(); } bool SessionBase_0_10::isValid() const { return impl; } +Connection SessionBase_0_10::getConnection() +{ + Connection c; + ConnectionAccess::setImpl(c, impl->getConnection()); + return c; +} + }} // namespace qpid::client diff --git a/cpp/src/tests/ClientSessionTest.cpp b/cpp/src/tests/ClientSessionTest.cpp index 6ca0aa6d44..8ce5d85632 100644 --- a/cpp/src/tests/ClientSessionTest.cpp +++ b/cpp/src/tests/ClientSessionTest.cpp @@ -607,6 +607,28 @@ QPID_AUTO_TEST_CASE(testExpirationNotAltered) { BOOST_CHECK_EQUAL(12345u, got.getDeliveryProperties().getExpiration()); } +QPID_AUTO_TEST_CASE(testGetConnectionFromSession) { + ClientSessionFixture fix; + FieldTable options; + options.setInt("no-local", 1); + fix.session.queueDeclare(arg::queue="a", arg::exclusive=true, arg::autoDelete=true, arg::arguments=options); + fix.session.queueDeclare(arg::queue="b", arg::exclusive=true, arg::autoDelete=true); + + Connection c = fix.session.getConnection(); + Session s = c.newSession(); + //If this new session was created as expected on the same connection as + //fix.session, then the no-local behaviour means that queue 'a' + //will not enqueue messages from this new session but queue 'b' + //will. + s.messageTransfer(arg::content=Message("a", "a")); + s.messageTransfer(arg::content=Message("b", "b")); + + Message got; + BOOST_CHECK(fix.subs.get(got, "b")); + BOOST_CHECK_EQUAL("b", got.getData()); + BOOST_CHECK(!fix.subs.get(got, "a")); +} + QPID_AUTO_TEST_SUITE_END() }} // namespace qpid::tests |