296570 EOFException for HttpExchange when HttpClient.stop called
git-svn-id: svn+ssh://dev.eclipse.org/svnroot/rt/org.eclipse.jetty/jetty/trunk@2066 7e9141cc-0065-0410-87d8-b60c137991c4
This commit is contained in:
parent
f24444b08a
commit
75dd71b1ff
|
@ -1,6 +1,7 @@
|
|||
jetty-7.1.5-SNAPSHOT
|
||||
+ Update ecj to 3.6 Helios release drop
|
||||
+ 288194 Add blacklist/whitelist to ProxyServlet and ProxyHandler
|
||||
+ 296570 EOFException for HttpExchange when HttpClient.stop called.
|
||||
+ 311550 The WebAppProvider should allow setTempDirectory
|
||||
+ 316449 Websocket disconnect fix
|
||||
+ 316584 Exception on startup if temp path has spaces and extractWAR=false
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
|
||||
package org.eclipse.jetty.client;
|
||||
|
||||
import java.io.EOFException;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.io.InterruptedIOException;
|
||||
|
@ -593,6 +594,14 @@ public class HttpConnection implements Connection
|
|||
|
||||
public void close() throws IOException
|
||||
{
|
||||
//if there is a live, unfinished exchange, set its status to be
|
||||
//excepted and wake up anyone waiting on waitForDone()
|
||||
if (_exchange != null && !_exchange.isDone())
|
||||
{
|
||||
_exchange.setStatus(HttpExchange.STATUS_EXCEPTED);
|
||||
_exchange.getEventListener().onException(new EOFException("local close"));
|
||||
}
|
||||
|
||||
_endp.close();
|
||||
}
|
||||
|
||||
|
|
|
@ -20,6 +20,8 @@ import java.io.OutputStream;
|
|||
import java.util.concurrent.CountDownLatch;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.atomic.AtomicInteger;
|
||||
import java.util.concurrent.atomic.AtomicReference;
|
||||
|
||||
import javax.servlet.ServletException;
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
|
@ -98,8 +100,6 @@ public class HttpExchangeTest extends TestCase
|
|||
sender(1,true);
|
||||
sender(10,false);
|
||||
sender(10,true);
|
||||
sender(20,false);
|
||||
sender(20,true);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -215,16 +215,19 @@ public class HttpExchangeTest extends TestCase
|
|||
assertTrue(complete.await(45,TimeUnit.SECONDS));
|
||||
|
||||
long elapsed=System.currentTimeMillis()-start;
|
||||
|
||||
// make windows-friendly ... System.currentTimeMillis() on windows is dope!
|
||||
/*
|
||||
if(elapsed>0)
|
||||
System.err.println(nb+"/"+_count+" c="+close+" rate="+(nb*1000/elapsed));
|
||||
*/
|
||||
|
||||
assertEquals("nb="+nb+" close="+close,0,latch.getCount());
|
||||
}
|
||||
|
||||
public void testPostWithContentExchange() throws Exception
|
||||
{
|
||||
for (int i=0;i<200;i++)
|
||||
for (int i=0;i<20;i++)
|
||||
{
|
||||
ContentExchange httpExchange=new ContentExchange();
|
||||
//httpExchange.setURL(_scheme+"localhost:"+_port+"/");
|
||||
|
@ -242,7 +245,7 @@ public class HttpExchangeTest extends TestCase
|
|||
|
||||
public void testGetWithContentExchange() throws Exception
|
||||
{
|
||||
for (int i=0;i<100;i++)
|
||||
for (int i=0;i<10;i++)
|
||||
{
|
||||
ContentExchange httpExchange=new ContentExchange();
|
||||
httpExchange.setURL(_scheme+"localhost:"+_port+"/?i="+i);
|
||||
|
@ -258,6 +261,44 @@ public class HttpExchangeTest extends TestCase
|
|||
}
|
||||
}
|
||||
|
||||
public void testShutdownWithExchange() throws Exception
|
||||
{
|
||||
final AtomicReference<Throwable> throwable=new AtomicReference<Throwable>();
|
||||
|
||||
HttpExchange httpExchange=new HttpExchange()
|
||||
{
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
* @see org.eclipse.jetty.client.HttpExchange#onException(java.lang.Throwable)
|
||||
*/
|
||||
@Override
|
||||
protected void onException(Throwable x)
|
||||
{
|
||||
throwable.set(x);
|
||||
}
|
||||
|
||||
};
|
||||
httpExchange.setURL(_scheme+"localhost:"+_port+"/");
|
||||
httpExchange.setMethod("SLEEP");
|
||||
_httpClient.send(httpExchange);
|
||||
new Thread()
|
||||
{
|
||||
@Override
|
||||
public void run()
|
||||
{
|
||||
try {
|
||||
Thread.sleep(250);
|
||||
_httpClient.stop();
|
||||
} catch(Exception e) {e.printStackTrace();}
|
||||
}
|
||||
}.start();
|
||||
int status = httpExchange.waitForDone();
|
||||
|
||||
assertTrue(throwable.get().toString().indexOf("local close")>=0);
|
||||
assertEquals(HttpExchange.STATUS_EXCEPTED, status);
|
||||
}
|
||||
|
||||
public void testBigPostWithContentExchange() throws Exception
|
||||
{
|
||||
int size =32;
|
||||
|
@ -478,6 +519,10 @@ public class HttpExchangeTest extends TestCase
|
|||
}
|
||||
response.getOutputStream().println("</hello>");
|
||||
}
|
||||
else if (request.getMethod().equalsIgnoreCase("SLEEP"))
|
||||
{
|
||||
Thread.sleep(1000);
|
||||
}
|
||||
else
|
||||
{
|
||||
response.setContentType(request.getContentType());
|
||||
|
|
Loading…
Reference in New Issue