From 97449c36a04083484408907adcdfd81ecb63e7c1 Mon Sep 17 00:00:00 2001 From: Robert Gemmell Date: Thu, 2 Feb 2012 13:56:14 +0000 Subject: QPID-3784: introduce system property to run a dispatcher thread as damon/non-daemon thread. Changes dispatcher thread to be non daemon thread by default. Applied patch from Andrew MacBean and Oleksandr Rudyy. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@1239620 13f79535-47bb-0310-9956-ffa450edef68 --- .../java/org/apache/qpid/client/AMQSession.java | 12 +++- .../apache/qpid/client/DispatcherDaemonTest.java | 66 ++++++++++++++++++++++ 2 files changed, 77 insertions(+), 1 deletion(-) create mode 100644 java/client/src/test/java/org/apache/qpid/client/DispatcherDaemonTest.java (limited to 'java') diff --git a/java/client/src/main/java/org/apache/qpid/client/AMQSession.java b/java/client/src/main/java/org/apache/qpid/client/AMQSession.java index 82ba04ddd3..f56f0c2747 100644 --- a/java/client/src/main/java/org/apache/qpid/client/AMQSession.java +++ b/java/client/src/main/java/org/apache/qpid/client/AMQSession.java @@ -387,6 +387,16 @@ public abstract class AMQSession _session; + + public void tearDown() throws Exception + { + super.tearDown(); + if (_session != null && _session.getDispatcherThread() != null) + { + _session.getDispatcherThread().interrupt(); + } + } + + public void testDispatcherIsRunInDaemonThreadWithNoMessageListener() throws Exception + { + _session = createSession(); + _session.startDispatcherIfNecessary(); + assertFalse("Dispatcher thread should be non daemon as qpid.jms.daemon.dispatcher is not set", + _session.getDispatcherThread().isDaemon()); + } + + public void testDispatcherIsRunInDaemonThreadWithConsumerMessageListenerAndDaemonFlagOn() throws Exception + { + setTestSystemProperty(AMQSession.DAEMON_DISPATCHER, "true"); + _session = createSession(); + _session.startDispatcherIfNecessary(); + assertTrue("Dispatcher thread should be daemon as qpid.jms.daemon.dispatcher is set to true", + _session.getDispatcherThread().isDaemon()); + } + + private AMQSession createSession() throws AMQException, URLSyntaxException + { + AMQConnection amqConnection = new MockAMQConnection( + "amqp://guest:guest@client/test?brokerlist='tcp://localhost:1'&maxprefetch='0'"); + + AMQSession_0_8 session = new AMQSession_0_8(amqConnection, 1, true, Session.SESSION_TRANSACTED, 1, 1); + return session; + } + +} -- cgit v1.2.1