在单元测试中重新启动嵌入式代理:VMTransportServer已绑定

时间:2013-08-19 11:55:09

标签: java unit-testing activemq

我正在尝试编写一个模拟“经纪人下行”阶段的测试。 因此我想

  1. 启动本地经纪人
  2. 发送消息1
  3. 停止经纪人
  4. 发送消息2(当然不会到达)
  5. 再次启动经纪人
  6. 发送消息3
  7. 根据http://activemq.apache.org/how-do-i-restart-embedded-broker.html,建议初始化一个新的BrokerService以再次启动代理。 所以代码看起来(几乎)像这样:

    private BrokerService _broker;
    
    private void startBroker() throws Exception {
        _broker = new BrokerService(); 
        _broker.addConnector("vm://localhost?broker.persistent=false");
        _broker.start();
        _broker.waitUntilStarted();
    }
    
    private void stopBroker() throws Exception {
        _broker.stop();
        _broker.waitUntilStopped();
    }
    
    @Test
    public void publishMessagesWithServerBreakdownInBetween()
        throws Exception
    {
        startBroker();
        ... send and receive message (works fine)
        stopBroker();
        ... send message (fails of course)  
        startBroker(); // this fails with java.io.IOException: VMTransportServer already bound at: vm://localhost?broker.persistent=false
        ... send and receive message
    }
    

    问题已在代码中作为注释提及: 由于错误导致代理重新启动失败: java.io.IOException:VMTransportServer已绑定:vm:// localhost?broker.persistent = false

    我在ActiveMQ论坛(http://activemq.2283324.n4.nabble.com/VMTransportServer-already-bound-td2364603.html)发现了类似的问题,但在我的情况下,主机名不为空。

    另一个想法是设置2个不同的经纪人名称,但这也没有帮助。

    我做错了什么?

1 个答案:

答案 0 :(得分:0)

由于要将其添加到已创建的代理中,因此您要告诉VM不要尝试为您创建代理,从而控制VM传输的功能。剩下的就很简单了:

public class AMQRestartTest {

    private BrokerService broker;
    private String connectorURI;
    private ActiveMQConnectionFactory factory;

    @Before
    public void startBroker() throws Exception {
        createBroker(true);
        factory = new ActiveMQConnectionFactory("failover://" + connectorURI);
    }

    private void createBroker(boolean deleteAllMessages) throws Exception {
        broker = new BrokerService();
        TransportConnector connector = broker.addConnector("vm://localhost?create=false");

        broker.setPersistent(false);
        broker.start();
        broker.waitUntilStarted();

        connectorURI = connector.getConnectUri().toString();
    }

    @Test(timeout = 60_000)
    public void test() throws Exception {
        Connection connection = factory.createConnection();
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        Queue queue = session.createQueue("test");
        MessageConsumer consumer = session.createConsumer(queue);
        MessageProducer producer = session.createProducer(queue);

        connection.start();

        broker.stop();
        broker.waitUntilStopped();
        createBroker(false);

        producer.send(session.createTextMessage("help!"));

        Message received = consumer.receive();

        assertNotNull(received);
        assertTrue(received instanceof TextMessage);
    }
}