mirror of https://github.com/apache/activemq.git
[no jira] test to exercise pool setBlockIfSessionPoolIsFull false
This commit is contained in:
parent
0f21cf7145
commit
5b4fb8aa2b
|
@ -16,17 +16,23 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.activemq.jms.pool;
|
package org.apache.activemq.jms.pool;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.fail;
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
import javax.jms.Connection;
|
import javax.jms.Connection;
|
||||||
import javax.jms.ConnectionFactory;
|
import javax.jms.ConnectionFactory;
|
||||||
import javax.jms.IllegalStateException;
|
import javax.jms.IllegalStateException;
|
||||||
|
import javax.jms.JMSException;
|
||||||
|
import javax.jms.Session;
|
||||||
|
|
||||||
import org.apache.activemq.ActiveMQConnectionFactory;
|
import org.apache.activemq.ActiveMQConnectionFactory;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A couple of tests against the PooledConnection class.
|
* A couple of tests against the PooledConnection class.
|
||||||
*
|
*
|
||||||
|
@ -106,4 +112,57 @@ public class PooledConnectionTest extends JmsPoolTestSupport {
|
||||||
LOG.debug("ConnectionFactory initialized.");
|
LOG.debug("ConnectionFactory initialized.");
|
||||||
return cf;
|
return cf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 60000)
|
||||||
|
public void testAllSessionsAvailableOnConstrainedPool() throws Exception {
|
||||||
|
PooledConnectionFactory cf = new PooledConnectionFactory();
|
||||||
|
cf.setConnectionFactory(new ActiveMQConnectionFactory(
|
||||||
|
"vm://localhost?broker.persistent=false&broker.useJmx=false&broker.schedulerSupport=false"));
|
||||||
|
cf.setMaxConnections(5);
|
||||||
|
cf.setMaximumActiveSessionPerConnection(2);
|
||||||
|
cf.setBlockIfSessionPoolIsFull(false);
|
||||||
|
|
||||||
|
LinkedList<Connection> connections = new LinkedList<>();
|
||||||
|
HashSet<Session> sessions = new HashSet();
|
||||||
|
|
||||||
|
for (int i=0; i<10; i++) {
|
||||||
|
Connection conn = cf.createConnection();
|
||||||
|
LOG.info("connection: " + i + ", " + ((PooledConnection)conn).getConnection());
|
||||||
|
|
||||||
|
conn.start();
|
||||||
|
connections.add(conn);
|
||||||
|
sessions.add(conn.createSession(false, Session.AUTO_ACKNOWLEDGE));
|
||||||
|
}
|
||||||
|
|
||||||
|
assertEquals(sessions.size(), 10);
|
||||||
|
assertEquals(connections.size(), 10);
|
||||||
|
|
||||||
|
Connection connectionToClose = connections.getLast();
|
||||||
|
connectionToClose.close();
|
||||||
|
|
||||||
|
Connection conn = cf.createConnection();
|
||||||
|
LOG.info("connection:" + ((PooledConnection)conn).getConnection());
|
||||||
|
|
||||||
|
conn.start();
|
||||||
|
connections.add(conn);
|
||||||
|
try {
|
||||||
|
sessions.add(conn.createSession(false, Session.AUTO_ACKNOWLEDGE));
|
||||||
|
} catch (JMSException expected) {
|
||||||
|
conn.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
conn = cf.createConnection();
|
||||||
|
LOG.info("connection:" + ((PooledConnection)conn).getConnection());
|
||||||
|
|
||||||
|
conn.start();
|
||||||
|
connections.add(conn);
|
||||||
|
try {
|
||||||
|
sessions.add(conn.createSession(false, Session.AUTO_ACKNOWLEDGE));
|
||||||
|
} catch (JMSException expected) {
|
||||||
|
conn.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
assertEquals(sessions.size(), 10);
|
||||||
|
assertEquals(connections.size(), 12);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue