480764 Add extra tests for empty multipart.
This commit is contained in:
parent
9f430ae7f7
commit
6f6ccdf061
|
@ -64,6 +64,17 @@ public class MultipartFilterTest
|
|||
private ServletTester tester;
|
||||
FilterHolder multipartFilter;
|
||||
|
||||
|
||||
public static class NullServlet extends HttpServlet
|
||||
{
|
||||
@Override
|
||||
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
|
||||
{
|
||||
resp.setStatus(200);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public static class FilenameServlet extends TestServlet
|
||||
{
|
||||
@Override
|
||||
|
@ -144,6 +155,70 @@ public class MultipartFilterTest
|
|||
tester=null;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFinalBoundaryOnly() throws Exception
|
||||
{
|
||||
|
||||
tester.addServlet(NullServlet.class,"/null");
|
||||
HttpTester.Request request = HttpTester.newRequest();
|
||||
HttpTester.Response response;
|
||||
|
||||
// test GET
|
||||
request.setMethod("POST");
|
||||
request.setVersion("HTTP/1.0");
|
||||
request.setHeader("Host","tester");
|
||||
request.setURI("/context/null");
|
||||
|
||||
String delimiter = "\r\n";
|
||||
final String boundary = "MockMultiPartTestBoundary";
|
||||
String content =
|
||||
delimiter +
|
||||
"Hello world" +
|
||||
delimiter + // Two delimiter markers, which make an empty line.
|
||||
delimiter +
|
||||
"--" + boundary + "--" + delimiter;
|
||||
|
||||
request.setHeader("Content-Type","multipart/form-data; boundary="+boundary);
|
||||
request.setContent(content);
|
||||
|
||||
try(StacklessLogging stackless = new StacklessLogging(ServletHandler.class))
|
||||
{
|
||||
response = HttpTester.parseResponse(tester.getResponses(request.generate()));
|
||||
assertEquals(HttpServletResponse.SC_OK,response.getStatus());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testEmpty() throws Exception
|
||||
{
|
||||
|
||||
tester.addServlet(NullServlet.class,"/null");
|
||||
|
||||
HttpTester.Request request = HttpTester.newRequest();
|
||||
HttpTester.Response response;
|
||||
|
||||
// test GET
|
||||
request.setMethod("POST");
|
||||
request.setVersion("HTTP/1.0");
|
||||
request.setHeader("Host","tester");
|
||||
request.setURI("/context/null");
|
||||
|
||||
String delimiter = "\r\n";
|
||||
final String boundary = "MockMultiPartTestBoundary";
|
||||
String content =
|
||||
delimiter +
|
||||
"--" + boundary + "--" + delimiter;
|
||||
|
||||
request.setHeader("Content-Type","multipart/form-data; boundary="+boundary);
|
||||
request.setContent(content);
|
||||
|
||||
try(StacklessLogging stackless = new StacklessLogging(ServletHandler.class))
|
||||
{
|
||||
response = HttpTester.parseResponse(tester.getResponses(request.generate()));
|
||||
assertEquals(HttpServletResponse.SC_OK,response.getStatus());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBadPost() throws Exception
|
||||
{
|
||||
|
|
|
@ -63,6 +63,7 @@ public class MultiPartInputStreamTest
|
|||
_tmpDir.deleteOnExit();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBadMultiPartRequest()
|
||||
throws Exception
|
||||
{
|
||||
|
@ -75,9 +76,9 @@ public class MultiPartInputStreamTest
|
|||
|
||||
MultipartConfigElement config = new MultipartConfigElement(_dirname, 1024, 3072, 50);
|
||||
MultiPartInputStreamParser mpis = new MultiPartInputStreamParser(new ByteArrayInputStream(str.getBytes()),
|
||||
"multipart/form-data, boundary="+boundary,
|
||||
config,
|
||||
_tmpDir);
|
||||
"multipart/form-data, boundary="+boundary,
|
||||
config,
|
||||
_tmpDir);
|
||||
mpis.setDeleteOnExit(true);
|
||||
try
|
||||
{
|
||||
|
@ -91,6 +92,55 @@ public class MultiPartInputStreamTest
|
|||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testFinalBoundaryOnly()
|
||||
throws Exception
|
||||
{
|
||||
String delimiter = "\r\n";
|
||||
final String boundary = "MockMultiPartTestBoundary";
|
||||
|
||||
|
||||
// Malformed multipart request body containing only an arbitrary string of text, followed by the final boundary marker, delimited by empty lines.
|
||||
String str =
|
||||
delimiter +
|
||||
"Hello world" +
|
||||
delimiter + // Two delimiter markers, which make an empty line.
|
||||
delimiter +
|
||||
"--" + boundary + "--" + delimiter;
|
||||
|
||||
MultipartConfigElement config = new MultipartConfigElement(_dirname, 1024, 3072, 50);
|
||||
MultiPartInputStreamParser mpis = new MultiPartInputStreamParser(new ByteArrayInputStream(str.getBytes()),
|
||||
"multipart/form-data, boundary="+boundary,
|
||||
config,
|
||||
_tmpDir);
|
||||
mpis.setDeleteOnExit(true);
|
||||
Collection<Part> parts = mpis.getParts();
|
||||
assertTrue(mpis.getParts().isEmpty());
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testEmpty()
|
||||
throws Exception
|
||||
{
|
||||
String delimiter = "\r\n";
|
||||
final String boundary = "MockMultiPartTestBoundary";
|
||||
|
||||
String str =
|
||||
delimiter +
|
||||
"--" + boundary + "--" + delimiter;
|
||||
|
||||
MultipartConfigElement config = new MultipartConfigElement(_dirname, 1024, 3072, 50);
|
||||
MultiPartInputStreamParser mpis = new MultiPartInputStreamParser(new ByteArrayInputStream(str.getBytes()),
|
||||
"multipart/form-data, boundary="+boundary,
|
||||
config,
|
||||
_tmpDir);
|
||||
mpis.setDeleteOnExit(true);
|
||||
assertTrue(mpis.getParts().isEmpty());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testNoBoundaryRequest()
|
||||
throws Exception
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue