SessionCloseOnGCTest#testCloseOneSessionOnGC avoiding intermittent failure - small improvement
This commit is contained in:
parent
bd946d2ce8
commit
e35c4d5800
|
@ -181,20 +181,14 @@ public class SessionCloseOnGCTest extends ActiveMQTestBase {
|
||||||
public void testCloseOneSessionOnGC() throws Exception {
|
public void testCloseOneSessionOnGC() throws Exception {
|
||||||
ClientSessionFactoryImpl sf = (ClientSessionFactoryImpl) locator.createSessionFactory();
|
ClientSessionFactoryImpl sf = (ClientSessionFactoryImpl) locator.createSessionFactory();
|
||||||
|
|
||||||
|
{
|
||||||
ClientSession session = sf.createSession(false, true, true);
|
ClientSession session = sf.createSession(false, true, true);
|
||||||
|
|
||||||
WeakReference<ClientSession> wses = new WeakReference<ClientSession>(session);
|
|
||||||
|
|
||||||
Assert.assertEquals(1, server.getRemotingService().getConnections().size());
|
Assert.assertEquals(1, server.getRemotingService().getConnections().size());
|
||||||
|
}
|
||||||
|
|
||||||
session = null;
|
for (int i = 0; i < 1000 && sf.numSessions() != 0; i++) {
|
||||||
|
forceGC();
|
||||||
ActiveMQTestBase.checkWeakReferences(wses);
|
|
||||||
|
|
||||||
for (int i = 0; i < 100 && sf.numSessions() != 0; i++) {
|
|
||||||
System.gc();
|
|
||||||
System.runFinalization();
|
|
||||||
Thread.sleep(100);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Assert.assertEquals(0, sf.numSessions());
|
Assert.assertEquals(0, sf.numSessions());
|
||||||
|
|
Loading…
Reference in New Issue