質問

私はCommons-Fileuploadを使用するフレームワークで働いています。

今、私はユニットテストクラスを書く必要があります。 ServletFileuploadがインターフェイスではない場合、私の疑いは模擬テストを書く方法です。私のクラスをテストする別の方法がありますか?

昨日、私はサーブレット部品にモッキートを使用してユニットテストを書きましたが、それは簡単です。しかし、Commons-Fileuploadのテストを書く方法を考えることはできません。

役に立ちましたか?

解決

基本に戻って、ラッピングまたは拡張してオーバーライドすることでモックオブジェクトをハンドロールすることができます。時には、すべてのモッキングフレームワークに依存しないことがあります。

モッキングモッキングとテストの結果

他のヒント

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にしっかりと結合しているようです...

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top