363488 ShutdownHandler use stopper thread
This commit is contained in:
parent
f70ed3ac21
commit
ef49f079c8
|
@ -69,6 +69,8 @@ public class ShutdownHandler extends AbstractHandler
|
||||||
|
|
||||||
private boolean _exitJvm = false;
|
private boolean _exitJvm = false;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a listener that lets the server be shut down remotely (but only from localhost).
|
* Creates a listener that lets the server be shut down remotely (but only from localhost).
|
||||||
*
|
*
|
||||||
|
@ -110,18 +112,24 @@ public class ShutdownHandler extends AbstractHandler
|
||||||
|
|
||||||
LOG.info("Shutting down by request from " + getRemoteAddr(request));
|
LOG.info("Shutting down by request from " + getRemoteAddr(request));
|
||||||
|
|
||||||
try
|
new Thread()
|
||||||
{
|
{
|
||||||
shutdownServer();
|
public void run ()
|
||||||
}
|
{
|
||||||
catch (InterruptedException e)
|
try
|
||||||
{
|
{
|
||||||
LOG.ignore(e);
|
shutdownServer();
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (InterruptedException e)
|
||||||
{
|
{
|
||||||
throw new RuntimeException("Shutting down server",e);
|
LOG.ignore(e);
|
||||||
}
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
throw new RuntimeException("Shutting down server",e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean requestFromLocalhost(HttpServletRequest request)
|
private boolean requestFromLocalhost(HttpServletRequest request)
|
||||||
|
|
|
@ -14,12 +14,18 @@ package org.eclipse.jetty.server.handler;
|
||||||
//========================================================================
|
//========================================================================
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import org.eclipse.jetty.server.Server;
|
import org.eclipse.jetty.server.Server;
|
||||||
|
import org.eclipse.jetty.util.component.AbstractLifeCycle;
|
||||||
|
import org.eclipse.jetty.util.component.LifeCycle;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
|
@ -48,7 +54,35 @@ public class ShutdownHandlerTest
|
||||||
public void shutdownServerWithCorrectTokenAndIPTest() throws Exception
|
public void shutdownServerWithCorrectTokenAndIPTest() throws Exception
|
||||||
{
|
{
|
||||||
setDefaultExpectations();
|
setDefaultExpectations();
|
||||||
|
final CountDownLatch countDown = new CountDownLatch(1);
|
||||||
|
server.addLifeCycleListener(new AbstractLifeCycle.Listener ()
|
||||||
|
{
|
||||||
|
|
||||||
|
public void lifeCycleStarting(LifeCycle event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public void lifeCycleStarted(LifeCycle event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public void lifeCycleFailure(LifeCycle event, Throwable cause)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public void lifeCycleStopping(LifeCycle event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public void lifeCycleStopped(LifeCycle event)
|
||||||
|
{
|
||||||
|
countDown.countDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
shutdownHandler.handle("/shutdown",null,request,response);
|
shutdownHandler.handle("/shutdown",null,request,response);
|
||||||
|
boolean stopped = countDown.await(1000, TimeUnit.MILLISECONDS); //wait up to 1 sec to stop
|
||||||
|
assertTrue("Server lifecycle stop listener called", stopped);
|
||||||
assertEquals("Server should be stopped","STOPPED",server.getState());
|
assertEquals("Server should be stopped","STOPPED",server.getState());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue