8

javax.mail.Messageインスタンスを処理するメソッドをユニットテストしようとしています。

さまざまな形式で届き、一貫した内部形式に変換される電子メールを変更するためのコンバーターを作成しています(MyMessage)。この変換は通常、電子メールの差出人アドレスまたは返信アドレスに依存し、電子メールの一部、件名、および差出人アドレスと返信アドレスが新しいを作成するために必要になりますMyMessage

ローカルにファイルとして保存されている生の電子メールのコレクションがあり、クラスパスからファイルをロードしてインスタンスに変換する.eml単体テストを作成したいと思います。これは可能ですか?もしそうなら、それはどのように行われますか?.emljavax.mail.Message

4

2 に答える 2

12

いくつかのテストの後、私は最終的にMimeMessage(Session, InputStream)パブリックコンストラクターを使用してメッセージを正常にロードしました(他の応答で引用されているフォルダーベースの保護されたコンストラクターとは対照的です)。

import java.io.FileInputStream;
import java.io.InputStream;

import javax.mail.internet.MimeMessage;

public class LoadEML {

    public static void main(String[] args) throws Exception {
        InputStream is = new FileInputStream(args[0]);
        MimeMessage mime = new MimeMessage(null, is);
        System.out.println("Subject: " + mime.getSubject());
    }

}
于 2011-01-10T18:12:19.380 に答える
0

私の問題は、Mockitoを使用してのコンストラクターでjavax.mail.Folder必要なものをモックすることから生じました。これにより、コンストラクターが呼び出され、そのコンストラクターがにアクセスします。これにより、のコンストラクターによってスローされました。javax.mail.internet.MimeMessageMimeMessage(Folder, InputStream, int)javax.mail.Message Message(Folder, int)folder.store.sessionNullPointerExceptionMimeMessage

解決:

class ClasspathMimeMessage extends MimeMessage {
    private ClasspathMimeMessage(Folder folder, InputStream is, int msgnum) throws MessagingException {
        super(folder, is, 0);
    }

    public static MimeMessage create(String resourceName) {
        Class<PopEmailMmsReceiverTest> loaderClass = PopEmailMmsReceiverTest.class;
        InputStream is = loaderClass.getResourceAsStream(resourceName);

        Folder inbox = new MyFolder();

        try {
            return new ClasspathMimeMessage(inbox, is, 0);
        } catch (MessagingException ex) {
            throw new RuntimeException("Unable to load email from classpath at " + loaderClass.getResource(resourceName).toString());
        }
    }
}

class MyFolder extends Folder {
    MyFolder() {
        super(createMockStore());
    }
    private static Store createMockStore() {
        return mock(Store.class);
    }
    public void appendMessages(Message[] msgs) throws MessagingException {
    }
    public void close(boolean expunge) throws MessagingException {
    }
    public boolean create(int type) throws MessagingException {
        return false;
    }
    public boolean delete(boolean recurse) throws MessagingException {
        return false;
    }
    public boolean exists() throws MessagingException {
        return false;
    }
    public Message[] expunge() throws MessagingException {
        return null;
    }
    public Folder getFolder(String name) throws MessagingException {
        return null;
    }
    public String getFullName() {
        return null;
    }
    public Message getMessage(int msgnum) throws MessagingException {
        return null;
    }
    public int getMessageCount() throws MessagingException {
        return 0;
    }
    public String getName() {
        return null;
    }
    public Folder getParent() throws MessagingException {
        return null;
    }
    public Flags getPermanentFlags() {
        return null;
    }
    public char getSeparator() throws MessagingException {
        return 0;
    }
    public int getType() throws MessagingException {
        return 0;
    }
    public boolean hasNewMessages() throws MessagingException {
        return false;
    }
    public boolean isOpen() {
        return false;
    }
    public Folder[] list(String pattern) throws MessagingException {
        return null;
    }
    public void open(int mode) throws MessagingException {
    }
    public boolean renameTo(Folder f) throws MessagingException {
        return false;
    }   
}

これは私には非常に醜いように見えるので、誰かがより良い提案を持っているなら、私はそれを聞いてうれしいです。

于 2010-05-06T15:29:51.930 に答える