测试发送的电子邮件 - Dumbster和greenmail没有捕获发送的JavaMail

时间:2012-10-02 07:08:29

标签: java email testing javamail greenmail

我正在尝试集成Dumbster来测试基于JavaMail的通知程序,以便发送外发电子邮件。电子邮件会被发送,但在我的测试中,Dumbster不接收它们。我不确定我是否需要额外的配置才能完成这项工作,但在它所说的dumbster主页上,它会自动收听通过端口25上的smtp发送的邮件。

这是我们的java邮件设置:

<bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
    <property name="host" value="smtp.somewhere.com" />
    <property name="port" value="25" />
    <property name="username" value="theUserName" />
    <property name="password" value="thePassword" />

    <property name="javaMailProperties">
        <props>
            <prop key="mail.smtp.auth">true</prop>
            <prop key="mail.smtp.starttls.enable">true</prop>
        </props>
    </property>
</bean>

我们的Mailer类只是注入了JavaMailer:

@Component
public class OurMailer {

    @Inject
    private MailSender mailSender;

    public void sendMail(String from, String to, String subject, String msg) {

        SimpleMailMessage message = new SimpleMailMessage();

        message.setFrom(from);
        message.setTo(to);
        message.setSubject(subject);
        message.setText(msg);
        mailSender.send(message);
    }

测试非常直接,因为他们在他们的页面上展示:

@Inject
private OurMailer ourMailer;

@Test
public void ourMailer_should_send_mail() {
    SimpleSmtpServer server = SimpleSmtpServer.start();
    ourMailer.sendMail(FROM_EMAIL, TO_EMAIL, SUBJECT, MESSAGE);
    server.stop();
    Assert.assertTrue(server.getReceivedEmailSize() == 1);
}

正如我所说,邮件被发送但Assert失败。

有什么想法吗?

顺便说一句:我也试过Greenmail但结果相同:

maven略有不同:

    <dependency>
        <groupId>com.icegreen</groupId>
        <artifactId>greenmail</artifactId>
        <version>1.3.1b</version>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

测试

    GreenMail greenMail = new GreenMail(); //uses test ports by default
    greenMail.start();
    // send mail
    Assert.assertEquals("subject", greenMail.getReceivedMessages()[0].getSubject());
    greenMail.stop();

2 个答案:

答案 0 :(得分:3)

测试失败,因为配置显示“将邮件发送到SMTP服务器smtp.somewhere.com”,但您想将其发送到SimpleSmtpServer上运行的localhost

host bean的mailSender参数使用System属性,并在运行测试时将其设置为localhost

那就是说,我建议把测试分成两部分。第一个测试应该确保使用正确的参数调用该方法。这样你就会知道代码试图在正确的时间发送邮件;在单元测试中测试SMTP身份验证,邮件服务器,邮件基础结构和网络没有什么意义 - 所有这些都由各自的制造商进行测试。

第二个测试应该只测试方法sendMail()方法。将该测试放入可以手动运行的测试套件中。您在此处想知道的是,您是否正确设置并使用MailSender API。除非您更改sendMail()方法中的代码,否则您根本不必运行此测试。

这将加速您的单元测试并消除许多不必要的依赖关系,即使您的代码正常工作,也可能导致测试失败。

答案 1 :(得分:0)

注意:似乎有更新版本的Dumbster(原始来源无法提供)可能修复了您遇到的挂起错误:

sourceforge.net/p/dumbster/patches/9 /

https://github.com/rjo1970/dumbster

git-wip-us.apache.org/repos/asf?p=logging-log4j2.git;a=commit;h=b0f7be4b0666dca22205e6df5c7374677daa416e

现在Greenmail似乎住在这里:

https://github.com/greenmail-mail-test/greenmail