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:
Lachlan Roberts 2018-03-13 20:21:10 +11:00
parent faa32f0c71
commit 20c9fb45f8
1 changed files with 18 additions and 71 deletions

View File

@ -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));
} }