jetty-9 more progress with RFC2616 tests
This commit is contained in:
parent
8b98e3918c
commit
4473572b6d
|
@ -36,8 +36,8 @@ public class HttpGenerator
|
||||||
|
|
||||||
// states
|
// states
|
||||||
public enum Action { FLUSH, COMPLETE, PREPARE };
|
public enum Action { FLUSH, COMPLETE, PREPARE };
|
||||||
public enum State { START, COMMITTING, COMMITTING_COMPLETING, COMMITTED, COMPLETING, END };
|
public enum State { START, COMMITTING, COMMITTING_COMPLETING, COMMITTED, COMPLETING, COMPLETING_1XX, END };
|
||||||
public enum Result { NEED_CHUNK,NEED_COMMIT,NEED_BUFFER,FLUSH,FLUSH_CONTENT,OK,SHUTDOWN_OUT};
|
public enum Result { NEED_CHUNK,NEED_INFO,NEED_HEADER,NEED_BUFFER,FLUSH,FLUSH_CONTENT,OK,SHUTDOWN_OUT};
|
||||||
|
|
||||||
// other statics
|
// other statics
|
||||||
public static final int CHUNK_SIZE = 12;
|
public static final int CHUNK_SIZE = 12;
|
||||||
|
@ -279,12 +279,12 @@ public class HttpGenerator
|
||||||
case COMMITTING_COMPLETING:
|
case COMMITTING_COMPLETING:
|
||||||
{
|
{
|
||||||
if (info==null)
|
if (info==null)
|
||||||
return Result.NEED_COMMIT;
|
return Result.NEED_INFO;
|
||||||
|
|
||||||
if (info instanceof RequestInfo)
|
if (info instanceof RequestInfo)
|
||||||
{
|
{
|
||||||
if (header==null || header.capacity()<=CHUNK_SIZE)
|
if (header==null || header.capacity()<=CHUNK_SIZE)
|
||||||
return Result.NEED_COMMIT;
|
return Result.NEED_HEADER;
|
||||||
|
|
||||||
if(info.getHttpVersion()==HttpVersion.HTTP_0_9)
|
if(info.getHttpVersion()==HttpVersion.HTTP_0_9)
|
||||||
{
|
{
|
||||||
|
@ -313,7 +313,7 @@ public class HttpGenerator
|
||||||
|
|
||||||
// yes we need a response header
|
// yes we need a response header
|
||||||
if (header==null || header.capacity()<=CHUNK_SIZE)
|
if (header==null || header.capacity()<=CHUNK_SIZE)
|
||||||
return Result.NEED_COMMIT;
|
return Result.NEED_HEADER;
|
||||||
|
|
||||||
// Are we persistent by default?
|
// Are we persistent by default?
|
||||||
if (_persistent==null)
|
if (_persistent==null)
|
||||||
|
@ -330,8 +330,8 @@ public class HttpGenerator
|
||||||
if (status!=101 )
|
if (status!=101 )
|
||||||
{
|
{
|
||||||
header.put(HttpTokens.CRLF);
|
header.put(HttpTokens.CRLF);
|
||||||
_state = State.START;
|
_state=State.COMPLETING_1XX;
|
||||||
return Result.OK;
|
return Result.FLUSH;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (status==204 || status==304)
|
else if (status==204 || status==304)
|
||||||
|
@ -419,6 +419,10 @@ public class HttpGenerator
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
|
case COMPLETING_1XX:
|
||||||
|
reset();
|
||||||
|
return Result.OK;
|
||||||
|
|
||||||
case END:
|
case END:
|
||||||
if (!_persistent)
|
if (!_persistent)
|
||||||
result=Result.SHUTDOWN_OUT;
|
result=Result.SHUTDOWN_OUT;
|
||||||
|
@ -964,7 +968,7 @@ public class HttpGenerator
|
||||||
_head = head;
|
_head = head;
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean isInformational()
|
public boolean isInformational()
|
||||||
{
|
{
|
||||||
return _status>=100 && _status<200;
|
return _status>=100 && _status<200;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1112,8 +1112,8 @@ public class HttpParser
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
public void close()
|
public void close()
|
||||||
{
|
{
|
||||||
if (_state!=State.END)
|
if (_state!=State.END && _state!=State.CLOSED)
|
||||||
throw new IllegalStateException(toString());
|
LOG.warn("Closing {}",this);
|
||||||
_persistent=false;
|
_persistent=false;
|
||||||
reset();
|
reset();
|
||||||
}
|
}
|
||||||
|
@ -1134,6 +1134,8 @@ public class HttpParser
|
||||||
{
|
{
|
||||||
this._state=state;
|
this._state=state;
|
||||||
_endOfContent=EndOfContent.UNKNOWN_CONTENT;
|
_endOfContent=EndOfContent.UNKNOWN_CONTENT;
|
||||||
|
if (state==State.CLOSED)
|
||||||
|
_persistent=false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------------- */
|
||||||
|
|
|
@ -52,7 +52,7 @@ public class HttpGeneratorClientTest
|
||||||
HttpGenerator.Result
|
HttpGenerator.Result
|
||||||
result=gen.generate(null,null,null,null,null,Action.COMPLETE);
|
result=gen.generate(null,null,null,null,null,Action.COMPLETE);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
Info info = new Info("GET","/index.html");
|
Info info = new Info("GET","/index.html");
|
||||||
info.getHttpFields().add("Host","something");
|
info.getHttpFields().add("Host","something");
|
||||||
info.getHttpFields().add("User-Agent","test");
|
info.getHttpFields().add("User-Agent","test");
|
||||||
|
@ -105,7 +105,7 @@ public class HttpGeneratorClientTest
|
||||||
assertTrue(BufferUtil.isEmpty(content1));
|
assertTrue(BufferUtil.isEmpty(content1));
|
||||||
|
|
||||||
result=gen.generate(null,null,null,buffer,null,Action.COMPLETE);
|
result=gen.generate(null,null,null,buffer,null,Action.COMPLETE);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
||||||
|
|
||||||
Info info = new Info("POST","/index.html");
|
Info info = new Info("POST","/index.html");
|
||||||
|
@ -158,7 +158,7 @@ public class HttpGeneratorClientTest
|
||||||
assertEquals(0,content0.remaining());
|
assertEquals(0,content0.remaining());
|
||||||
|
|
||||||
result=gen.generate(null,null,null,buffer,content1,null);
|
result=gen.generate(null,null,null,buffer,content1,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
||||||
assertEquals(43,content1.remaining());
|
assertEquals(43,content1.remaining());
|
||||||
|
@ -257,7 +257,7 @@ public class HttpGeneratorClientTest
|
||||||
HttpGenerator.Result
|
HttpGenerator.Result
|
||||||
|
|
||||||
result=gen.generate(null,null,null,null,content0,null);
|
result=gen.generate(null,null,null,null,content0,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
|
|
||||||
Info info = new Info("POST","/index.html");
|
Info info = new Info("POST","/index.html");
|
||||||
|
@ -338,7 +338,7 @@ public class HttpGeneratorClientTest
|
||||||
assertEquals(0,content0.remaining());
|
assertEquals(0,content0.remaining());
|
||||||
|
|
||||||
result=gen.generate(null,null,null,buffer,content1,null);
|
result=gen.generate(null,null,null,buffer,content1,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
||||||
assertEquals(43,content1.remaining());
|
assertEquals(43,content1.remaining());
|
||||||
|
@ -419,7 +419,7 @@ public class HttpGeneratorClientTest
|
||||||
HttpGenerator.Result
|
HttpGenerator.Result
|
||||||
|
|
||||||
result=gen.generate(null,null,null,null,content0,null);
|
result=gen.generate(null,null,null,null,content0,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
|
|
||||||
Info info = new Info("POST","/index.html",59);
|
Info info = new Info("POST","/index.html",59);
|
||||||
|
|
|
@ -189,8 +189,11 @@ public class HttpGeneratorServerTest
|
||||||
|
|
||||||
switch(result)
|
switch(result)
|
||||||
{
|
{
|
||||||
case NEED_COMMIT:
|
case NEED_INFO:
|
||||||
info=new HttpGenerator.ResponseInfo(HttpVersion.fromVersion(version),_fields,_contentLength,_code,reason,_head);
|
info=new HttpGenerator.ResponseInfo(HttpVersion.fromVersion(version),_fields,_contentLength,_code,reason,_head);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NEED_HEADER:
|
||||||
header=BufferUtil.allocate(2048);
|
header=BufferUtil.allocate(2048);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -369,7 +372,7 @@ public class HttpGeneratorServerTest
|
||||||
HttpGenerator.Result
|
HttpGenerator.Result
|
||||||
result=gen.generate(null,null,null,null,null,Action.COMPLETE);
|
result=gen.generate(null,null,null,null,null,Action.COMPLETE);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
|
|
||||||
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
||||||
info.getHttpFields().add("Last-Modified",HttpFields.__01Jan1970);
|
info.getHttpFields().add("Last-Modified",HttpFields.__01Jan1970);
|
||||||
|
@ -412,7 +415,7 @@ public class HttpGeneratorServerTest
|
||||||
assertEquals(0,content0.remaining());
|
assertEquals(0,content0.remaining());
|
||||||
|
|
||||||
result=gen.generate(null,null,null,buffer,content1,null);
|
result=gen.generate(null,null,null,buffer,content1,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
||||||
assertEquals(43,content1.remaining());
|
assertEquals(43,content1.remaining());
|
||||||
|
@ -517,7 +520,7 @@ public class HttpGeneratorServerTest
|
||||||
assertEquals(0,content0.remaining());
|
assertEquals(0,content0.remaining());
|
||||||
|
|
||||||
result=gen.generate(null,null,null,buffer,content1,null);
|
result=gen.generate(null,null,null,buffer,content1,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
assertEquals("Hello World! The",BufferUtil.toString(buffer));
|
||||||
assertEquals(43,content1.remaining());
|
assertEquals(43,content1.remaining());
|
||||||
|
@ -594,7 +597,7 @@ public class HttpGeneratorServerTest
|
||||||
HttpGenerator.Result
|
HttpGenerator.Result
|
||||||
|
|
||||||
result=gen.generate(null,null,null,null,content0,null);
|
result=gen.generate(null,null,null,null,content0,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
|
|
||||||
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),59,200,null,false);
|
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),59,200,null,false);
|
||||||
|
@ -648,7 +651,7 @@ public class HttpGeneratorServerTest
|
||||||
HttpGenerator.Result
|
HttpGenerator.Result
|
||||||
|
|
||||||
result=gen.generate(null,null,null,null,content0,null);
|
result=gen.generate(null,null,null,null,content0,null);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING,gen.getState());
|
||||||
|
|
||||||
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
||||||
|
@ -730,7 +733,78 @@ public class HttpGeneratorServerTest
|
||||||
assertTrue(BufferUtil.isEmpty(content1));
|
assertTrue(BufferUtil.isEmpty(content1));
|
||||||
|
|
||||||
result=gen.generate(null,null,null,buffer,null,Action.COMPLETE);
|
result=gen.generate(null,null,null,buffer,null,Action.COMPLETE);
|
||||||
assertEquals(HttpGenerator.Result.NEED_COMMIT,result);
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
|
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
||||||
|
|
||||||
|
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
||||||
|
info.getHttpFields().add("Last-Modified",HttpFields.__01Jan1970);
|
||||||
|
result=gen.generate(info,header,null,buffer,null,null);
|
||||||
|
assertEquals(HttpGenerator.Result.FLUSH,result);
|
||||||
|
assertEquals(HttpGenerator.State.COMPLETING,gen.getState());
|
||||||
|
|
||||||
|
String head = BufferUtil.toString(header);
|
||||||
|
BufferUtil.clear(header);
|
||||||
|
body+=BufferUtil.toString(buffer);
|
||||||
|
BufferUtil.clear(buffer);
|
||||||
|
|
||||||
|
result=gen.generate(info,null,null,buffer,null,null);
|
||||||
|
assertEquals(HttpGenerator.Result.OK,result);
|
||||||
|
assertEquals(HttpGenerator.State.END,gen.getState());
|
||||||
|
|
||||||
|
assertThat(head,containsString("HTTP/1.1 200 OK"));
|
||||||
|
assertThat(head,containsString("Last-Modified: Thu, 01 Jan 1970 00?00?00 GMT"));
|
||||||
|
assertThat(head,containsString("Content-Length: 58"));
|
||||||
|
assertTrue(head.endsWith("\r\n\r\n"));
|
||||||
|
|
||||||
|
assertEquals("Hello World. The quick brown fox jumped over the lazy dog.",body);
|
||||||
|
|
||||||
|
assertEquals(58,gen.getContentPrepared());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test100ThenResponseWithSmallContent() throws Exception
|
||||||
|
{
|
||||||
|
String body="";
|
||||||
|
ByteBuffer header=BufferUtil.allocate(4096);
|
||||||
|
ByteBuffer buffer=BufferUtil.allocate(8096);
|
||||||
|
ByteBuffer content=BufferUtil.toBuffer("Hello World");
|
||||||
|
ByteBuffer content1=BufferUtil.toBuffer(". The quick brown fox jumped over the lazy dog.");
|
||||||
|
HttpGenerator gen = new HttpGenerator();
|
||||||
|
|
||||||
|
HttpGenerator.Result
|
||||||
|
|
||||||
|
result=gen.generate(HttpGenerator.CONTINUE_100_INFO,null,null,null,null,Action.COMPLETE);
|
||||||
|
assertEquals(HttpGenerator.Result.NEED_HEADER,result);
|
||||||
|
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
||||||
|
|
||||||
|
result=gen.generate(HttpGenerator.CONTINUE_100_INFO,header,null,null,null,Action.COMPLETE);
|
||||||
|
assertEquals(HttpGenerator.Result.FLUSH,result);
|
||||||
|
assertEquals(HttpGenerator.State.COMPLETING_1XX,gen.getState());
|
||||||
|
assertThat(BufferUtil.toString(header),Matchers.startsWith("HTTP/1.1 100 Continue"));
|
||||||
|
BufferUtil.clear(header);
|
||||||
|
|
||||||
|
result=gen.generate(null,null,null,null,null,null);
|
||||||
|
assertEquals(HttpGenerator.Result.OK,result);
|
||||||
|
assertEquals(HttpGenerator.State.START,gen.getState());
|
||||||
|
|
||||||
|
result=gen.generate(null,null,null,null,content,null);
|
||||||
|
assertEquals(HttpGenerator.Result.NEED_BUFFER,result);
|
||||||
|
assertEquals(HttpGenerator.State.START,gen.getState());
|
||||||
|
|
||||||
|
result=gen.generate(null,null,null,buffer,content,null);
|
||||||
|
assertEquals(HttpGenerator.Result.OK,result);
|
||||||
|
assertEquals(HttpGenerator.State.START,gen.getState());
|
||||||
|
assertEquals("Hello World",BufferUtil.toString(buffer));
|
||||||
|
assertTrue(BufferUtil.isEmpty(content));
|
||||||
|
|
||||||
|
result=gen.generate(null,null,null,buffer,content1,null);
|
||||||
|
assertEquals(HttpGenerator.Result.OK,result);
|
||||||
|
assertEquals(HttpGenerator.State.START,gen.getState());
|
||||||
|
assertEquals("Hello World. The quick brown fox jumped over the lazy dog.",BufferUtil.toString(buffer));
|
||||||
|
assertTrue(BufferUtil.isEmpty(content1));
|
||||||
|
|
||||||
|
result=gen.generate(null,null,null,buffer,null,Action.COMPLETE);
|
||||||
|
assertEquals(HttpGenerator.Result.NEED_INFO,result);
|
||||||
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
assertEquals(HttpGenerator.State.COMMITTING_COMPLETING,gen.getState());
|
||||||
|
|
||||||
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
ResponseInfo info = new ResponseInfo(HttpVersion.HTTP_1_1,new HttpFields(),-1,200,null,false);
|
||||||
|
|
|
@ -32,7 +32,7 @@ public abstract class AbstractEndPoint implements EndPoint
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setMaxIdleTime(int timeMs) throws IOException
|
public void setMaxIdleTime(int timeMs)
|
||||||
{
|
{
|
||||||
_maxIdleTime=timeMs;
|
_maxIdleTime=timeMs;
|
||||||
}
|
}
|
||||||
|
|
|
@ -121,9 +121,8 @@ public interface EndPoint
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
/** Set the max idle time.
|
/** Set the max idle time.
|
||||||
* @param timeMs the max idle time in MS. Timeout <= 0 implies an infinite timeout
|
* @param timeMs the max idle time in MS. Timeout <= 0 implies an infinite timeout
|
||||||
* @throws IOException if the timeout cannot be set.
|
|
||||||
*/
|
*/
|
||||||
void setMaxIdleTime(int timeMs) throws IOException;
|
void setMaxIdleTime(int timeMs);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,6 @@ public abstract class ReadInterest
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
public void readable()
|
public void readable()
|
||||||
{
|
{
|
||||||
|
|
|
@ -328,6 +328,7 @@ public abstract class HttpChannel
|
||||||
if (_state.isInitial())
|
if (_state.isInitial())
|
||||||
{
|
{
|
||||||
_request.setDispatcherType(DispatcherType.REQUEST);
|
_request.setDispatcherType(DispatcherType.REQUEST);
|
||||||
|
_request.setPathInfo(_uri.getPath());
|
||||||
getHttpConnector().customize(_request);
|
getHttpConnector().customize(_request);
|
||||||
getServer().handle(this);
|
getServer().handle(this);
|
||||||
}
|
}
|
||||||
|
|
|
@ -467,10 +467,15 @@ public class HttpConnection extends AbstractAsyncConnection
|
||||||
|
|
||||||
switch(result)
|
switch(result)
|
||||||
{
|
{
|
||||||
case NEED_COMMIT:
|
case NEED_INFO:
|
||||||
if (_info==null)
|
if (_info==null)
|
||||||
_info=_channel.getEventHandler().commit();
|
_info=_channel.getEventHandler().commit();
|
||||||
LOG.debug("{} Gcommit {}",this,_info);
|
LOG.debug("{} Gcommit {}",this,_info);
|
||||||
|
if (_responseHeader==null)
|
||||||
|
_responseHeader=_bufferPool.acquire(_connector.getResponseHeaderSize(),false);
|
||||||
|
continue;
|
||||||
|
|
||||||
|
case NEED_HEADER:
|
||||||
_responseHeader=_bufferPool.acquire(_connector.getResponseHeaderSize(),false);
|
_responseHeader=_bufferPool.acquire(_connector.getResponseHeaderSize(),false);
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -541,7 +546,6 @@ public class HttpConnection extends AbstractAsyncConnection
|
||||||
|
|
||||||
LOG.debug("{} commit {}",this,_info);
|
LOG.debug("{} commit {}",this,_info);
|
||||||
|
|
||||||
// TODO review the locks with a mind that other threads may read and write
|
|
||||||
synchronized (_lock)
|
synchronized (_lock)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
@ -558,16 +562,20 @@ public class HttpConnection extends AbstractAsyncConnection
|
||||||
LOG.debug("{} commit: {} ({},{},{})@{}",
|
LOG.debug("{} commit: {} ({},{},{})@{}",
|
||||||
this,
|
this,
|
||||||
result,
|
result,
|
||||||
BufferUtil.toSummaryString(_responseHeader),
|
BufferUtil.toDetailString(_responseHeader),
|
||||||
BufferUtil.toSummaryString(_responseBuffer),
|
BufferUtil.toSummaryString(_responseBuffer),
|
||||||
BufferUtil.toSummaryString(content),
|
BufferUtil.toSummaryString(content),
|
||||||
_generator.getState());
|
_generator.getState());
|
||||||
|
|
||||||
switch(result)
|
switch(result)
|
||||||
{
|
{
|
||||||
case NEED_COMMIT:
|
case NEED_INFO:
|
||||||
if (_info==null)
|
_info=_channel.getEventHandler().commit();
|
||||||
_info=_channel.getEventHandler().commit();
|
if (_responseHeader==null)
|
||||||
|
_responseHeader=_bufferPool.acquire(_connector.getResponseHeaderSize(),false);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NEED_HEADER:
|
||||||
_responseHeader=_bufferPool.acquire(_connector.getResponseHeaderSize(),false);
|
_responseHeader=_bufferPool.acquire(_connector.getResponseHeaderSize(),false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -606,6 +614,8 @@ public class HttpConnection extends AbstractAsyncConnection
|
||||||
break loop;
|
break loop;
|
||||||
|
|
||||||
case OK:
|
case OK:
|
||||||
|
if (_info!=null && _info.isInformational())
|
||||||
|
_info=null;
|
||||||
break loop;
|
break loop;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -731,24 +741,45 @@ public class HttpConnection extends AbstractAsyncConnection
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int available()
|
||||||
|
{
|
||||||
|
int available=super.available();
|
||||||
|
if (available==0 && _parser.isInContent() && BufferUtil.hasContent(_requestBuffer))
|
||||||
|
return 1;
|
||||||
|
return available;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void consumeAll()
|
public void consumeAll()
|
||||||
{
|
{
|
||||||
while (true)
|
// Consume content only if the connection is persistent
|
||||||
|
if (!_generator.isPersistent())
|
||||||
{
|
{
|
||||||
|
_parser.setState(HttpParser.State.CLOSED);
|
||||||
synchronized (_inputQ.lock())
|
synchronized (_inputQ.lock())
|
||||||
{
|
{
|
||||||
_inputQ.clear();
|
_inputQ.clear();
|
||||||
}
|
}
|
||||||
if (_parser.isComplete() || _parser.isClosed())
|
}
|
||||||
return;
|
else
|
||||||
try
|
{
|
||||||
|
while (true)
|
||||||
{
|
{
|
||||||
blockForContent();
|
synchronized (_inputQ.lock())
|
||||||
}
|
{
|
||||||
catch(IOException e)
|
_inputQ.clear();
|
||||||
{
|
}
|
||||||
LOG.warn(e);
|
if (_parser.isComplete() || _parser.isClosed())
|
||||||
|
return;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
blockForContent();
|
||||||
|
}
|
||||||
|
catch(IOException e)
|
||||||
|
{
|
||||||
|
LOG.warn(e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ import org.eclipse.jetty.util.BufferUtil;
|
||||||
import org.eclipse.jetty.util.StringUtil;
|
import org.eclipse.jetty.util.StringUtil;
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
|
import org.omg.CORBA._PolicyStub;
|
||||||
|
|
||||||
public class LocalHttpConnector extends HttpConnector
|
public class LocalHttpConnector extends HttpConnector
|
||||||
{
|
{
|
||||||
|
@ -52,19 +53,24 @@ public class LocalHttpConnector extends HttpConnector
|
||||||
|
|
||||||
public ByteBuffer getResponses(ByteBuffer requestsBuffer) throws Exception
|
public ByteBuffer getResponses(ByteBuffer requestsBuffer) throws Exception
|
||||||
{
|
{
|
||||||
int phase=_executor._phaser.getPhase();
|
LOG.debug("getResponses");
|
||||||
|
Phaser phaser=_executor._phaser;
|
||||||
|
int phase = phaser.register(); // the corresponding arrival will be done by the acceptor thread when it takes
|
||||||
LocalEndPoint request = new LocalEndPoint();
|
LocalEndPoint request = new LocalEndPoint();
|
||||||
request.setInput(requestsBuffer);
|
request.setInput(requestsBuffer);
|
||||||
_connects.add(request);
|
_connects.add(request);
|
||||||
_executor._phaser.awaitAdvance(phase);
|
phaser.awaitAdvance(phase);
|
||||||
return request.takeOutput();
|
return request.takeOutput();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void executeRequest(String rawRequest)
|
public LocalEndPoint executeRequest(String rawRequest)
|
||||||
{
|
{
|
||||||
|
Phaser phaser=_executor._phaser;
|
||||||
|
int phase = phaser.register(); // the corresponding arrival will be done by the acceptor thread when it takes
|
||||||
LocalEndPoint endp = new LocalEndPoint();
|
LocalEndPoint endp = new LocalEndPoint();
|
||||||
endp.setInput(BufferUtil.toBuffer(rawRequest,StringUtil.__UTF8_CHARSET));
|
endp.setInput(BufferUtil.toBuffer(rawRequest,StringUtil.__UTF8_CHARSET));
|
||||||
_connects.add(endp);
|
_connects.add(endp);
|
||||||
|
return endp;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -72,12 +78,10 @@ public class LocalHttpConnector extends HttpConnector
|
||||||
{
|
{
|
||||||
LOG.debug("accepting {}",acceptorID);
|
LOG.debug("accepting {}",acceptorID);
|
||||||
LocalEndPoint endp = _connects.take();
|
LocalEndPoint endp = _connects.take();
|
||||||
_executor._phaser.register();
|
|
||||||
HttpConnection connection=new HttpConnection(this,endp,getServer());
|
HttpConnection connection=new HttpConnection(this,endp,getServer());
|
||||||
endp.setAsyncConnection(connection);
|
endp.setAsyncConnection(connection);
|
||||||
LOG.debug("accepted {} {}",endp,connection);
|
|
||||||
connection.onOpen();
|
connection.onOpen();
|
||||||
_executor._phaser.arriveAndDeregister();
|
_executor._phaser.arriveAndDeregister(); // arrive for the register done in getResponses
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -109,7 +113,7 @@ public class LocalHttpConnector extends HttpConnector
|
||||||
@Override
|
@Override
|
||||||
protected boolean onAdvance(int phase, int registeredParties)
|
protected boolean onAdvance(int phase, int registeredParties)
|
||||||
{
|
{
|
||||||
return super.onAdvance(phase,registeredParties);
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -123,6 +127,7 @@ public class LocalHttpConnector extends HttpConnector
|
||||||
public void execute(final Runnable task)
|
public void execute(final Runnable task)
|
||||||
{
|
{
|
||||||
_phaser.register();
|
_phaser.register();
|
||||||
|
LOG.debug("{} execute {} {}",this,task,_phaser);
|
||||||
_executor.execute(new Runnable()
|
_executor.execute(new Runnable()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
|
@ -141,17 +146,26 @@ public class LocalHttpConnector extends HttpConnector
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class LocalEndPoint extends AsyncByteArrayEndPoint
|
public class LocalEndPoint extends AsyncByteArrayEndPoint
|
||||||
{
|
{
|
||||||
LocalEndPoint()
|
LocalEndPoint()
|
||||||
{
|
{
|
||||||
setGrowOutput(true);
|
setGrowOutput(true);
|
||||||
|
setMaxIdleTime(LocalHttpConnector.this.getMaxIdleTime());
|
||||||
}
|
}
|
||||||
|
|
||||||
LocalEndPoint(CountDownLatch onCloseLatch)
|
LocalEndPoint(CountDownLatch onCloseLatch)
|
||||||
{
|
{
|
||||||
this();
|
this();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void addInput(String s)
|
||||||
|
{
|
||||||
|
// TODO this is a busy wait
|
||||||
|
while(getIn()==null || BufferUtil.hasContent(getIn()))
|
||||||
|
Thread.yield();
|
||||||
|
setInput(BufferUtil.toBuffer(s,StringUtil.__UTF8_CHARSET));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,75 @@
|
||||||
|
package org.eclipse.jetty.server;
|
||||||
|
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.util.log.Log;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class LocalHttpConnectorTest
|
||||||
|
{
|
||||||
|
private Server _server;
|
||||||
|
private LocalHttpConnector _connector;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void init() throws Exception
|
||||||
|
{
|
||||||
|
_server = new Server();
|
||||||
|
_connector = new LocalHttpConnector();
|
||||||
|
_server.addConnector(_connector);
|
||||||
|
_server.setHandler(new DumpHandler());
|
||||||
|
_server.start();
|
||||||
|
//_server.dumpStdErr();
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tini() throws Exception
|
||||||
|
{
|
||||||
|
_server.stop();
|
||||||
|
_server=null;
|
||||||
|
_connector=null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testOneGET() throws Exception
|
||||||
|
{
|
||||||
|
String response=_connector.getResponses("GET /R1 HTTP/1.0\r\n\r\n");
|
||||||
|
|
||||||
|
assertThat(response,containsString("HTTP/1.1 200 OK"));
|
||||||
|
assertThat(response,containsString("pathInfo=/R1"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTwoGETs() throws Exception
|
||||||
|
{
|
||||||
|
String response=_connector.getResponses(
|
||||||
|
"GET /R1 HTTP/1.1\r\n"+
|
||||||
|
"Host: localhost\r\n"+
|
||||||
|
"\r\n"+
|
||||||
|
"GET /R2 HTTP/1.0\r\n\r\n");
|
||||||
|
|
||||||
|
assertThat(response,containsString("HTTP/1.1 200 OK"));
|
||||||
|
assertThat(response,containsString("pathInfo=/R1"));
|
||||||
|
|
||||||
|
response=response.substring(response.indexOf("</html>")+8);
|
||||||
|
|
||||||
|
assertThat(response,containsString("HTTP/1.1 200 OK"));
|
||||||
|
assertThat(response,containsString("pathInfo=/R2"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGETandGET() throws Exception
|
||||||
|
{
|
||||||
|
String response=_connector.getResponses("GET /R1 HTTP/1.0\r\n\r\n");
|
||||||
|
assertThat(response,containsString("HTTP/1.1 200 OK"));
|
||||||
|
assertThat(response,containsString("pathInfo=/R1"));
|
||||||
|
|
||||||
|
response=_connector.getResponses("GET /R2 HTTP/1.0\r\n\r\n");
|
||||||
|
assertThat(response,containsString("HTTP/1.1 200 OK"));
|
||||||
|
assertThat(response,containsString("pathInfo=/R2"));
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,19 +0,0 @@
|
||||||
package org.eclipse.jetty.server;
|
|
||||||
|
|
||||||
public class LocalServer
|
|
||||||
{
|
|
||||||
|
|
||||||
public static void main(String[] s) throws Exception
|
|
||||||
{
|
|
||||||
Server server = new Server();
|
|
||||||
LocalHttpConnector connector = new LocalHttpConnector();
|
|
||||||
server.addConnector(connector);
|
|
||||||
server.setHandler(new DumpHandler());
|
|
||||||
server.start();
|
|
||||||
server.dumpStdErr();
|
|
||||||
|
|
||||||
System.err.println(connector.getResponses("GET / HTTP/1.0\r\n\r\n"));
|
|
||||||
|
|
||||||
server.stop();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -19,6 +19,8 @@
|
||||||
*/
|
*/
|
||||||
package org.eclipse.jetty.server;
|
package org.eclipse.jetty.server;
|
||||||
|
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.not;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
@ -29,7 +31,10 @@ import java.util.List;
|
||||||
import org.eclipse.jetty.http.HttpFields;
|
import org.eclipse.jetty.http.HttpFields;
|
||||||
import org.eclipse.jetty.server.handler.ContextHandler;
|
import org.eclipse.jetty.server.handler.ContextHandler;
|
||||||
import org.eclipse.jetty.server.handler.HandlerCollection;
|
import org.eclipse.jetty.server.handler.HandlerCollection;
|
||||||
|
import org.eclipse.jetty.util.log.Log;
|
||||||
|
import org.hamcrest.Matchers;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
|
import org.junit.Assert;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -46,6 +51,7 @@ public class RFC2616Test
|
||||||
{
|
{
|
||||||
server = new Server();
|
server = new Server();
|
||||||
connector = new LocalHttpConnector();
|
connector = new LocalHttpConnector();
|
||||||
|
connector.setMaxIdleTime(10000);
|
||||||
server.addConnector(connector);
|
server.addConnector(connector);
|
||||||
|
|
||||||
ContextHandler vcontext=new ContextHandler();
|
ContextHandler vcontext=new ContextHandler();
|
||||||
|
@ -102,66 +108,136 @@ public class RFC2616Test
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test3_6()
|
public void test3_6_a() throws Exception
|
||||||
{
|
{
|
||||||
String response=null;
|
String response=null;
|
||||||
try
|
int offset=0;
|
||||||
{
|
|
||||||
int offset=0;
|
|
||||||
|
|
||||||
// Chunk last
|
// Chunk last
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked,identity\n"+"Content-Type: text/plain\n"
|
response=connector.getResponses(
|
||||||
+"\015\012"+"5;\015\012"+"123\015\012\015\012"+"0;\015\012\015\012");
|
"GET /R1 HTTP/1.1\n"+
|
||||||
checkContains(response,offset,"HTTP/1.1 400 Bad","Chunked last");
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: chunked,identity\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"\015\012"+
|
||||||
|
"5;\015\012"+
|
||||||
|
"123\015\012\015\012"+
|
||||||
|
"0;\015\012\015\012");
|
||||||
|
checkContains(response,offset,"HTTP/1.1 400 Bad","Chunked last");
|
||||||
|
}
|
||||||
|
|
||||||
// Chunked
|
@Test
|
||||||
offset=0;
|
public void test3_6_b() throws Exception
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked\n"+"Content-Type: text/plain\n"+"\n"+"2;\n"
|
{
|
||||||
+"12\n"+"3;\n"+"345\n"+"0;\n\n"+
|
String response=null;
|
||||||
|
int offset=0;
|
||||||
|
|
||||||
"GET /R2 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked\n"+"Content-Type: text/plain\n"+"\n"+"4;\n"+"6789\n"+"5;\n"+"abcde\n"
|
// Chunked
|
||||||
+"0;\n\n"+
|
response=connector.getResponses(
|
||||||
|
"GET /R1 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: chunked\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"\n"+
|
||||||
|
"2;\n"+
|
||||||
|
"12\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"345\n"+
|
||||||
|
"0;\n\n"+
|
||||||
|
|
||||||
"GET /R3 HTTP/1.1\n"+"Host: localhost\n"+"Connection: close\n"+"\n");
|
"GET /R2 HTTP/1.1\n"+
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
"Host: localhost\n"+
|
||||||
offset=checkContains(response,offset,"12345","3.6.1 Chunking");
|
"Transfer-Encoding: chunked\n"+
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
"Content-Type: text/plain\n"+
|
||||||
offset=checkContains(response,offset,"6789abcde","3.6.1 Chunking");
|
"\n"+
|
||||||
offset=checkContains(response,offset,"/R3","3.6.1 Chunking");
|
"4;\n"+
|
||||||
|
"6789\n"+
|
||||||
|
"5;\n"+
|
||||||
|
"abcde\n"+
|
||||||
|
"0;\n\n"+
|
||||||
|
|
||||||
// Chunked
|
"GET /R3 HTTP/1.1\n"+
|
||||||
offset=0;
|
"Host: localhost\n"+
|
||||||
response=connector.getResponses("POST /R1 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked\n"+"Content-Type: text/plain\n"+"\n"+"3;\n"
|
"Connection: close\n"+
|
||||||
+"fgh\n"+"3;\n"+"Ijk\n"+"0;\n\n"+
|
"\n");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"12345","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"6789abcde","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"/R3","3.6.1 Chunking");
|
||||||
|
|
||||||
"POST /R2 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked\n"+"Content-Type: text/plain\n"+"\n"+"4;\n"+"lmno\n"+"5;\n"+"Pqrst\n"
|
}
|
||||||
+"0;\n\n"+
|
|
||||||
|
|
||||||
"GET /R3 HTTP/1.1\n"+"Host: localhost\n"+"Connection: close\n"+"\n");
|
@Test
|
||||||
checkNotContained(response,"HTTP/1.1 100","3.6.1 Chunking");
|
public void test3_6_c() throws Exception
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
{
|
||||||
offset=checkContains(response,offset,"fghIjk","3.6.1 Chunking");
|
String response=null;
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
int offset=0;
|
||||||
offset=checkContains(response,offset,"lmnoPqrst","3.6.1 Chunking");
|
|
||||||
offset=checkContains(response,offset,"/R3","3.6.1 Chunking");
|
|
||||||
|
|
||||||
// Chunked and keep alive
|
response=connector.getResponses(
|
||||||
offset=0;
|
"POST /R1 HTTP/1.1\n"+
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked\n"+"Content-Type: text/plain\n"
|
"Host: localhost\n"+
|
||||||
+"Connection: keep-alive\n"+"\n"+"3;\n"+"123\n"+"3;\n"+"456\n"+"0;\n\n"+
|
"Transfer-Encoding: chunked\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"fgh\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"Ijk\n"+
|
||||||
|
"0;\n\n"+
|
||||||
|
|
||||||
|
"POST /R2 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: chunked\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"\n"+
|
||||||
|
"4;\n"+
|
||||||
|
"lmno\n"+
|
||||||
|
"5;\n"+
|
||||||
|
"Pqrst\n"+
|
||||||
|
"0;\n\n"+
|
||||||
|
|
||||||
|
"GET /R3 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Connection: close\n"+
|
||||||
|
"\n");
|
||||||
|
checkNotContained(response,"HTTP/1.1 100","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"fghIjk","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"lmnoPqrst","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"/R3","3.6.1 Chunking");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test3_6_d() throws Exception
|
||||||
|
{
|
||||||
|
String response=null;
|
||||||
|
int offset=0;
|
||||||
|
|
||||||
|
// Chunked and keep alive
|
||||||
|
response=connector.getResponses(
|
||||||
|
"GET /R1 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: chunked\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"Connection: keep-alive\n"+
|
||||||
|
"\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"123\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"456\n"+
|
||||||
|
"0;\n\n"+
|
||||||
|
|
||||||
|
"GET /R2 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Connection: close\n"+
|
||||||
|
"\n");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking")+10;
|
||||||
|
offset=checkContains(response,offset,"123456","3.6.1 Chunking");
|
||||||
|
offset=checkContains(response,offset,"/R2","3.6.1 Chunking")+10;
|
||||||
|
|
||||||
"GET /R2 HTTP/1.1\n"+"Host: localhost\n"+"Connection: close\n"+"\n");
|
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","3.6.1 Chunking")+10;
|
|
||||||
offset=checkContains(response,offset,"123456","3.6.1 Chunking");
|
|
||||||
offset=checkContains(response,offset,"/R2","3.6.1 Chunking")+10;
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
assertTrue(false);
|
|
||||||
if (response!=null)
|
|
||||||
System.err.println(response);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -189,69 +265,111 @@ public class RFC2616Test
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test4_4()
|
public void test4_4_2() throws Exception
|
||||||
{
|
{
|
||||||
try
|
|
||||||
{
|
|
||||||
String response;
|
String response;
|
||||||
int offset=0;
|
int offset=0;
|
||||||
|
|
||||||
// 2
|
// 2
|
||||||
// If _content length not used, second request will not be read.
|
// If _content length not used, second request will not be read.
|
||||||
offset=0;
|
response=connector.getResponses(
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: identity\n"+"Content-Type: text/plain\n"
|
"GET /R1 HTTP/1.1\n"+
|
||||||
+"Content-Length: 5\n"+"\n"+"123\015\012"+
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: identity\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"Content-Length: 5\n"+
|
||||||
|
"\n"+
|
||||||
|
"123\015\012"+
|
||||||
|
|
||||||
"GET /R2 HTTP/1.1\n"+"Host: localhost\n"+"Connection: close\n"+"\n");
|
"GET /R2 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: other\n"+
|
||||||
|
"Connection: close\n"+
|
||||||
|
"\n");
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200 OK","2. identity")+10;
|
offset=checkContains(response,offset,"HTTP/1.1 200 OK","2. identity")+10;
|
||||||
offset=checkContains(response,offset,"/R1","2. identity")+3;
|
offset=checkContains(response,offset,"/R1","2. identity")+3;
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200 OK","2. identity")+10;
|
offset=checkContains(response,offset,"HTTP/1.1 200 OK","2. identity")+10;
|
||||||
offset=checkContains(response,offset,"/R2","2. identity")+3;
|
offset=checkContains(response,offset,"/R2","2. identity")+3;
|
||||||
|
|
||||||
// 3
|
|
||||||
// _content length is ignored, as chunking is used. If it is
|
|
||||||
// not ignored, the second request wont be seen.
|
|
||||||
offset=0;
|
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Transfer-Encoding: chunked\n"+"Content-Type: text/plain\n"
|
|
||||||
+"Content-Length: 100\n"+"\n"+"3;\n"+"123\n"+"3;\n"+"456\n"+"0;\n"+"\n"+
|
|
||||||
|
|
||||||
"GET /R2 HTTP/1.1\n"+"Host: localhost\n"+"Connection: close\n"+"Content-Type: text/plain\n"+"Content-Length: 6\n"+"\n"+"123456");
|
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200 OK","3. ignore c-l")+1;
|
|
||||||
offset=checkContains(response,offset,"/R1","3. ignore c-l")+1;
|
|
||||||
offset=checkContains(response,offset,"123456","3. ignore c-l")+1;
|
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200 OK","3. ignore c-l")+1;
|
|
||||||
offset=checkContains(response,offset,"/R2","3. _content-length")+1;
|
|
||||||
offset=checkContains(response,offset,"123456","3. _content-length")+1;
|
|
||||||
|
|
||||||
// No _content length
|
|
||||||
assertTrue("Skip 411 checks as IE breaks this rule",true);
|
|
||||||
// offset=0; connector.reopen();
|
|
||||||
// response=connector.getResponses("GET /R2 HTTP/1.1\n"+
|
|
||||||
// "Host: localhost\n"+
|
|
||||||
// "Content-Type: text/plain\n"+
|
|
||||||
// "Connection: close\n"+
|
|
||||||
// "\n"+
|
|
||||||
// "123456");
|
|
||||||
// offset=checkContains(response,offset,
|
|
||||||
// "HTTP/1.1 411 ","411 length required")+10;
|
|
||||||
// offset=0; connector.reopen();
|
|
||||||
// response=connector.getResponses("GET /R2 HTTP/1.0\n"+
|
|
||||||
// "Content-Type: text/plain\n"+
|
|
||||||
// "\n"+
|
|
||||||
// "123456");
|
|
||||||
// offset=checkContains(response,offset,
|
|
||||||
// "HTTP/1.0 411 ","411 length required")+10;
|
|
||||||
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
assertTrue(false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test5_2() throws Exception
|
public void test4_4_3() throws Exception
|
||||||
|
{
|
||||||
|
String response;
|
||||||
|
int offset=0;
|
||||||
|
// 3
|
||||||
|
// _content length is ignored, as chunking is used. If it is
|
||||||
|
// not ignored, the second request wont be seen.
|
||||||
|
offset=0;
|
||||||
|
response=connector.getResponses(
|
||||||
|
"GET /R1 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Transfer-Encoding: chunked\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"Content-Length: 100\n"+
|
||||||
|
"\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"123\n"+
|
||||||
|
"3;\n"+
|
||||||
|
"456\n"+
|
||||||
|
"0;\n"+
|
||||||
|
"\n"+
|
||||||
|
|
||||||
|
"GET /R2 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Connection: close\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"Content-Length: 6\n"+
|
||||||
|
"\n"+
|
||||||
|
"abcdef");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200 OK","3. ignore c-l")+1;
|
||||||
|
offset=checkContains(response,offset,"/R1","3. ignore c-l")+1;
|
||||||
|
offset=checkContains(response,offset,"123456","3. ignore c-l")+1;
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200 OK","3. ignore c-l")+1;
|
||||||
|
offset=checkContains(response,offset,"/R2","3. _content-length")+1;
|
||||||
|
offset=checkContains(response,offset,"abcdef","3. _content-length")+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test4_4_4() throws Exception
|
||||||
|
{
|
||||||
|
// No _content length
|
||||||
|
assertTrue("Skip 411 checks as IE breaks this rule",true);
|
||||||
|
// offset=0; connector.reopen();
|
||||||
|
// response=connector.getResponses("GET /R2 HTTP/1.1\n"+
|
||||||
|
// "Host: localhost\n"+
|
||||||
|
// "Content-Type: text/plain\n"+
|
||||||
|
// "Connection: close\n"+
|
||||||
|
// "\n"+
|
||||||
|
// "123456");
|
||||||
|
// offset=checkContains(response,offset,
|
||||||
|
// "HTTP/1.1 411 ","411 length required")+10;
|
||||||
|
// offset=0; connector.reopen();
|
||||||
|
// response=connector.getResponses("GET /R2 HTTP/1.0\n"+
|
||||||
|
// "Content-Type: text/plain\n"+
|
||||||
|
// "\n"+
|
||||||
|
// "123456");
|
||||||
|
// offset=checkContains(response,offset,
|
||||||
|
// "HTTP/1.0 411 ","411 length required")+10;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test5_2_1() throws Exception
|
||||||
|
{
|
||||||
|
String response;
|
||||||
|
int offset=0;
|
||||||
|
|
||||||
|
// Default Host
|
||||||
|
offset=0;
|
||||||
|
response=connector.getResponses("GET http://VirtualHost:8888/path/R1 HTTP/1.1\n"+"Host: wronghost\n"+"\n");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","Default host")+1;
|
||||||
|
offset=checkContains(response,offset,"Virtual Dump","virtual host")+1;
|
||||||
|
offset=checkContains(response,offset,"pathInfo=/path/R1","Default host")+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test5_2_2() throws Exception
|
||||||
{
|
{
|
||||||
String response;
|
String response;
|
||||||
int offset=0;
|
int offset=0;
|
||||||
|
@ -259,11 +377,24 @@ public class RFC2616Test
|
||||||
// Default Host
|
// Default Host
|
||||||
offset=0;
|
offset=0;
|
||||||
response=connector.getResponses("GET /path/R1 HTTP/1.1\n"+"Host: localhost\n"+"\n");
|
response=connector.getResponses("GET /path/R1 HTTP/1.1\n"+"Host: localhost\n"+"\n");
|
||||||
|
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","Default host")+1;
|
offset=checkContains(response,offset,"HTTP/1.1 200","Default host")+1;
|
||||||
offset=checkContains(response,offset,"Dump HttpHandler","Default host")+1;
|
offset=checkContains(response,offset,"Dump HttpHandler","Default host")+1;
|
||||||
offset=checkContains(response,offset,"pathInfo=/path/R1","Default host")+1;
|
offset=checkContains(response,offset,"pathInfo=/path/R1","Default host")+1;
|
||||||
|
|
||||||
|
// Virtual Host
|
||||||
|
offset=0;
|
||||||
|
response=connector.getResponses("GET /path/R2 HTTP/1.1\n"+"Host: VirtualHost\n"+"\n");
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","Default host")+1;
|
||||||
|
offset=checkContains(response,offset,"Virtual Dump","virtual host")+1;
|
||||||
|
offset=checkContains(response,offset,"pathInfo=/path/R2","Default host")+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test5_2() throws Exception
|
||||||
|
{
|
||||||
|
String response;
|
||||||
|
int offset=0;
|
||||||
|
|
||||||
// Virtual Host
|
// Virtual Host
|
||||||
offset=0;
|
offset=0;
|
||||||
response=connector.getResponses("GET /path/R1 HTTP/1.1\n"+"Host: VirtualHost\n"+"\n");
|
response=connector.getResponses("GET /path/R1 HTTP/1.1\n"+"Host: VirtualHost\n"+"\n");
|
||||||
|
@ -319,38 +450,39 @@ public class RFC2616Test
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test8_2() throws Exception
|
public void test10_4_18() throws Exception
|
||||||
{
|
{
|
||||||
String response;
|
String response;
|
||||||
int offset=0;
|
int offset=0;
|
||||||
// No Expect 100
|
|
||||||
offset=0;
|
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+
|
|
||||||
"Host: localhost\n"+
|
|
||||||
"Content-Type: text/plain\n"+
|
|
||||||
"Content-Length: 8\n"+
|
|
||||||
"\n",true);
|
|
||||||
|
|
||||||
assertTrue("8.2.3 no expect 100",response==null || response.length()==0);
|
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+
|
|
||||||
"Host: localhost\n"+
|
|
||||||
"Content-Type: text/plain\n"+
|
|
||||||
"Content-Length: 8\n"+
|
|
||||||
"\n"+
|
|
||||||
"AbCdEf\015\012",true);
|
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","8.2.3 no expect 100")+1;
|
|
||||||
offset=checkContains(response,offset,"AbCdEf","8.2.3 no expect 100")+1;
|
|
||||||
|
|
||||||
// Expect Failure
|
// Expect Failure
|
||||||
offset=0;
|
offset=0;
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Expect: unknown\n"+"Content-Type: text/plain\n"+"Content-Length: 8\n"
|
response=connector.getResponses(
|
||||||
+"\n");
|
"GET /R1 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Expect: unknown\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"Content-Length: 8\n"+
|
||||||
|
"\n");
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 417","8.2.3 expect failure")+1;
|
offset=checkContains(response,offset,"HTTP/1.1 417","8.2.3 expect failure")+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test8_2_3_dash5() throws Exception
|
||||||
|
{
|
||||||
|
String response;
|
||||||
|
int offset=0;
|
||||||
// Expect with body
|
// Expect with body
|
||||||
offset=0;
|
offset=0;
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+"Host: localhost\n"+"Expect: 100-continue\n"+"Content-Type: text/plain\n"
|
response=connector.getResponses(
|
||||||
+"Content-Length: 8\n"+"Connection: close\n"+"\n"+"123456\015\012");
|
"GET /R1 HTTP/1.1\n"+
|
||||||
|
"Host: localhost\n"+
|
||||||
|
"Expect: 100-continue\n"+
|
||||||
|
"Content-Type: text/plain\n"+
|
||||||
|
"Content-Length: 8\n"+
|
||||||
|
"Connection: close\n"+
|
||||||
|
"\n"+
|
||||||
|
"123456\015\012");
|
||||||
checkNotContained(response,offset,"HTTP/1.1 100 ","8.2.3 expect 100");
|
checkNotContained(response,offset,"HTTP/1.1 100 ","8.2.3 expect 100");
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200 OK","8.2.3 expect with body")+1;
|
offset=checkContains(response,offset,"HTTP/1.1 200 OK","8.2.3 expect with body")+1;
|
||||||
}
|
}
|
||||||
|
@ -358,23 +490,27 @@ public class RFC2616Test
|
||||||
@Test
|
@Test
|
||||||
public void test8_2_3() throws Exception
|
public void test8_2_3() throws Exception
|
||||||
{
|
{
|
||||||
String response;
|
|
||||||
int offset=0;
|
int offset=0;
|
||||||
// Expect 100
|
// Expect 100
|
||||||
response=connector.getResponses("GET /R1 HTTP/1.1\n"+
|
LocalHttpConnector.LocalEndPoint endp =connector.executeRequest("GET /R1 HTTP/1.1\n"+
|
||||||
"Host: localhost\n"+
|
"Host: localhost\n"+
|
||||||
"Connection: close\n"+
|
"Connection: close\n"+
|
||||||
"Expect: 100-continue\n"+
|
"Expect: 100-continue\n"+
|
||||||
"Content-Type: text/plain\n"+
|
"Content-Type: text/plain\n"+
|
||||||
"Content-Length: 8\n"+
|
"Content-Length: 8\n"+
|
||||||
"\n",true);
|
"\n");
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 100 ","8.2.3 expect 100")+1;
|
Thread.sleep(200);
|
||||||
checkNotContained(response,offset,"HTTP/1.1 200","8.2.3 expect 100");
|
String infomational= endp.takeOutputString();
|
||||||
/* can't test this with localconnector.
|
offset=checkContains(infomational,offset,"HTTP/1.1 100 ","8.2.3 expect 100")+1;
|
||||||
response=connector.getResponses("654321\015\012");
|
checkNotContained(infomational,offset,"HTTP/1.1 200","8.2.3 expect 100");
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 200","8.2.3 expect 100")+1;
|
|
||||||
offset=checkContains(response,offset,"654321","8.2.3 expect 100")+1;
|
endp.addInput("654321\015\012");
|
||||||
*/
|
|
||||||
|
Thread.sleep(200);
|
||||||
|
String response= endp.takeOutputString();
|
||||||
|
offset=0;
|
||||||
|
offset=checkContains(response,offset,"HTTP/1.1 200","8.2.3 expect 100")+1;
|
||||||
|
offset=checkContains(response,offset,"654321","8.2.3 expect 100")+1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -390,7 +526,7 @@ public class RFC2616Test
|
||||||
"Expect: 100-continue\n"+
|
"Expect: 100-continue\n"+
|
||||||
"Content-Type: text/plain\n"+
|
"Content-Type: text/plain\n"+
|
||||||
"Content-Length: 8\n"+
|
"Content-Length: 8\n"+
|
||||||
"\n",true);
|
"\n");
|
||||||
checkNotContained(response,offset,"HTTP/1.1 100","8.2.3 expect 100");
|
checkNotContained(response,offset,"HTTP/1.1 100","8.2.3 expect 100");
|
||||||
offset=checkContains(response,offset,"HTTP/1.1 401 ","8.2.3 expect 100")+1;
|
offset=checkContains(response,offset,"HTTP/1.1 401 ","8.2.3 expect 100")+1;
|
||||||
offset=checkContains(response,offset,"Connection: close","8.2.3 expect 100")+1;
|
offset=checkContains(response,offset,"Connection: close","8.2.3 expect 100")+1;
|
||||||
|
@ -819,24 +955,16 @@ public class RFC2616Test
|
||||||
|
|
||||||
private int checkContains(String s, int offset, String c, String test)
|
private int checkContains(String s, int offset, String c, String test)
|
||||||
{
|
{
|
||||||
int o=s.indexOf(c,offset);
|
// System.err.println("===");
|
||||||
if (o<offset)
|
// System.err.println(s);
|
||||||
{
|
// System.err.println("---");
|
||||||
System.err.println("FAILED: "+test);
|
Assert.assertThat(test,s.substring(offset),containsString(c));
|
||||||
System.err.println("'"+c+"' not in:");
|
return s.indexOf(c,offset);
|
||||||
System.err.println(s.substring(offset));
|
|
||||||
System.err.flush();
|
|
||||||
System.out.println("--\n"+s);
|
|
||||||
System.out.flush();
|
|
||||||
assertTrue(test,false);
|
|
||||||
}
|
|
||||||
return o;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkNotContained(String s, int offset, String c, String test)
|
private void checkNotContained(String s, int offset, String c, String test)
|
||||||
{
|
{
|
||||||
int o=s.indexOf(c,offset);
|
Assert.assertThat(test,s.substring(offset),not(containsString(c)));
|
||||||
assertTrue(test,o<offset);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkNotContained(String s, String c, String test)
|
private void checkNotContained(String s, String c, String test)
|
||||||
|
|
|
@ -804,7 +804,7 @@ public class RequestTest
|
||||||
|
|
||||||
String request="POST / HTTP/1.1\r\n"+
|
String request="POST / HTTP/1.1\r\n"+
|
||||||
"Host: whatever\r\n"+
|
"Host: whatever\r\n"+
|
||||||
"Content-Type: "+MimeTypes.FORM_ENCODED+"\r\n"+
|
"Content-Type: "+MimeTypes.Type.FORM_ENCODED.asString()+"\r\n"+
|
||||||
"Content-Length: "+buf.length()+"\r\n"+
|
"Content-Length: "+buf.length()+"\r\n"+
|
||||||
"Connection: close\r\n"+
|
"Connection: close\r\n"+
|
||||||
"\r\n"+
|
"\r\n"+
|
||||||
|
@ -832,7 +832,7 @@ public class RequestTest
|
||||||
{
|
{
|
||||||
((Request)request).setHandled(true);
|
((Request)request).setHandled(true);
|
||||||
|
|
||||||
if (request.getContentLength()>0 && !MimeTypes.FORM_ENCODED.equals(request.getContentType()))
|
if (request.getContentLength()>0 && !MimeTypes.Type.FORM_ENCODED.asString().equals(request.getContentType()))
|
||||||
_content=IO.toString(request.getInputStream());
|
_content=IO.toString(request.getInputStream());
|
||||||
|
|
||||||
if (_checker!=null && _checker.check(request,response))
|
if (_checker!=null && _checker.check(request,response))
|
||||||
|
|
|
@ -33,7 +33,6 @@ import javax.servlet.ServletException;
|
||||||
import javax.servlet.http.Cookie;
|
import javax.servlet.http.Cookie;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import javax.servlet.http.HttpSessionContext;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.http.HttpHeader;
|
import org.eclipse.jetty.http.HttpHeader;
|
||||||
import org.eclipse.jetty.http.HttpURI;
|
import org.eclipse.jetty.http.HttpURI;
|
||||||
|
@ -78,7 +77,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testContentType() throws Exception
|
public void testContentType() throws Exception
|
||||||
{
|
{
|
||||||
AbstractHttpConnection connection = new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer());
|
TestHttpChannel connection = new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer());
|
||||||
Response response = connection.getResponse();
|
Response response = connection.getResponse();
|
||||||
|
|
||||||
assertEquals(null,response.getContentType());
|
assertEquals(null,response.getContentType());
|
||||||
|
@ -133,7 +132,7 @@ public class ResponseTest
|
||||||
public void testLocale() throws Exception
|
public void testLocale() throws Exception
|
||||||
{
|
{
|
||||||
|
|
||||||
AbstractHttpConnection connection = new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer());
|
TestHttpChannel connection = new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer());
|
||||||
Request request = connection.getRequest();
|
Request request = connection.getRequest();
|
||||||
Response response = connection.getResponse();
|
Response response = connection.getResponse();
|
||||||
ContextHandler context = new ContextHandler();
|
ContextHandler context = new ContextHandler();
|
||||||
|
@ -157,7 +156,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testContentTypeCharacterEncoding() throws Exception
|
public void testContentTypeCharacterEncoding() throws Exception
|
||||||
{
|
{
|
||||||
AbstractHttpConnection connection = new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer());
|
TestHttpChannel connection = new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer());
|
||||||
|
|
||||||
Response response = connection.getResponse();
|
Response response = connection.getResponse();
|
||||||
|
|
||||||
|
@ -189,7 +188,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testCharacterEncodingContentType() throws Exception
|
public void testCharacterEncodingContentType() throws Exception
|
||||||
{
|
{
|
||||||
Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()));
|
Response response = new Response(new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer()));
|
||||||
|
|
||||||
response.setCharacterEncoding("utf-8");
|
response.setCharacterEncoding("utf-8");
|
||||||
response.setContentType("foo/bar");
|
response.setContentType("foo/bar");
|
||||||
|
@ -218,7 +217,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testContentTypeWithCharacterEncoding() throws Exception
|
public void testContentTypeWithCharacterEncoding() throws Exception
|
||||||
{
|
{
|
||||||
Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()));
|
Response response = new Response(new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer()));
|
||||||
|
|
||||||
response.setCharacterEncoding("utf16");
|
response.setCharacterEncoding("utf16");
|
||||||
response.setContentType("foo/bar; charset=utf-8");
|
response.setContentType("foo/bar; charset=utf-8");
|
||||||
|
@ -247,7 +246,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testContentTypeWithOther() throws Exception
|
public void testContentTypeWithOther() throws Exception
|
||||||
{
|
{
|
||||||
Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()));
|
Response response = new Response(new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer()));
|
||||||
|
|
||||||
response.setContentType("foo/bar; other=xyz");
|
response.setContentType("foo/bar; other=xyz");
|
||||||
assertEquals("foo/bar; other=xyz",response.getContentType());
|
assertEquals("foo/bar; other=xyz",response.getContentType());
|
||||||
|
@ -270,7 +269,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testContentTypeWithCharacterEncodingAndOther() throws Exception
|
public void testContentTypeWithCharacterEncodingAndOther() throws Exception
|
||||||
{
|
{
|
||||||
Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()));
|
Response response = new Response(new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer()));
|
||||||
|
|
||||||
response.setCharacterEncoding("utf16");
|
response.setCharacterEncoding("utf16");
|
||||||
response.setContentType("foo/bar; charset=utf-8 other=xyz");
|
response.setContentType("foo/bar; charset=utf-8 other=xyz");
|
||||||
|
@ -310,7 +309,7 @@ public class ResponseTest
|
||||||
response.sendError(500, "Database Error");
|
response.sendError(500, "Database Error");
|
||||||
assertEquals(500, response.getStatus());
|
assertEquals(500, response.getStatus());
|
||||||
assertEquals("Database Error", response.getReason());
|
assertEquals("Database Error", response.getReason());
|
||||||
assertEquals("must-revalidate,no-cache,no-store", response.getHeader(HttpHeader.CACHE_CONTROL));
|
assertEquals("must-revalidate,no-cache,no-store", response.getHeader(HttpHeader.CACHE_CONTROL.asString()));
|
||||||
|
|
||||||
response=newResponse();
|
response=newResponse();
|
||||||
|
|
||||||
|
@ -323,14 +322,14 @@ public class ResponseTest
|
||||||
response.sendError(406, "Super Nanny");
|
response.sendError(406, "Super Nanny");
|
||||||
assertEquals(406, response.getStatus());
|
assertEquals(406, response.getStatus());
|
||||||
assertEquals("Super Nanny", response.getReason());
|
assertEquals("Super Nanny", response.getReason());
|
||||||
assertEquals("must-revalidate,no-cache,no-store", response.getHeader(HttpHeader.CACHE_CONTROL));
|
assertEquals("must-revalidate,no-cache,no-store", response.getHeader(HttpHeader.CACHE_CONTROL.asString()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testEncodeRedirect()
|
public void testEncodeRedirect()
|
||||||
throws Exception
|
throws Exception
|
||||||
{
|
{
|
||||||
AbstractHttpConnection connection=new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer());
|
TestHttpChannel connection=new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer());
|
||||||
Response response = new Response(connection);
|
Response response = new Response(connection);
|
||||||
Request request = connection.getRequest();
|
Request request = connection.getRequest();
|
||||||
request.setServerName("myhost");
|
request.setServerName("myhost");
|
||||||
|
@ -395,7 +394,7 @@ public class ResponseTest
|
||||||
for (int i=1;i<tests.length;i++)
|
for (int i=1;i<tests.length;i++)
|
||||||
{
|
{
|
||||||
ByteArrayEndPoint out=new ByteArrayEndPoint(new byte[]{},4096);
|
ByteArrayEndPoint out=new ByteArrayEndPoint(new byte[]{},4096);
|
||||||
AbstractHttpConnection connection=new TestHttpConnection(connector,out, connector.getServer());
|
TestHttpChannel connection=new TestHttpChannel(connector,out, connector.getServer());
|
||||||
Response response = new Response(connection);
|
Response response = new Response(connection);
|
||||||
Request request = connection.getRequest();
|
Request request = connection.getRequest();
|
||||||
request.setServerName("myhost");
|
request.setServerName("myhost");
|
||||||
|
@ -423,7 +422,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testSetBufferSize () throws Exception
|
public void testSetBufferSize () throws Exception
|
||||||
{
|
{
|
||||||
Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()));
|
Response response = new Response(new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer()));
|
||||||
response.setBufferSize(20*1024);
|
response.setBufferSize(20*1024);
|
||||||
response.getWriter().print("hello");
|
response.getWriter().print("hello");
|
||||||
try
|
try
|
||||||
|
@ -487,7 +486,7 @@ public class ResponseTest
|
||||||
@Test
|
@Test
|
||||||
public void testAddCookie() throws Exception
|
public void testAddCookie() throws Exception
|
||||||
{
|
{
|
||||||
Response response = new Response(new TestHttpConnection(connector,new ByteArrayEndPoint(), connector.getServer()));
|
Response response = new Response(new TestHttpChannel(connector,new ByteArrayEndPoint(), connector.getServer()));
|
||||||
|
|
||||||
Cookie cookie=new Cookie("name","value");
|
Cookie cookie=new Cookie("name","value");
|
||||||
cookie.setDomain("domain");
|
cookie.setDomain("domain");
|
||||||
|
@ -507,9 +506,9 @@ public class ResponseTest
|
||||||
ByteArrayEndPoint endPoint = new ByteArrayEndPoint();
|
ByteArrayEndPoint endPoint = new ByteArrayEndPoint();
|
||||||
endPoint.setOutput(new ByteArrayBuffer(1024));
|
endPoint.setOutput(new ByteArrayBuffer(1024));
|
||||||
endPoint.setGrowOutput(true);
|
endPoint.setGrowOutput(true);
|
||||||
AbstractHttpConnection connection=new TestHttpConnection(connector, endPoint, connector.getServer());
|
TestHttpChannel connection=new TestHttpChannel(connector, endPoint, connector.getServer());
|
||||||
connection.getGenerator().reset();
|
connection.getGenerator().reset();
|
||||||
AbstractHttpConnection.setCurrentHttpChannel(connection);
|
TestHttpChannel.setCurrentHttpChannel(connection);
|
||||||
Response response = connection.getResponse();
|
Response response = connection.getResponse();
|
||||||
connection.getRequest().setRequestURI("/test");
|
connection.getRequest().setRequestURI("/test");
|
||||||
return response;
|
return response;
|
||||||
|
@ -609,24 +608,20 @@ public class ResponseTest
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static class TestHttpConnection extends AbstractHttpConnection
|
static class TestHttpChannel extends HttpChannel
|
||||||
{
|
{
|
||||||
|
|
||||||
public TestHttpConnection(Connector connector, EndPoint endpoint, Server server)
|
public TestHttpChannel(Connector connector, EndPoint endpoint, Server server)
|
||||||
{
|
{
|
||||||
|
super(server,null,null);
|
||||||
super(connector,endpoint,server);
|
super(connector,endpoint,server);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TestHttpConnection(Connector connector, EndPoint endpoint, Server server, Parser parser, Generator generator, Request request)
|
public TestHttpChannel(Connector connector, EndPoint endpoint, Server server, Parser parser, Generator generator, Request request)
|
||||||
{
|
{
|
||||||
super(connector,endpoint,server,parser,generator,request);
|
super(connector,endpoint,server,parser,generator,request);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public AsyncConnection handle() throws IOException
|
|
||||||
{
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -371,7 +371,7 @@ public class QueuedThreadPool extends AbstractLifeCycle implements SizedThreadPo
|
||||||
public void execute(Runnable job)
|
public void execute(Runnable job)
|
||||||
{
|
{
|
||||||
if (!dispatch(job))
|
if (!dispatch(job))
|
||||||
throw new RejectedExecutionException();
|
throw new RejectedExecutionException(toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
|
@ -500,15 +500,13 @@ public class QueuedThreadPool extends AbstractLifeCycle implements SizedThreadPo
|
||||||
|
|
||||||
AggregateLifeCycle.dumpObject(out,this);
|
AggregateLifeCycle.dumpObject(out,this);
|
||||||
AggregateLifeCycle.dump(out,indent,dump);
|
AggregateLifeCycle.dump(out,indent,dump);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
@Override
|
@Override
|
||||||
public String toString()
|
public String toString()
|
||||||
{
|
{
|
||||||
return _name+"{"+getMinThreads()+"<="+getIdleThreads()+"<="+getThreads()+"/"+getMaxThreads()+","+(_jobs==null?-1:_jobs.size())+"}";
|
return String.format("%s{%b,%d<=%d<=%d/%d,%d}",_name,isRunning(),getMinThreads(),getIdleThreads(),getThreads(),getMaxThreads(),(_jobs==null?-1:_jobs.size()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------ */
|
/* ------------------------------------------------------------ */
|
||||||
|
|
Loading…
Reference in New Issue