Как писать модульные тесты с помощью общего пользования?
-
11-10-2019 - |
Вопрос
Я работаю в рамках, которая использует Commons-FileUpload.
Теперь мне нужно написать классы тестирования модуля. Я сомневаюсь в том, как написать фиктивные тесты, если ServletFileUpload не является интерфейсом? Есть другой способ проверить мои занятия?
Вчера я написал модульные тесты, используя Mockito для деталей сервлета, и это легко. Но я не могу думать, как писать тесты для общинного обстановки.
Решение
Вы можете вернуться к основаниям и рукой рукой своему фиктивному объекту, обернув или расширив и переопределяя. Иногда легче не зависеть от насмешливой структуры для всего.
Другие советы
Вы можете использовать Commons httpclient для создания многопоточного потока:
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.apache.http.HttpEntity;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import javax.servlet.ServletException;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class ServletFileUploadMock {
public static class FileUpload {
private final String filename;
private final String mimeType;
private final byte[] contents;
public FileUpload(String filename, String mimeType, byte[] contents) {
this.filename = filename;
this.mimeType = mimeType;
this.contents = contents;
}
}
public static HttpServletResponse mockServletFileUpload(HttpServlet servlet, List<FileUpload> files,
Map<String, String> queryParams) throws IOException, ServletException {
MultipartEntityBuilder builder = MultipartEntityBuilder.create();
for (FileUpload f : files) {
builder = builder.addBinaryBody(f.filename, f.contents, ContentType.create(f.mimeType), f.filename);
}
HttpEntity entity = builder.build();
ByteArrayOutputStream os = new ByteArrayOutputStream();
entity.writeTo(os);
ByteArrayInputStream is = new ByteArrayInputStream(os.toByteArray());
HttpServletRequest mockRequest = mock(HttpServletRequest.class);
when(mockRequest.getMethod()).thenReturn("POST");
when(mockRequest.getContentType()).thenReturn(entity.getContentType().getValue());
when(mockRequest.getContentLength()).thenReturn((int)entity.getContentLength());
when(mockRequest.getInputStream()).thenReturn(new MockServletInputStream(is));
// Mock query params
for (Entry<String, String> p : queryParams.entrySet()) {
when(mockRequest.getParameter(p.getKey())).thenReturn(p.getValue());
}
HttpServletResponse mockResponse = mock(HttpServletResponse.class);
servlet.service(mockRequest, mockResponse);
return mockResponse;
}
public static class MockServletInputStream extends ServletInputStream {
private final InputStream delegate;
public MockServletInputStream(InputStream delegate) {
this.delegate = delegate;
}
@Override
public int read() throws IOException {
return delegate.read();
}
}
}
Я бы рассмотрел обертывание ваших вызовов FileUpload в другой слой. Хотя это может показаться излишним, это позволит вам очень быстро переключать библиотеки загрузки с дополнительной способностью лучше проверить ваши вызовы ... кажется, что вы тесно связаете свое приложение с Commons-FileUpload ...