Reworked the tests on EPILOGUE and multiple content. All tests are passing.
Signed-off-by: Lachlan Roberts <lachlan@webtide.com>
This commit is contained in:
parent
faa32f0c71
commit
20c9fb45f8
|
@ -323,38 +323,11 @@ public class MultiPartParserTest
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testEpilogue() {
|
public void testEpilogue() {
|
||||||
List<String> fields = new ArrayList<>();
|
TestHandler handler = new TestHandler();
|
||||||
List<String> content = new ArrayList<>();
|
MultiPartParser parser = new MultiPartParser(handler,"BOUNDARY");
|
||||||
MultiPartParser parser = new MultiPartParser(new MultiPartParser.Handler()
|
|
||||||
{
|
|
||||||
|
|
||||||
@Override
|
ByteBuffer data = BufferUtil.toBuffer(""
|
||||||
public void parsedField(String name, String value)
|
+ "--BOUNDARY\r\n"
|
||||||
{
|
|
||||||
fields.add(name+": "+value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean headerComplete()
|
|
||||||
{
|
|
||||||
fields.add("<<COMPLETE>>");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean content(ByteBuffer buffer, boolean last)
|
|
||||||
{
|
|
||||||
if (BufferUtil.hasContent(buffer))
|
|
||||||
content.add(BufferUtil.toString(buffer));
|
|
||||||
if (last)
|
|
||||||
content.add("<<LAST>>");
|
|
||||||
return last;
|
|
||||||
}
|
|
||||||
|
|
||||||
},"BOUNDARY");
|
|
||||||
ByteBuffer data = BufferUtil.toBuffer("");
|
|
||||||
|
|
||||||
data = BufferUtil.toBuffer("--BOUNDARY\r\n"
|
|
||||||
+ "name: value\n"
|
+ "name: value\n"
|
||||||
+ "\r\n"
|
+ "\r\n"
|
||||||
+ "Hello\r\n"
|
+ "Hello\r\n"
|
||||||
|
@ -364,10 +337,12 @@ public class MultiPartParserTest
|
||||||
+ "--BOUNDARY--"
|
+ "--BOUNDARY--"
|
||||||
+ "\r\n"
|
+ "\r\n"
|
||||||
+ "--BOUNDARY");
|
+ "--BOUNDARY");
|
||||||
|
|
||||||
|
|
||||||
parser.parse(data,false);
|
parser.parse(data,false);
|
||||||
assertThat(parser.getState(), is(State.DELIMITER));
|
assertThat(parser.getState(), is(State.DELIMITER));
|
||||||
assertThat(fields,Matchers.contains("name: value", "<<COMPLETE>>"));
|
assertThat(handler.fields,Matchers.contains("name: value", "<<COMPLETE>>"));
|
||||||
assertThat(content,Matchers.contains("Hello","<<LAST>>"));
|
assertThat(handler.content,Matchers.contains("Hello","<<LAST>>"));
|
||||||
|
|
||||||
parser.parse(data,false);
|
parser.parse(data,false);
|
||||||
assertThat(parser.getState(), is(State.EPILOGUE));
|
assertThat(parser.getState(), is(State.EPILOGUE));
|
||||||
|
@ -380,44 +355,17 @@ public class MultiPartParserTest
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMultipleContent() {
|
public void testMultipleContent() {
|
||||||
List<String> fields = new ArrayList<>();
|
TestHandler handler = new TestHandler();
|
||||||
List<String> content = new ArrayList<>();
|
MultiPartParser parser = new MultiPartParser(handler,"BOUNDARY");
|
||||||
MultiPartParser parser = new MultiPartParser(new MultiPartParser.Handler()
|
|
||||||
{
|
|
||||||
|
|
||||||
@Override
|
ByteBuffer data = BufferUtil.toBuffer(""
|
||||||
public void parsedField(String name, String value)
|
+ "--BOUNDARY\r\n"
|
||||||
{
|
|
||||||
fields.add(name+": "+value);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean headerComplete()
|
|
||||||
{
|
|
||||||
fields.add("<<COMPLETE>>");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean content(ByteBuffer buffer, boolean last)
|
|
||||||
{
|
|
||||||
if (BufferUtil.hasContent(buffer))
|
|
||||||
content.add(BufferUtil.toString(buffer));
|
|
||||||
if (last)
|
|
||||||
content.add("<<LAST>>");
|
|
||||||
return last;
|
|
||||||
}
|
|
||||||
|
|
||||||
},"BOUNDARY");
|
|
||||||
ByteBuffer data = BufferUtil.toBuffer("");
|
|
||||||
|
|
||||||
data = BufferUtil.toBuffer("--BOUNDARY\r\n"
|
|
||||||
+ "name: value\n"
|
+ "name: value\n"
|
||||||
+ "\r\n"
|
+ "\r\n"
|
||||||
+ "Hello"
|
+ "Hello"
|
||||||
+ "\r\n"
|
+ "\r\n"
|
||||||
+ "--BOUNDARY\r\n"
|
+ "--BOUNDARY\r\n"
|
||||||
+ "powerLevel: 9001"
|
+ "powerLevel: 9001\n"
|
||||||
+ "\r\n"
|
+ "\r\n"
|
||||||
+ "secondary"
|
+ "secondary"
|
||||||
+ "\r\n"
|
+ "\r\n"
|
||||||
|
@ -428,15 +376,14 @@ public class MultiPartParserTest
|
||||||
/* Test First Content Section */
|
/* Test First Content Section */
|
||||||
parser.parse(data,false);
|
parser.parse(data,false);
|
||||||
assertThat(parser.getState(), is(State.DELIMITER));
|
assertThat(parser.getState(), is(State.DELIMITER));
|
||||||
assertThat(fields,Matchers.contains("name: value", "<<COMPLETE>>"));
|
assertThat(handler.fields, Matchers.contains("name: value", "<<COMPLETE>>"));
|
||||||
assertThat(content,Matchers.contains("Hello","<<LAST>>"));
|
assertThat(handler.content, Matchers.contains("Hello","<<LAST>>"));
|
||||||
|
|
||||||
|
|
||||||
/* Test Second Content Section */
|
/* Test Second Content Section */
|
||||||
parser.parse(data,false);
|
parser.parse(data,false);
|
||||||
assertThat(parser.getState(), is(State.DELIMITER));
|
assertThat(parser.getState(), is(State.DELIMITER));
|
||||||
assertThat(fields,Matchers.contains("name: value", "<<COMPLETE>>","powerLevel: 9001"));
|
assertThat(handler.fields, Matchers.contains("name: value", "<<COMPLETE>>","powerLevel: 9001","<<COMPLETE>>"));
|
||||||
assertThat(content,Matchers.contains("Hello","<<LAST>>","secondary\r\ncontent"));
|
assertThat(handler.content, Matchers.contains("Hello","<<LAST>>","secondary\r\ncontent","<<LAST>>"));
|
||||||
|
|
||||||
/* Test Progression to EPILOGUE State */
|
/* Test Progression to EPILOGUE State */
|
||||||
parser.parse(data,false);
|
parser.parse(data,false);
|
||||||
|
@ -444,7 +391,7 @@ public class MultiPartParserTest
|
||||||
assertThat(data.remaining(),is(0));
|
assertThat(data.remaining(),is(0));
|
||||||
|
|
||||||
/* Test Progression to END State */
|
/* Test Progression to END State */
|
||||||
parser.parse(data,false);
|
parser.parse(data,true);
|
||||||
assertThat(parser.getState(), is(State.END));
|
assertThat(parser.getState(), is(State.END));
|
||||||
assertThat(data.remaining(),is(0));
|
assertThat(data.remaining(),is(0));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue